Update api docs
Change-Id: I44f59a4b066929dcbd5d8f07df87d0d600a4aca8
diff --git a/TestON/Documentation/TestON_Document/TestON.tests.HAsanity.HAsanity-pysrc.html b/TestON/Documentation/TestON_Document/TestON.tests.HAsanity.HAsanity-pysrc.html
new file mode 100644
index 0000000..17b39dc
--- /dev/null
+++ b/TestON/Documentation/TestON_Document/TestON.tests.HAsanity.HAsanity-pysrc.html
@@ -0,0 +1,4672 @@
+<?xml version="1.0" encoding="ascii"?>
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
+ "DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
+<head>
+ <title>TestON.tests.HAsanity.HAsanity</title>
+ <link rel="stylesheet" href="epydoc.css" type="text/css" />
+ <script type="text/javascript" src="epydoc.js"></script>
+</head>
+
+<body bgcolor="white" text="black" link="blue" vlink="#204080"
+ alink="#204080">
+<!-- ==================== NAVIGATION BAR ==================== -->
+<table class="navbar" border="0" width="100%" cellpadding="0"
+ bgcolor="#a0c0ff" cellspacing="0">
+ <tr valign="middle">
+ <!-- Home link -->
+ <th> <a
+ href="TestON-module.html">Home</a> </th>
+
+ <!-- Tree link -->
+ <th> <a
+ href="module-tree.html">Trees</a> </th>
+
+ <!-- Index link -->
+ <th> <a
+ href="identifier-index.html">Indices</a> </th>
+
+ <!-- Help link -->
+ <th> <a
+ href="help.html">Help</a> </th>
+
+ <!-- Project homepage -->
+ <th class="navbar" align="right" width="100%">
+ <table border="0" cellpadding="0" cellspacing="0">
+ <tr><th class="navbar" align="center"
+ >TestON</th>
+ </tr></table></th>
+ </tr>
+</table>
+<table width="100%" cellpadding="0" cellspacing="0">
+ <tr valign="top">
+ <td width="100%">
+ <span class="breadcrumbs">
+ <a href="TestON-module.html">Package TestON</a> ::
+ <a href="TestON.tests-module.html">Package tests</a> ::
+ <a href="TestON.tests.HAsanity-module.html">Package HAsanity</a> ::
+ Module HAsanity
+ </span>
+ </td>
+ <td>
+ <table cellpadding="0" cellspacing="0">
+ <!-- hide/show private -->
+ <tr><td align="right"><span class="options">[<a href="javascript:void(0);" class="privatelink"
+ onclick="toggle_private();">hide private</a>]</span></td></tr>
+ <tr><td align="right"><span class="options"
+ >[<a href="frames.html" target="_top">frames</a
+ >] | <a href="TestON.tests.HAsanity.HAsanity-pysrc.html"
+ target="_top">no frames</a>]</span></td></tr>
+ </table>
+ </td>
+ </tr>
+</table>
+<h1 class="epydoc">Source Code for <a href="TestON.tests.HAsanity.HAsanity-module.html">Module TestON.tests.HAsanity.HAsanity</a></h1>
+<pre class="py-src">
+<a name="L1"></a><tt class="py-lineno"> 1</tt> <tt class="py-line"><tt class="py-docstring">"""</tt> </tt>
+<a name="L2"></a><tt class="py-lineno"> 2</tt> <tt class="py-line"><tt class="py-docstring">Description: This test is to determine if the HA test setup is</tt> </tt>
+<a name="L3"></a><tt class="py-lineno"> 3</tt> <tt class="py-line"><tt class="py-docstring"> working correctly. There are no failures so this test should</tt> </tt>
+<a name="L4"></a><tt class="py-lineno"> 4</tt> <tt class="py-line"><tt class="py-docstring"> have a 100% pass rate</tt> </tt>
+<a name="L5"></a><tt class="py-lineno"> 5</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt>
+<a name="L6"></a><tt class="py-lineno"> 6</tt> <tt class="py-line"><tt class="py-docstring">List of test cases:</tt> </tt>
+<a name="L7"></a><tt class="py-lineno"> 7</tt> <tt class="py-line"><tt class="py-docstring">CASE1: Compile ONOS and push it to the test machines</tt> </tt>
+<a name="L8"></a><tt class="py-lineno"> 8</tt> <tt class="py-line"><tt class="py-docstring">CASE2: Assign devices to controllers</tt> </tt>
+<a name="L9"></a><tt class="py-lineno"> 9</tt> <tt class="py-line"><tt class="py-docstring">CASE21: Assign mastership to controllers</tt> </tt>
+<a name="L10"></a><tt class="py-lineno"> 10</tt> <tt class="py-line"><tt class="py-docstring">CASE3: Assign intents</tt> </tt>
+<a name="L11"></a><tt class="py-lineno"> 11</tt> <tt class="py-line"><tt class="py-docstring">CASE4: Ping across added host intents</tt> </tt>
+<a name="L12"></a><tt class="py-lineno"> 12</tt> <tt class="py-line"><tt class="py-docstring">CASE5: Reading state of ONOS</tt> </tt>
+<a name="L13"></a><tt class="py-lineno"> 13</tt> <tt class="py-line"><tt class="py-docstring">CASE6: The Failure case. Since this is the Sanity test, we do nothing.</tt> </tt>
+<a name="L14"></a><tt class="py-lineno"> 14</tt> <tt class="py-line"><tt class="py-docstring">CASE7: Check state after control plane failure</tt> </tt>
+<a name="L15"></a><tt class="py-lineno"> 15</tt> <tt class="py-line"><tt class="py-docstring">CASE8: Compare topo</tt> </tt>
+<a name="L16"></a><tt class="py-lineno"> 16</tt> <tt class="py-line"><tt class="py-docstring">CASE9: Link s3-s28 down</tt> </tt>
+<a name="L17"></a><tt class="py-lineno"> 17</tt> <tt class="py-line"><tt class="py-docstring">CASE10: Link s3-s28 up</tt> </tt>
+<a name="L18"></a><tt class="py-lineno"> 18</tt> <tt class="py-line"><tt class="py-docstring">CASE11: Switch down</tt> </tt>
+<a name="L19"></a><tt class="py-lineno"> 19</tt> <tt class="py-line"><tt class="py-docstring">CASE12: Switch up</tt> </tt>
+<a name="L20"></a><tt class="py-lineno"> 20</tt> <tt class="py-line"><tt class="py-docstring">CASE13: Clean up</tt> </tt>
+<a name="L21"></a><tt class="py-lineno"> 21</tt> <tt class="py-line"><tt class="py-docstring">CASE14: start election app on all onos nodes</tt> </tt>
+<a name="L22"></a><tt class="py-lineno"> 22</tt> <tt class="py-line"><tt class="py-docstring">CASE15: Check that Leadership Election is still functional</tt> </tt>
+<a name="L23"></a><tt class="py-lineno"> 23</tt> <tt class="py-line"><tt class="py-docstring">CASE16: Install Distributed Primitives app</tt> </tt>
+<a name="L24"></a><tt class="py-lineno"> 24</tt> <tt class="py-line"><tt class="py-docstring">CASE17: Check for basic functionality with distributed primitives</tt> </tt>
+<a name="L25"></a><tt class="py-lineno"> 25</tt> <tt class="py-line"><tt class="py-docstring">"""</tt> </tt>
+<a name="L26"></a><tt class="py-lineno"> 26</tt> <tt class="py-line"> </tt>
+<a name="L27"></a><tt class="py-lineno"> 27</tt> <tt class="py-line"> </tt>
+<a name="HAsanity"></a><div id="HAsanity-def"><a name="L28"></a><tt class="py-lineno"> 28</tt> <a class="py-toggle" href="#" id="HAsanity-toggle" onclick="return toggle('HAsanity');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html">HAsanity</a><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="HAsanity-expanded"><a name="L29"></a><tt class="py-lineno"> 29</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.__init__"></a><div id="HAsanity.__init__-def"><a name="L30"></a><tt class="py-lineno"> 30</tt> <a class="py-toggle" href="#" id="HAsanity.__init__-toggle" onclick="return toggle('HAsanity.__init__');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#__init__">__init__</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.__init__-expanded"><a name="L31"></a><tt class="py-lineno"> 31</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-0" class="py-name" targets="Method TestON.bin.cli.CLI.default()=TestON.bin.cli.CLI-class.html#default"><a title="TestON.bin.cli.CLI.default" class="py-name" href="#" onclick="return doclink('link-0', 'default', 'link-0');">default</a></tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
+</div><a name="L32"></a><tt class="py-lineno"> 32</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE1"></a><div id="HAsanity.CASE1-def"><a name="L33"></a><tt class="py-lineno"> 33</tt> <a class="py-toggle" href="#" id="HAsanity.CASE1-toggle" onclick="return toggle('HAsanity.CASE1');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE1">CASE1</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE1-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE1-expanded"><a name="L34"></a><tt class="py-lineno"> 34</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L35"></a><tt class="py-lineno"> 35</tt> <tt class="py-line"><tt class="py-docstring"> CASE1 is to compile ONOS and push it to the test machines</tt> </tt>
+<a name="L36"></a><tt class="py-lineno"> 36</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt>
+<a name="L37"></a><tt class="py-lineno"> 37</tt> <tt class="py-line"><tt class="py-docstring"> Startup sequence:</tt> </tt>
+<a name="L38"></a><tt class="py-lineno"> 38</tt> <tt class="py-line"><tt class="py-docstring"> cell <name></tt> </tt>
+<a name="L39"></a><tt class="py-lineno"> 39</tt> <tt class="py-line"><tt class="py-docstring"> onos-verify-cell</tt> </tt>
+<a name="L40"></a><tt class="py-lineno"> 40</tt> <tt class="py-line"><tt class="py-docstring"> NOTE: temporary - onos-remove-raft-logs</tt> </tt>
+<a name="L41"></a><tt class="py-lineno"> 41</tt> <tt class="py-line"><tt class="py-docstring"> onos-uninstall</tt> </tt>
+<a name="L42"></a><tt class="py-lineno"> 42</tt> <tt class="py-line"><tt class="py-docstring"> start mininet</tt> </tt>
+<a name="L43"></a><tt class="py-lineno"> 43</tt> <tt class="py-line"><tt class="py-docstring"> git pull</tt> </tt>
+<a name="L44"></a><tt class="py-lineno"> 44</tt> <tt class="py-line"><tt class="py-docstring"> mvn clean install</tt> </tt>
+<a name="L45"></a><tt class="py-lineno"> 45</tt> <tt class="py-line"><tt class="py-docstring"> onos-package</tt> </tt>
+<a name="L46"></a><tt class="py-lineno"> 46</tt> <tt class="py-line"><tt class="py-docstring"> onos-install -f</tt> </tt>
+<a name="L47"></a><tt class="py-lineno"> 47</tt> <tt class="py-line"><tt class="py-docstring"> onos-wait-for-start</tt> </tt>
+<a name="L48"></a><tt class="py-lineno"> 48</tt> <tt class="py-line"><tt class="py-docstring"> start cli sessions</tt> </tt>
+<a name="L49"></a><tt class="py-lineno"> 49</tt> <tt class="py-line"><tt class="py-docstring"> start tcpdump</tt> </tt>
+<a name="L50"></a><tt class="py-lineno"> 50</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L51"></a><tt class="py-lineno"> 51</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">imp</tt> </tt>
+<a name="L52"></a><tt class="py-lineno"> 52</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#log"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS HA Sanity test - initialization"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L53"></a><tt class="py-lineno"> 53</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-2" class="py-name" targets="Method TestON.core.teston.TestON.case()=TestON.core.teston.TestON-class.html#case"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-2', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Setting up test environment"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L54"></a><tt class="py-lineno"> 54</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Setup the test environment including "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L55"></a><tt class="py-lineno"> 55</tt> <tt class="py-line"> <tt class="py-string">"installing ONOS, starting Mininet and ONOS"</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L56"></a><tt class="py-lineno"> 56</tt> <tt class="py-line"> <tt class="py-string">"cli sessions."</tt> </tt>
+<a name="L57"></a><tt class="py-lineno"> 57</tt> <tt class="py-line"> <tt class="py-comment"># TODO: save all the timers and output them for plotting</tt> </tt>
+<a name="L58"></a><tt class="py-lineno"> 58</tt> <tt class="py-line"> </tt>
+<a name="L59"></a><tt class="py-lineno"> 59</tt> <tt class="py-line"> <tt class="py-comment"># load some variables from the params file</tt> </tt>
+<a name="L60"></a><tt class="py-lineno"> 60</tt> <tt class="py-line"> <tt class="py-name">PULLCODE</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L61"></a><tt class="py-lineno"> 61</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'Git'</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'True'</tt><tt class="py-op">:</tt> </tt>
+<a name="L62"></a><tt class="py-lineno"> 62</tt> <tt class="py-line"> <tt class="py-name">PULLCODE</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L63"></a><tt class="py-lineno"> 63</tt> <tt class="py-line"> <tt class="py-name">gitBranch</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'branch'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L64"></a><tt class="py-lineno"> 64</tt> <tt class="py-line"> <tt class="py-name">cellName</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'ENV'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'cellName'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L65"></a><tt class="py-lineno"> 65</tt> <tt class="py-line"> </tt>
+<a name="L66"></a><tt class="py-lineno"> 66</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'num_controllers'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L67"></a><tt class="py-lineno"> 67</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt><tt class="py-op">:</tt> </tt>
+<a name="L68"></a><tt class="py-lineno"> 68</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op"><</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">:</tt> </tt>
+<a name="L69"></a><tt class="py-lineno"> 69</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">)</tt> </tt>
+<a name="L70"></a><tt class="py-lineno"> 70</tt> <tt class="py-line"> <tt class="py-comment"># TODO: refactor how to get onos port, maybe put into component tag?</tt> </tt>
+<a name="L71"></a><tt class="py-lineno"> 71</tt> <tt class="py-line"> <tt class="py-comment"># set global variables</tt> </tt>
+<a name="L72"></a><tt class="py-lineno"> 72</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS1Port</tt> </tt>
+<a name="L73"></a><tt class="py-lineno"> 73</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS2Port</tt> </tt>
+<a name="L74"></a><tt class="py-lineno"> 74</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS3Port</tt> </tt>
+<a name="L75"></a><tt class="py-lineno"> 75</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS4Port</tt> </tt>
+<a name="L76"></a><tt class="py-lineno"> 76</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS5Port</tt> </tt>
+<a name="L77"></a><tt class="py-lineno"> 77</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS6Port</tt> </tt>
+<a name="L78"></a><tt class="py-lineno"> 78</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">ONOS7Port</tt> </tt>
+<a name="L79"></a><tt class="py-lineno"> 79</tt> <tt class="py-line"> </tt>
+<a name="L80"></a><tt class="py-lineno"> 80</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: just get controller port from params?</tt> </tt>
+<a name="L81"></a><tt class="py-lineno"> 81</tt> <tt class="py-line"> <tt class="py-comment"># TODO: do we really need all these?</tt> </tt>
+<a name="L82"></a><tt class="py-lineno"> 82</tt> <tt class="py-line"> <tt class="py-name">ONOS1Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port1'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L83"></a><tt class="py-lineno"> 83</tt> <tt class="py-line"> <tt class="py-name">ONOS2Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port2'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L84"></a><tt class="py-lineno"> 84</tt> <tt class="py-line"> <tt class="py-name">ONOS3Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port3'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L85"></a><tt class="py-lineno"> 85</tt> <tt class="py-line"> <tt class="py-name">ONOS4Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port4'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L86"></a><tt class="py-lineno"> 86</tt> <tt class="py-line"> <tt class="py-name">ONOS5Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port5'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L87"></a><tt class="py-lineno"> 87</tt> <tt class="py-line"> <tt class="py-name">ONOS6Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port6'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L88"></a><tt class="py-lineno"> 88</tt> <tt class="py-line"> <tt class="py-name">ONOS7Port</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'CTRL'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port7'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L89"></a><tt class="py-lineno"> 89</tt> <tt class="py-line"> </tt>
+<a name="L90"></a><tt class="py-lineno"> 90</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L91"></a><tt class="py-lineno"> 91</tt> <tt class="py-line"> <tt class="py-name">fileName</tt> <tt class="py-op">=</tt> <tt class="py-string">"Counters"</tt> </tt>
+<a name="L92"></a><tt class="py-lineno"> 92</tt> <tt class="py-line"> <tt id="link-3" class="py-name" targets="Variable TestON.bin.cli.path=TestON.bin.cli-module.html#path,Variable TestON.core.teston.path=TestON.core.teston-module.html#path"><a title="TestON.bin.cli.path
+TestON.core.teston.path" class="py-name" href="#" onclick="return doclink('link-3', 'path', 'link-3');">path</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'imports'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'path'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L93"></a><tt class="py-lineno"> 93</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-4" class="py-name" targets="Module TestON.tests.HAclusterRestart.dependencies.Counters=TestON.tests.HAclusterRestart.dependencies.Counters-module.html,Module TestON.tests.HAminorityRestart.dependencies.Counters=TestON.tests.HAminorityRestart.dependencies.Counters-module.html,Module TestON.tests.HAsanity.dependencies.Counters=TestON.tests.HAsanity.dependencies.Counters-module.html,Module TestON.tests.HAsingleInstanceRestart.dependencies.Counters=TestON.tests.HAsingleInstanceRestart.dependencies.Counters-module.html"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-4', 'Counters', 'link-4');">Counters</a></tt> <tt class="py-op">=</tt> <tt class="py-name">imp</tt><tt class="py-op">.</tt><tt class="py-name">load_source</tt><tt class="py-op">(</tt> <tt class="py-name">fileName</tt><tt class="py-op">,</tt> </tt>
+<a name="L94"></a><tt class="py-lineno"> 94</tt> <tt class="py-line"> <tt id="link-5" class="py-name"><a title="TestON.bin.cli.path
+TestON.core.teston.path" class="py-name" href="#" onclick="return doclink('link-5', 'path', 'link-3');">path</a></tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> <tt class="py-op">+</tt> <tt class="py-string">".py"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L95"></a><tt class="py-lineno"> 95</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt> <tt class="py-keyword">as</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt>
+<a name="L96"></a><tt class="py-lineno"> 96</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-6" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-6', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">e</tt> <tt class="py-op">)</tt> </tt>
+<a name="L97"></a><tt class="py-lineno"> 97</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-7" class="py-name" targets="Method TestON.core.teston.TestON.cleanup()=TestON.core.teston.TestON-class.html#cleanup"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-7', 'cleanup', 'link-7');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L98"></a><tt class="py-lineno"> 98</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-8" class="py-name" targets="Method TestON.core.teston.TestON.exit()=TestON.core.teston.TestON-class.html#exit"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-8', 'exit', 'link-8');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L99"></a><tt class="py-lineno"> 99</tt> <tt class="py-line"> </tt>
+<a name="L100"></a><tt class="py-lineno"> 100</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L101"></a><tt class="py-lineno"> 101</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-9" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#nodes,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#nodes"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-9', 'nodes', 'link-9');">nodes</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L102"></a><tt class="py-lineno"> 102</tt> <tt class="py-line"> <tt class="py-name">ipList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L103"></a><tt class="py-lineno"> 103</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L104"></a><tt class="py-lineno"> 104</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L105"></a><tt class="py-lineno"> 105</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">getattr</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">'ONOScli'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L106"></a><tt class="py-lineno"> 106</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-10" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-10', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">getattr</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">'ONOS'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L107"></a><tt class="py-lineno"> 107</tt> <tt class="py-line"> <tt class="py-name">ipList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-11" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-11', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-op">-</tt><tt class="py-number">1</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L108"></a><tt class="py-lineno"> 108</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">AttributeError</tt><tt class="py-op">:</tt> </tt>
+<a name="L109"></a><tt class="py-lineno"> 109</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L110"></a><tt class="py-lineno"> 110</tt> <tt class="py-line"> </tt>
+<a name="L111"></a><tt class="py-lineno"> 111</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-12" class="py-name" targets="Method TestON.core.teston.TestON.step()=TestON.core.teston.TestON-class.html#step"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-12', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Create cell file"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L112"></a><tt class="py-lineno"> 112</tt> <tt class="py-line"> <tt class="py-name">cellAppString</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'ENV'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'appString'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L113"></a><tt class="py-lineno"> 113</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-13" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.createCellFile()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#createCellFile"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.createCellFile" class="py-name" href="#" onclick="return doclink('link-13', 'createCellFile', 'link-13');">createCellFile</a></tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt><tt class="py-op">,</tt> <tt class="py-name">cellName</tt><tt class="py-op">,</tt> </tt>
+<a name="L114"></a><tt class="py-lineno"> 114</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt><tt class="py-op">,</tt> </tt>
+<a name="L115"></a><tt class="py-lineno"> 115</tt> <tt class="py-line"> <tt class="py-name">cellAppString</tt><tt class="py-op">,</tt> <tt class="py-name">ipList</tt> <tt class="py-op">)</tt> </tt>
+<a name="L116"></a><tt class="py-lineno"> 116</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-14" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-14', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Applying cell variable to environment"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L117"></a><tt class="py-lineno"> 117</tt> <tt class="py-line"> <tt class="py-name">cellResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-15" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setCell()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#setCell,Method TestON.drivers.common.cli.onosdriver.OnosDriver.setCell()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#setCell"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setCell
+TestON.drivers.common.cli.onosdriver.OnosDriver.setCell" class="py-name" href="#" onclick="return doclink('link-15', 'setCell', 'link-15');">setCell</a></tt><tt class="py-op">(</tt> <tt class="py-name">cellName</tt> <tt class="py-op">)</tt> </tt>
+<a name="L118"></a><tt class="py-lineno"> 118</tt> <tt class="py-line"> <tt class="py-name">verifyResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-16" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.verifyCell()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#verifyCell"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.verifyCell" class="py-name" href="#" onclick="return doclink('link-16', 'verifyCell', 'link-16');">verifyCell</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L119"></a><tt class="py-lineno"> 119</tt> <tt class="py-line"> </tt>
+<a name="L120"></a><tt class="py-lineno"> 120</tt> <tt class="py-line"> <tt class="py-comment"># FIXME:this is short term fix</tt> </tt>
+<a name="L121"></a><tt class="py-lineno"> 121</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-17" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-17', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Removing raft logs"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L122"></a><tt class="py-lineno"> 122</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-18" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosRemoveRaftLogs()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosRemoveRaftLogs"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosRemoveRaftLogs" class="py-name" href="#" onclick="return doclink('link-18', 'onosRemoveRaftLogs', 'link-18');">onosRemoveRaftLogs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L123"></a><tt class="py-lineno"> 123</tt> <tt class="py-line"> </tt>
+<a name="L124"></a><tt class="py-lineno"> 124</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-19" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-19', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstalling ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L125"></a><tt class="py-lineno"> 125</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-20" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-20', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L126"></a><tt class="py-lineno"> 126</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-21" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosUninstall()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosUninstall"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosUninstall" class="py-name" href="#" onclick="return doclink('link-21', 'onosUninstall', 'link-21');">onosUninstall</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L127"></a><tt class="py-lineno"> 127</tt> <tt class="py-line"> </tt>
+<a name="L128"></a><tt class="py-lineno"> 128</tt> <tt class="py-line"> <tt class="py-comment"># Make sure ONOS is DEAD</tt> </tt>
+<a name="L129"></a><tt class="py-lineno"> 129</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-22" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-22', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Killing any ONOS processes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L130"></a><tt class="py-lineno"> 130</tt> <tt class="py-line"> <tt class="py-name">killResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L131"></a><tt class="py-lineno"> 131</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-23" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-23', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L132"></a><tt class="py-lineno"> 132</tt> <tt class="py-line"> <tt class="py-name">killed</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-24" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosKill()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosKill"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosKill" class="py-name" href="#" onclick="return doclink('link-24', 'onosKill', 'link-24');">onosKill</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L133"></a><tt class="py-lineno"> 133</tt> <tt class="py-line"> <tt class="py-name">killResults</tt> <tt class="py-op">=</tt> <tt class="py-name">killResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">killed</tt> </tt>
+<a name="L134"></a><tt class="py-lineno"> 134</tt> <tt class="py-line"> </tt>
+<a name="L135"></a><tt class="py-lineno"> 135</tt> <tt class="py-line"> <tt class="py-name">cleanInstallResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L136"></a><tt class="py-lineno"> 136</tt> <tt class="py-line"> <tt class="py-name">gitPullResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L137"></a><tt class="py-lineno"> 137</tt> <tt class="py-line"> </tt>
+<a name="L138"></a><tt class="py-lineno"> 138</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-25" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-25', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Starting Mininet"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L139"></a><tt class="py-lineno"> 139</tt> <tt class="py-line"> <tt class="py-comment"># scp topo file to mininet</tt> </tt>
+<a name="L140"></a><tt class="py-lineno"> 140</tt> <tt class="py-line"> <tt class="py-comment"># TODO: move to params?</tt> </tt>
+<a name="L141"></a><tt class="py-lineno"> 141</tt> <tt class="py-line"> <tt class="py-name">topoName</tt> <tt class="py-op">=</tt> <tt class="py-string">"obelisk.py"</tt> </tt>
+<a name="L142"></a><tt class="py-lineno"> 142</tt> <tt class="py-line"> <tt class="py-name">filePath</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"/tools/test/topos/"</tt> </tt>
+<a name="L143"></a><tt class="py-lineno"> 143</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-26" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.copyMininetFile()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#copyMininetFile"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.copyMininetFile" class="py-name" href="#" onclick="return doclink('link-26', 'copyMininetFile', 'link-26');">copyMininetFile</a></tt><tt class="py-op">(</tt> <tt class="py-name">topoName</tt><tt class="py-op">,</tt> <tt class="py-name">filePath</tt><tt class="py-op">,</tt> </tt>
+<a name="L144"></a><tt class="py-lineno"> 144</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt class="py-name">user_name</tt><tt class="py-op">,</tt> </tt>
+<a name="L145"></a><tt class="py-lineno"> 145</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L146"></a><tt class="py-lineno"> 146</tt> <tt class="py-line"> <tt class="py-name">mnResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-27" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.startNet()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#startNet"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.startNet" class="py-name" href="#" onclick="return doclink('link-27', 'startNet', 'link-27');">startNet</a></tt><tt class="py-op">(</tt> <tt class="py-op">)</tt> </tt>
+<a name="L147"></a><tt class="py-lineno"> 147</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">mnResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L148"></a><tt class="py-lineno"> 148</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Mininet Started"</tt><tt class="py-op">,</tt> </tt>
+<a name="L149"></a><tt class="py-lineno"> 149</tt> <tt class="py-line"> <tt id="link-28" class="py-name" targets="Method TestON.core.teston.TestON.onfail()=TestON.core.teston.TestON-class.html#onfail,Method TestON.drivers.common.clidriver.CLI.onfail()=TestON.drivers.common.clidriver.CLI-class.html#onfail"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-28', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error starting Mininet"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L150"></a><tt class="py-lineno"> 150</tt> <tt class="py-line"> </tt>
+<a name="L151"></a><tt class="py-lineno"> 151</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-29" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-29', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Git checkout and pull "</tt> <tt class="py-op">+</tt> <tt class="py-name">gitBranch</tt> <tt class="py-op">)</tt> </tt>
+<a name="L152"></a><tt class="py-lineno"> 152</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">PULLCODE</tt><tt class="py-op">:</tt> </tt>
+<a name="L153"></a><tt class="py-lineno"> 153</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-30" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.gitCheckout()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#gitCheckout"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.gitCheckout" class="py-name" href="#" onclick="return doclink('link-30', 'gitCheckout', 'link-30');">gitCheckout</a></tt><tt class="py-op">(</tt> <tt class="py-name">gitBranch</tt> <tt class="py-op">)</tt> </tt>
+<a name="L154"></a><tt class="py-lineno"> 154</tt> <tt class="py-line"> <tt class="py-name">gitPullResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-31" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.gitPull()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#gitPull"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.gitPull" class="py-name" href="#" onclick="return doclink('link-31', 'gitPull', 'link-31');">gitPull</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L155"></a><tt class="py-lineno"> 155</tt> <tt class="py-line"> <tt class="py-comment"># values of 1 or 3 are good</tt> </tt>
+<a name="L156"></a><tt class="py-lineno"> 156</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_lesser</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">gitPullResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L157"></a><tt class="py-lineno"> 157</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Git pull successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L158"></a><tt class="py-lineno"> 158</tt> <tt class="py-line"> <tt id="link-32" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-32', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Git pull failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L159"></a><tt class="py-lineno"> 159</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-33" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getVersion()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getVersion,Method TestON.drivers.common.cli.onosdriver.OnosDriver.getVersion()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getVersion"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getVersion
+TestON.drivers.common.cli.onosdriver.OnosDriver.getVersion" class="py-name" href="#" onclick="return doclink('link-33', 'getVersion', 'link-33');">getVersion</a></tt><tt class="py-op">(</tt> <tt class="py-name">report</tt><tt class="py-op">=</tt><tt class="py-name">True</tt> <tt class="py-op">)</tt> </tt>
+<a name="L160"></a><tt class="py-lineno"> 160</tt> <tt class="py-line"> </tt>
+<a name="L161"></a><tt class="py-lineno"> 161</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-34" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-34', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Using mvn clean install"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L162"></a><tt class="py-lineno"> 162</tt> <tt class="py-line"> <tt class="py-name">cleanInstallResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L163"></a><tt class="py-lineno"> 163</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">PULLCODE</tt> <tt class="py-keyword">and</tt> <tt class="py-name">gitPullResult</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L164"></a><tt class="py-lineno"> 164</tt> <tt class="py-line"> <tt class="py-name">cleanInstallResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-35" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.cleanInstall()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#cleanInstall"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.cleanInstall" class="py-name" href="#" onclick="return doclink('link-35', 'cleanInstall', 'link-35');">cleanInstall</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L165"></a><tt class="py-lineno"> 165</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L166"></a><tt class="py-lineno"> 166</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-36" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-36', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Did not pull new code so skipping mvn "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L167"></a><tt class="py-lineno"> 167</tt> <tt class="py-line"> <tt class="py-string">"clean install"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L168"></a><tt class="py-lineno"> 168</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L169"></a><tt class="py-lineno"> 169</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">cleanInstallResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L170"></a><tt class="py-lineno"> 170</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"MCI successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L171"></a><tt class="py-lineno"> 171</tt> <tt class="py-line"> <tt id="link-37" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-37', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"MCI failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L172"></a><tt class="py-lineno"> 172</tt> <tt class="py-line"> <tt class="py-comment"># GRAPHS</tt> </tt>
+<a name="L173"></a><tt class="py-lineno"> 173</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: important params here:</tt> </tt>
+<a name="L174"></a><tt class="py-lineno"> 174</tt> <tt class="py-line"> <tt class="py-comment"># job = name of Jenkins job</tt> </tt>
+<a name="L175"></a><tt class="py-lineno"> 175</tt> <tt class="py-line"> <tt class="py-comment"># Plot Name = Plot-HA, only can be used if multiple plots</tt> </tt>
+<a name="L176"></a><tt class="py-lineno"> 176</tt> <tt class="py-line"> <tt class="py-comment"># index = The number of the graph under plot name</tt> </tt>
+<a name="L177"></a><tt class="py-lineno"> 177</tt> <tt class="py-line"> <tt class="py-name">job</tt> <tt class="py-op">=</tt> <tt class="py-string">"HAsanity"</tt> </tt>
+<a name="L178"></a><tt class="py-lineno"> 178</tt> <tt class="py-line"> <tt class="py-name">plotName</tt> <tt class="py-op">=</tt> <tt class="py-string">"Plot-HA"</tt> </tt>
+<a name="L179"></a><tt class="py-lineno"> 179</tt> <tt class="py-line"> <tt class="py-name">graphs</tt> <tt class="py-op">=</tt> <tt class="py-string">'<ac:structured-macro ac:name="html">\n'</tt> </tt>
+<a name="L180"></a><tt class="py-lineno"> 180</tt> <tt class="py-line"> <tt class="py-name">graphs</tt> <tt class="py-op">+=</tt> <tt class="py-string">'<ac:plain-text-body><![CDATA[\n'</tt> </tt>
+<a name="L181"></a><tt class="py-lineno"> 181</tt> <tt class="py-line"> <tt class="py-name">graphs</tt> <tt class="py-op">+=</tt> <tt class="py-string">'<iframe src="https://onos-jenkins.onlab.us/job/'</tt> <tt class="py-op">+</tt> <tt class="py-name">job</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L182"></a><tt class="py-lineno"> 182</tt> <tt class="py-line"> <tt class="py-string">'/plot/'</tt> <tt class="py-op">+</tt> <tt class="py-name">plotName</tt> <tt class="py-op">+</tt> <tt class="py-string">'/getPlot?index=0'</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L183"></a><tt class="py-lineno"> 183</tt> <tt class="py-line"> <tt class="py-string">'&width=500&height=300"'</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L184"></a><tt class="py-lineno"> 184</tt> <tt class="py-line"> <tt class="py-string">'noborder="0" width="500" height="300" scrolling="yes" '</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L185"></a><tt class="py-lineno"> 185</tt> <tt class="py-line"> <tt class="py-string">'seamless="seamless"></iframe>\n'</tt> </tt>
+<a name="L186"></a><tt class="py-lineno"> 186</tt> <tt class="py-line"> <tt class="py-name">graphs</tt> <tt class="py-op">+=</tt> <tt class="py-string">']]></ac:plain-text-body>\n'</tt> </tt>
+<a name="L187"></a><tt class="py-lineno"> 187</tt> <tt class="py-line"> <tt class="py-name">graphs</tt> <tt class="py-op">+=</tt> <tt class="py-string">'</ac:structured-macro>\n'</tt> </tt>
+<a name="L188"></a><tt class="py-lineno"> 188</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-38" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-38', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">wiki</tt><tt class="py-op">(</tt><tt class="py-name">graphs</tt><tt class="py-op">)</tt> </tt>
+<a name="L189"></a><tt class="py-lineno"> 189</tt> <tt class="py-line"> </tt>
+<a name="L190"></a><tt class="py-lineno"> 190</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-39" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-39', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Creating ONOS package"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L191"></a><tt class="py-lineno"> 191</tt> <tt class="py-line"> <tt class="py-name">packageResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-40" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosPackage()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosPackage"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosPackage" class="py-name" href="#" onclick="return doclink('link-40', 'onosPackage', 'link-40');">onosPackage</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L192"></a><tt class="py-lineno"> 192</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">packageResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L193"></a><tt class="py-lineno"> 193</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS package successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L194"></a><tt class="py-lineno"> 194</tt> <tt class="py-line"> <tt id="link-41" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-41', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS package failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L195"></a><tt class="py-lineno"> 195</tt> <tt class="py-line"> </tt>
+<a name="L196"></a><tt class="py-lineno"> 196</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-42" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-42', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Installing ONOS package"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L197"></a><tt class="py-lineno"> 197</tt> <tt class="py-line"> <tt class="py-name">onosInstallResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L198"></a><tt class="py-lineno"> 198</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-43" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-43', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L199"></a><tt class="py-lineno"> 199</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-44" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosInstall()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosInstall"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosInstall" class="py-name" href="#" onclick="return doclink('link-44', 'onosInstall', 'link-44');">onosInstall</a></tt><tt class="py-op">(</tt> <tt class="py-name">options</tt><tt class="py-op">=</tt><tt class="py-string">"-f"</tt><tt class="py-op">,</tt> </tt>
+<a name="L200"></a><tt class="py-lineno"> 200</tt> <tt class="py-line"> <tt class="py-name">node</tt><tt class="py-op">=</tt><tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L201"></a><tt class="py-lineno"> 201</tt> <tt class="py-line"> <tt class="py-name">onosInstallResult</tt> <tt class="py-op">=</tt> <tt class="py-name">onosInstallResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L202"></a><tt class="py-lineno"> 202</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">onosInstallResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L203"></a><tt class="py-lineno"> 203</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS install successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L204"></a><tt class="py-lineno"> 204</tt> <tt class="py-line"> <tt id="link-45" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-45', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS install failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L205"></a><tt class="py-lineno"> 205</tt> <tt class="py-line"> </tt>
+<a name="L206"></a><tt class="py-lineno"> 206</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-46" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-46', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Checking if ONOS is up yet"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L207"></a><tt class="py-lineno"> 207</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L208"></a><tt class="py-lineno"> 208</tt> <tt class="py-line"> <tt class="py-name">onosIsupResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L209"></a><tt class="py-lineno"> 209</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-47" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-47', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L210"></a><tt class="py-lineno"> 210</tt> <tt class="py-line"> <tt class="py-name">started</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-48" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.isup()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#isup"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.isup" class="py-name" href="#" onclick="return doclink('link-48', 'isup', 'link-48');">isup</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L211"></a><tt class="py-lineno"> 211</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">started</tt><tt class="py-op">:</tt> </tt>
+<a name="L212"></a><tt class="py-lineno"> 212</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-49" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-49', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-50" class="py-name" targets="Function TestON.bin.cli.error()=TestON.bin.cli-module.html#error"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-50', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">" didn't start!"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L213"></a><tt class="py-lineno"> 213</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-51" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosStop()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStop"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosStop" class="py-name" href="#" onclick="return doclink('link-51', 'onosStop', 'link-51');">onosStop</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L214"></a><tt class="py-lineno"> 214</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-52" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.onosStart()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStart"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosStart" class="py-name" href="#" onclick="return doclink('link-52', 'onosStart', 'link-52');">onosStart</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L215"></a><tt class="py-lineno"> 215</tt> <tt class="py-line"> <tt class="py-name">onosIsupResult</tt> <tt class="py-op">=</tt> <tt class="py-name">onosIsupResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">started</tt> </tt>
+<a name="L216"></a><tt class="py-lineno"> 216</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosIsupResult</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L217"></a><tt class="py-lineno"> 217</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L218"></a><tt class="py-lineno"> 218</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">onosIsupResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L219"></a><tt class="py-lineno"> 219</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS startup successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L220"></a><tt class="py-lineno"> 220</tt> <tt class="py-line"> <tt id="link-53" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-53', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS startup failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L221"></a><tt class="py-lineno"> 221</tt> <tt class="py-line"> </tt>
+<a name="L222"></a><tt class="py-lineno"> 222</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-54" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-54', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-55" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-55', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Starting ONOS CLI sessions"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L223"></a><tt class="py-lineno"> 223</tt> <tt class="py-line"> <tt class="py-name">cliResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L224"></a><tt class="py-lineno"> 224</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L225"></a><tt class="py-lineno"> 225</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L226"></a><tt class="py-lineno"> 226</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-56" class="py-name" targets="Module TestON.core.Thread=TestON.core.Thread-module.html,Class TestON.core.Thread.Thread=TestON.core.Thread.Thread-class.html"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-56', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-57" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.startOnosCli()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#startOnosCli"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.startOnosCli" class="py-name" href="#" onclick="return doclink('link-57', 'startOnosCli', 'link-57');">startOnosCli</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L227"></a><tt class="py-lineno"> 227</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"startOnosCli-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L228"></a><tt class="py-lineno"> 228</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-58" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-58', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L229"></a><tt class="py-lineno"> 229</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L230"></a><tt class="py-lineno"> 230</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L231"></a><tt class="py-lineno"> 231</tt> <tt class="py-line"> </tt>
+<a name="L232"></a><tt class="py-lineno"> 232</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L233"></a><tt class="py-lineno"> 233</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L234"></a><tt class="py-lineno"> 234</tt> <tt class="py-line"> <tt class="py-name">cliResults</tt> <tt class="py-op">=</tt> <tt class="py-name">cliResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L235"></a><tt class="py-lineno"> 235</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">cliResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L236"></a><tt class="py-lineno"> 236</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS cli startup successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L237"></a><tt class="py-lineno"> 237</tt> <tt class="py-line"> <tt id="link-59" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-59', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS cli startup failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L238"></a><tt class="py-lineno"> 238</tt> <tt class="py-line"> </tt>
+<a name="L239"></a><tt class="py-lineno"> 239</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'tcpdump'</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">lower</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-string">"true"</tt><tt class="py-op">:</tt> </tt>
+<a name="L240"></a><tt class="py-lineno"> 240</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-60" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-60', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Start Packet Capture MN"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L241"></a><tt class="py-lineno"> 241</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-61" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.startTcpdump()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#startTcpdump,Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.startTcpdump()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#startTcpdump"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.startTcpdump
+TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.startTcpdump" class="py-name" href="#" onclick="return doclink('link-61', 'startTcpdump', 'link-61');">startTcpdump</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L242"></a><tt class="py-lineno"> 242</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'MNtcpdump'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'folder'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TEST</tt> <tt class="py-op">)</tt> </tt>
+<a name="L243"></a><tt class="py-lineno"> 243</tt> <tt class="py-line"> <tt class="py-op">+</tt> <tt class="py-string">"-MN.pcap"</tt><tt class="py-op">,</tt> </tt>
+<a name="L244"></a><tt class="py-lineno"> 244</tt> <tt class="py-line"> <tt class="py-name">intf</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'MNtcpdump'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'intf'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L245"></a><tt class="py-lineno"> 245</tt> <tt class="py-line"> <tt class="py-name">port</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'MNtcpdump'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'port'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L246"></a><tt class="py-lineno"> 246</tt> <tt class="py-line"> </tt>
+<a name="L247"></a><tt class="py-lineno"> 247</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-62" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-62', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"App Ids check"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L248"></a><tt class="py-lineno"> 248</tt> <tt class="py-line"> <tt class="py-name">appCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L249"></a><tt class="py-lineno"> 249</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L250"></a><tt class="py-lineno"> 250</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L251"></a><tt class="py-lineno"> 251</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-63" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-63', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-64" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#appToIDCheck"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-64', 'appToIDCheck', 'link-64');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L252"></a><tt class="py-lineno"> 252</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"appToIDCheck-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L253"></a><tt class="py-lineno"> 253</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L254"></a><tt class="py-lineno"> 254</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L255"></a><tt class="py-lineno"> 255</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L256"></a><tt class="py-lineno"> 256</tt> <tt class="py-line"> </tt>
+<a name="L257"></a><tt class="py-lineno"> 257</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L258"></a><tt class="py-lineno"> 258</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L259"></a><tt class="py-lineno"> 259</tt> <tt class="py-line"> <tt class="py-name">appCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">appCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L260"></a><tt class="py-lineno"> 260</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">appCheck</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L261"></a><tt class="py-lineno"> 261</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-65" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-65', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-66" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#apps,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#apps"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-66', 'apps', 'link-66');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L262"></a><tt class="py-lineno"> 262</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-67" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-67', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-68" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#appIDs"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-68', 'appIDs', 'link-68');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L263"></a><tt class="py-lineno"> 263</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">appCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L264"></a><tt class="py-lineno"> 264</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"App Ids seem to be correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L265"></a><tt class="py-lineno"> 265</tt> <tt class="py-line"> <tt id="link-69" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-69', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something is wrong with app Ids"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L266"></a><tt class="py-lineno"> 266</tt> <tt class="py-line"> </tt>
+<a name="L267"></a><tt class="py-lineno"> 267</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">cliResults</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L268"></a><tt class="py-lineno"> 268</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-70" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-70', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-71" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-71', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Failed to start ONOS, stopping test"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L269"></a><tt class="py-lineno"> 269</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-72" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-72', 'cleanup', 'link-7');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L270"></a><tt class="py-lineno"> 270</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-73" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-73', 'exit', 'link-8');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+</div><a name="L271"></a><tt class="py-lineno"> 271</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE2"></a><div id="HAsanity.CASE2-def"><a name="L272"></a><tt class="py-lineno"> 272</tt> <a class="py-toggle" href="#" id="HAsanity.CASE2-toggle" onclick="return toggle('HAsanity.CASE2');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE2">CASE2</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE2-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE2-expanded"><a name="L273"></a><tt class="py-lineno"> 273</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L274"></a><tt class="py-lineno"> 274</tt> <tt class="py-line"><tt class="py-docstring"> Assign devices to controllers</tt> </tt>
+<a name="L275"></a><tt class="py-lineno"> 275</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L276"></a><tt class="py-lineno"> 276</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
+<a name="L277"></a><tt class="py-lineno"> 277</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L278"></a><tt class="py-lineno"> 278</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L279"></a><tt class="py-lineno"> 279</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L280"></a><tt class="py-lineno"> 280</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L281"></a><tt class="py-lineno"> 281</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-74" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-74', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L282"></a><tt class="py-lineno"> 282</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS1Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS1Port not defined"</tt> </tt>
+<a name="L283"></a><tt class="py-lineno"> 283</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS2Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS2Port not defined"</tt> </tt>
+<a name="L284"></a><tt class="py-lineno"> 284</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS3Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS3Port not defined"</tt> </tt>
+<a name="L285"></a><tt class="py-lineno"> 285</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS4Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS4Port not defined"</tt> </tt>
+<a name="L286"></a><tt class="py-lineno"> 286</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS5Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS5Port not defined"</tt> </tt>
+<a name="L287"></a><tt class="py-lineno"> 287</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS6Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS6Port not defined"</tt> </tt>
+<a name="L288"></a><tt class="py-lineno"> 288</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS7Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS7Port not defined"</tt> </tt>
+<a name="L289"></a><tt class="py-lineno"> 289</tt> <tt class="py-line"> </tt>
+<a name="L290"></a><tt class="py-lineno"> 290</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-75" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-75', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assigning devices to controllers"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L291"></a><tt class="py-lineno"> 291</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Assign switches to ONOS using 'ovs-vsctl' "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L292"></a><tt class="py-lineno"> 292</tt> <tt class="py-line"> <tt class="py-string">"and check that an ONOS node becomes the "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L293"></a><tt class="py-lineno"> 293</tt> <tt class="py-line"> <tt class="py-string">"master of the device."</tt> </tt>
+<a name="L294"></a><tt class="py-lineno"> 294</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-76" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-76', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assign switches to controllers"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L295"></a><tt class="py-lineno"> 295</tt> <tt class="py-line"> </tt>
+<a name="L296"></a><tt class="py-lineno"> 296</tt> <tt class="py-line"> <tt class="py-name">ipList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L297"></a><tt class="py-lineno"> 297</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L298"></a><tt class="py-lineno"> 298</tt> <tt class="py-line"> <tt class="py-name">ipList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-77" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-77', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L299"></a><tt class="py-lineno"> 299</tt> <tt class="py-line"> <tt class="py-name">swList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L300"></a><tt class="py-lineno"> 300</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-number">29</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L301"></a><tt class="py-lineno"> 301</tt> <tt class="py-line"> <tt class="py-name">swList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L302"></a><tt class="py-lineno"> 302</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-78" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.assignSwController()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#assignSwController"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.assignSwController" class="py-name" href="#" onclick="return doclink('link-78', 'assignSwController', 'link-78');">assignSwController</a></tt><tt class="py-op">(</tt> <tt class="py-name">sw</tt><tt class="py-op">=</tt><tt class="py-name">swList</tt><tt class="py-op">,</tt> <tt class="py-name">ip</tt><tt class="py-op">=</tt><tt class="py-name">ipList</tt> <tt class="py-op">)</tt> </tt>
+<a name="L303"></a><tt class="py-lineno"> 303</tt> <tt class="py-line"> </tt>
+<a name="L304"></a><tt class="py-lineno"> 304</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L305"></a><tt class="py-lineno"> 305</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-number">29</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L306"></a><tt class="py-lineno"> 306</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-79" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwController()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getSwController"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwController" class="py-name" href="#" onclick="return doclink('link-79', 'getSwController', 'link-79');">getSwController</a></tt><tt class="py-op">(</tt> <tt class="py-string">"s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L307"></a><tt class="py-lineno"> 307</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L308"></a><tt class="py-lineno"> 308</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-80" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-80', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L309"></a><tt class="py-lineno"> 309</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt>
+<a name="L310"></a><tt class="py-lineno"> 310</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-81" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-81', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L311"></a><tt class="py-lineno"> 311</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-82" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-82', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L312"></a><tt class="py-lineno"> 312</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">search</tt><tt class="py-op">(</tt> <tt class="py-string">"tcp:"</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt><tt class="py-op">,</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L313"></a><tt class="py-lineno"> 313</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">mastershipCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L314"></a><tt class="py-lineno"> 314</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L315"></a><tt class="py-lineno"> 315</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-83" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-83', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-84" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-84', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error, node "</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">+</tt> <tt class="py-string">" is "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L316"></a><tt class="py-lineno"> 316</tt> <tt class="py-line"> <tt class="py-string">"not in the list of controllers s"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L317"></a><tt class="py-lineno"> 317</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is connecting to."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L318"></a><tt class="py-lineno"> 318</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L319"></a><tt class="py-lineno"> 319</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L320"></a><tt class="py-lineno"> 320</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L321"></a><tt class="py-lineno"> 321</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">mastershipCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L322"></a><tt class="py-lineno"> 322</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Switch mastership assigned correctly"</tt><tt class="py-op">,</tt> </tt>
+<a name="L323"></a><tt class="py-lineno"> 323</tt> <tt class="py-line"> <tt id="link-85" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-85', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Switches not assigned correctly to controllers"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L324"></a><tt class="py-lineno"> 324</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE21"></a><div id="HAsanity.CASE21-def"><a name="L325"></a><tt class="py-lineno"> 325</tt> <a class="py-toggle" href="#" id="HAsanity.CASE21-toggle" onclick="return toggle('HAsanity.CASE21');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE21">CASE21</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE21-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE21-expanded"><a name="L326"></a><tt class="py-lineno"> 326</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L327"></a><tt class="py-lineno"> 327</tt> <tt class="py-line"><tt class="py-docstring"> Assign mastership to controllers</tt> </tt>
+<a name="L328"></a><tt class="py-lineno"> 328</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L329"></a><tt class="py-lineno"> 329</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L330"></a><tt class="py-lineno"> 330</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L331"></a><tt class="py-lineno"> 331</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L332"></a><tt class="py-lineno"> 332</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L333"></a><tt class="py-lineno"> 333</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L334"></a><tt class="py-lineno"> 334</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-86" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-86', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L335"></a><tt class="py-lineno"> 335</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS1Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS1Port not defined"</tt> </tt>
+<a name="L336"></a><tt class="py-lineno"> 336</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS2Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS2Port not defined"</tt> </tt>
+<a name="L337"></a><tt class="py-lineno"> 337</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS3Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS3Port not defined"</tt> </tt>
+<a name="L338"></a><tt class="py-lineno"> 338</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS4Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS4Port not defined"</tt> </tt>
+<a name="L339"></a><tt class="py-lineno"> 339</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS5Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS5Port not defined"</tt> </tt>
+<a name="L340"></a><tt class="py-lineno"> 340</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS6Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS6Port not defined"</tt> </tt>
+<a name="L341"></a><tt class="py-lineno"> 341</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS7Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS7Port not defined"</tt> </tt>
+<a name="L342"></a><tt class="py-lineno"> 342</tt> <tt class="py-line"> </tt>
+<a name="L343"></a><tt class="py-lineno"> 343</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-87" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-87', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assigning Controller roles for switches"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L344"></a><tt class="py-lineno"> 344</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Check that ONOS is connected to each "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L345"></a><tt class="py-lineno"> 345</tt> <tt class="py-line"> <tt class="py-string">"device. Then manually assign"</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L346"></a><tt class="py-lineno"> 346</tt> <tt class="py-line"> <tt class="py-string">" mastership to specific ONOS nodes using"</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L347"></a><tt class="py-lineno"> 347</tt> <tt class="py-line"> <tt class="py-string">" 'device-role'"</tt> </tt>
+<a name="L348"></a><tt class="py-lineno"> 348</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-88" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-88', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assign mastership of switches to specific controllers"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L349"></a><tt class="py-lineno"> 349</tt> <tt class="py-line"> <tt class="py-comment"># Manually assign mastership to the controller we want</tt> </tt>
+<a name="L350"></a><tt class="py-lineno"> 350</tt> <tt class="py-line"> <tt class="py-name">roleCall</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L351"></a><tt class="py-lineno"> 351</tt> <tt class="py-line"> </tt>
+<a name="L352"></a><tt class="py-lineno"> 352</tt> <tt class="py-line"> <tt class="py-name">ipList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-op">]</tt> </tt>
+<a name="L353"></a><tt class="py-lineno"> 353</tt> <tt class="py-line"> <tt class="py-name">deviceList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L354"></a><tt class="py-lineno"> 354</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L355"></a><tt class="py-lineno"> 355</tt> <tt class="py-line"> <tt class="py-comment"># Assign mastership to specific controllers. This assignment was</tt> </tt>
+<a name="L356"></a><tt class="py-lineno"> 356</tt> <tt class="py-line"> <tt class="py-comment"># determined for a 7 node cluser, but will work with any sized</tt> </tt>
+<a name="L357"></a><tt class="py-lineno"> 357</tt> <tt class="py-line"> <tt class="py-comment"># cluster</tt> </tt>
+<a name="L358"></a><tt class="py-lineno"> 358</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-number">29</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-comment"># switches 1 through 28</tt> </tt>
+<a name="L359"></a><tt class="py-lineno"> 359</tt> <tt class="py-line"> <tt class="py-comment"># set up correct variables:</tt> </tt>
+<a name="L360"></a><tt class="py-lineno"> 360</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L361"></a><tt class="py-lineno"> 361</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L362"></a><tt class="py-lineno"> 362</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-89" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-89', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS1</tt> </tt>
+<a name="L363"></a><tt class="py-lineno"> 363</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-90" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getDevice"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-90', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"1000"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L364"></a><tt class="py-lineno"> 364</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt>
+<a name="L365"></a><tt class="py-lineno"> 365</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">1</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L366"></a><tt class="py-lineno"> 366</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-91" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-91', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS2</tt> </tt>
+<a name="L367"></a><tt class="py-lineno"> 367</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-92" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-92', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"2000"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L368"></a><tt class="py-lineno"> 368</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt>
+<a name="L369"></a><tt class="py-lineno"> 369</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">1</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L370"></a><tt class="py-lineno"> 370</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-93" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-93', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS2</tt> </tt>
+<a name="L371"></a><tt class="py-lineno"> 371</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-94" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-94', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"3000"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L372"></a><tt class="py-lineno"> 372</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">4</tt><tt class="py-op">:</tt> </tt>
+<a name="L373"></a><tt class="py-lineno"> 373</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">3</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L374"></a><tt class="py-lineno"> 374</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-95" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-95', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS4</tt> </tt>
+<a name="L375"></a><tt class="py-lineno"> 375</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-96" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-96', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"3004"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L376"></a><tt class="py-lineno"> 376</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">5</tt><tt class="py-op">:</tt> </tt>
+<a name="L377"></a><tt class="py-lineno"> 377</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">2</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L378"></a><tt class="py-lineno"> 378</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-97" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-97', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS3</tt> </tt>
+<a name="L379"></a><tt class="py-lineno"> 379</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-98" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-98', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"5000"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L380"></a><tt class="py-lineno"> 380</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">6</tt><tt class="py-op">:</tt> </tt>
+<a name="L381"></a><tt class="py-lineno"> 381</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">2</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L382"></a><tt class="py-lineno"> 382</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-99" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-99', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS3</tt> </tt>
+<a name="L383"></a><tt class="py-lineno"> 383</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-100" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-100', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"6000"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L384"></a><tt class="py-lineno"> 384</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">7</tt><tt class="py-op">:</tt> </tt>
+<a name="L385"></a><tt class="py-lineno"> 385</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">5</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L386"></a><tt class="py-lineno"> 386</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-101" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-101', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS6</tt> </tt>
+<a name="L387"></a><tt class="py-lineno"> 387</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-102" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-102', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"6007"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L388"></a><tt class="py-lineno"> 388</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">>=</tt> <tt class="py-number">8</tt> <tt class="py-keyword">and</tt> <tt class="py-name">i</tt> <tt class="py-op"><=</tt> <tt class="py-number">17</tt><tt class="py-op">:</tt> </tt>
+<a name="L389"></a><tt class="py-lineno"> 389</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">4</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L390"></a><tt class="py-lineno"> 390</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-103" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-103', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS5</tt> </tt>
+<a name="L391"></a><tt class="py-lineno"> 391</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">'3'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt> <tt class="py-number">3</tt> <tt class="py-op">)</tt> </tt>
+<a name="L392"></a><tt class="py-lineno"> 392</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-104" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-104', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-name">dpid</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L393"></a><tt class="py-lineno"> 393</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">>=</tt> <tt class="py-number">18</tt> <tt class="py-keyword">and</tt> <tt class="py-name">i</tt> <tt class="py-op"><=</tt> <tt class="py-number">27</tt><tt class="py-op">:</tt> </tt>
+<a name="L394"></a><tt class="py-lineno"> 394</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">6</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> </tt>
+<a name="L395"></a><tt class="py-lineno"> 395</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-105" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-105', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS7</tt> </tt>
+<a name="L396"></a><tt class="py-lineno"> 396</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">'6'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt> <tt class="py-number">3</tt> <tt class="py-op">)</tt> </tt>
+<a name="L397"></a><tt class="py-lineno"> 397</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-106" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-106', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-name">dpid</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L398"></a><tt class="py-lineno"> 398</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">28</tt><tt class="py-op">:</tt> </tt>
+<a name="L399"></a><tt class="py-lineno"> 399</tt> <tt class="py-line"> <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L400"></a><tt class="py-lineno"> 400</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-107" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-107', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">c</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-comment"># ONOS1</tt> </tt>
+<a name="L401"></a><tt class="py-lineno"> 401</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-108" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-108', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-string">"2800"</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L402"></a><tt class="py-lineno"> 402</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L403"></a><tt class="py-lineno"> 403</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-109" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-109', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-110" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-110', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"You didn't write an else statement for "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L404"></a><tt class="py-lineno"> 404</tt> <tt class="py-line"> <tt class="py-string">"switch s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L405"></a><tt class="py-lineno"> 405</tt> <tt class="py-line"> <tt class="py-name">roleCall</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L406"></a><tt class="py-lineno"> 406</tt> <tt class="py-line"> <tt class="py-comment"># Assign switch</tt> </tt>
+<a name="L407"></a><tt class="py-lineno"> 407</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">deviceId</tt><tt class="py-op">,</tt> <tt class="py-string">"No device id for s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" in ONOS"</tt> </tt>
+<a name="L408"></a><tt class="py-lineno"> 408</tt> <tt class="py-line"> <tt class="py-comment"># TODO: make this controller dynamic</tt> </tt>
+<a name="L409"></a><tt class="py-lineno"> 409</tt> <tt class="py-line"> <tt class="py-name">roleCall</tt> <tt class="py-op">=</tt> <tt class="py-name">roleCall</tt> <tt class="py-keyword">and</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-111" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deviceRole()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#deviceRole"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deviceRole" class="py-name" href="#" onclick="return doclink('link-111', 'deviceRole', 'link-111');">deviceRole</a></tt><tt class="py-op">(</tt> <tt class="py-name">deviceId</tt><tt class="py-op">,</tt> </tt>
+<a name="L410"></a><tt class="py-lineno"> 410</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">)</tt> </tt>
+<a name="L411"></a><tt class="py-lineno"> 411</tt> <tt class="py-line"> <tt class="py-name">ipList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">ip</tt> <tt class="py-op">)</tt> </tt>
+<a name="L412"></a><tt class="py-lineno"> 412</tt> <tt class="py-line"> <tt class="py-name">deviceList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">deviceId</tt> <tt class="py-op">)</tt> </tt>
+<a name="L413"></a><tt class="py-lineno"> 413</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">AttributeError</tt><tt class="py-op">,</tt> <tt class="py-name">AssertionError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L414"></a><tt class="py-lineno"> 414</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-112" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-112', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Something is wrong with ONOS device view"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L415"></a><tt class="py-lineno"> 415</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-113" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-113', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-114" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#devices"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-114', 'devices', 'link-114');">devices</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L416"></a><tt class="py-lineno"> 416</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L417"></a><tt class="py-lineno"> 417</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L418"></a><tt class="py-lineno"> 418</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">roleCall</tt><tt class="py-op">,</tt> </tt>
+<a name="L419"></a><tt class="py-lineno"> 419</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Re-assigned switch mastership to designated controller"</tt><tt class="py-op">,</tt> </tt>
+<a name="L420"></a><tt class="py-lineno"> 420</tt> <tt class="py-line"> <tt id="link-115" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-115', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something wrong with deviceRole calls"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L421"></a><tt class="py-lineno"> 421</tt> <tt class="py-line"> </tt>
+<a name="L422"></a><tt class="py-lineno"> 422</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-116" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-116', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check mastership was correctly assigned"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L423"></a><tt class="py-lineno"> 423</tt> <tt class="py-line"> <tt class="py-name">roleCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L424"></a><tt class="py-lineno"> 424</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: This is due to the fact that device mastership change is not</tt> </tt>
+<a name="L425"></a><tt class="py-lineno"> 425</tt> <tt class="py-line"> <tt class="py-comment"># atomic and is actually a multi step process</tt> </tt>
+<a name="L426"></a><tt class="py-lineno"> 426</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">5</tt> <tt class="py-op">)</tt> </tt>
+<a name="L427"></a><tt class="py-lineno"> 427</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">ipList</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L428"></a><tt class="py-lineno"> 428</tt> <tt class="py-line"> <tt class="py-name">ip</tt> <tt class="py-op">=</tt> <tt class="py-name">ipList</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
+<a name="L429"></a><tt class="py-lineno"> 429</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceList</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
+<a name="L430"></a><tt class="py-lineno"> 430</tt> <tt class="py-line"> <tt class="py-comment"># Check assignment</tt> </tt>
+<a name="L431"></a><tt class="py-lineno"> 431</tt> <tt class="py-line"> <tt class="py-name">master</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-117" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getRole()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getRole"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getRole" class="py-name" href="#" onclick="return doclink('link-117', 'getRole', 'link-117');">getRole</a></tt><tt class="py-op">(</tt> <tt class="py-name">deviceId</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'master'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L432"></a><tt class="py-lineno"> 432</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ip</tt> <tt class="py-keyword">in</tt> <tt class="py-name">master</tt><tt class="py-op">:</tt> </tt>
+<a name="L433"></a><tt class="py-lineno"> 433</tt> <tt class="py-line"> <tt class="py-name">roleCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">roleCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L434"></a><tt class="py-lineno"> 434</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L435"></a><tt class="py-lineno"> 435</tt> <tt class="py-line"> <tt class="py-name">roleCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">roleCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L436"></a><tt class="py-lineno"> 436</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-118" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-118', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-119" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-119', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error, controller "</tt> <tt class="py-op">+</tt> <tt class="py-name">ip</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L437"></a><tt class="py-lineno"> 437</tt> <tt class="py-line"> <tt class="py-string">" master "</tt> <tt class="py-op">+</tt> <tt class="py-string">"of device "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L438"></a><tt class="py-lineno"> 438</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">deviceId</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">". Master is "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L439"></a><tt class="py-lineno"> 439</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">master</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L440"></a><tt class="py-lineno"> 440</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L441"></a><tt class="py-lineno"> 441</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L442"></a><tt class="py-lineno"> 442</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">roleCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L443"></a><tt class="py-lineno"> 443</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Switches were successfully reassigned to designated "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L444"></a><tt class="py-lineno"> 444</tt> <tt class="py-line"> <tt class="py-string">"controller"</tt><tt class="py-op">,</tt> </tt>
+<a name="L445"></a><tt class="py-lineno"> 445</tt> <tt class="py-line"> <tt id="link-120" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-120', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Switches were not successfully reassigned"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L446"></a><tt class="py-lineno"> 446</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE3"></a><div id="HAsanity.CASE3-def"><a name="L447"></a><tt class="py-lineno"> 447</tt> <a class="py-toggle" href="#" id="HAsanity.CASE3-toggle" onclick="return toggle('HAsanity.CASE3');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE3">CASE3</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE3-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE3-expanded"><a name="L448"></a><tt class="py-lineno"> 448</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L449"></a><tt class="py-lineno"> 449</tt> <tt class="py-line"><tt class="py-docstring"> Assign intents</tt> </tt>
+<a name="L450"></a><tt class="py-lineno"> 450</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L451"></a><tt class="py-lineno"> 451</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L452"></a><tt class="py-lineno"> 452</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt>
+<a name="L453"></a><tt class="py-lineno"> 453</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L454"></a><tt class="py-lineno"> 454</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L455"></a><tt class="py-lineno"> 455</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L456"></a><tt class="py-lineno"> 456</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L457"></a><tt class="py-lineno"> 457</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-121" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-121', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L458"></a><tt class="py-lineno"> 458</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-122" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-122', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Adding host Intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L459"></a><tt class="py-lineno"> 459</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Discover hosts by using pingall then "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L460"></a><tt class="py-lineno"> 460</tt> <tt class="py-line"> <tt class="py-string">"assign predetermined host-to-host intents."</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L461"></a><tt class="py-lineno"> 461</tt> <tt class="py-line"> <tt class="py-string">" After installation, check that the intent"</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L462"></a><tt class="py-lineno"> 462</tt> <tt class="py-line"> <tt class="py-string">" is distributed to all nodes and the state"</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L463"></a><tt class="py-lineno"> 463</tt> <tt class="py-line"> <tt class="py-string">" is INSTALLED"</tt> </tt>
+<a name="L464"></a><tt class="py-lineno"> 464</tt> <tt class="py-line"> </tt>
+<a name="L465"></a><tt class="py-lineno"> 465</tt> <tt class="py-line"> <tt class="py-comment"># install onos-app-fwd</tt> </tt>
+<a name="L466"></a><tt class="py-lineno"> 466</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-123" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-123', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install reactive forwarding app"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L467"></a><tt class="py-lineno"> 467</tt> <tt class="py-line"> <tt class="py-name">installResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-124" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.activateApp()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#activateApp,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#activateApp"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.activateApp
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp" class="py-name" href="#" onclick="return doclink('link-124', 'activateApp', 'link-124');">activateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L468"></a><tt class="py-lineno"> 468</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">installResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L469"></a><tt class="py-lineno"> 469</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install fwd successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L470"></a><tt class="py-lineno"> 470</tt> <tt class="py-line"> <tt id="link-125" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-125', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install fwd failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L471"></a><tt class="py-lineno"> 471</tt> <tt class="py-line"> </tt>
+<a name="L472"></a><tt class="py-lineno"> 472</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-126" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-126', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check app ids"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L473"></a><tt class="py-lineno"> 473</tt> <tt class="py-line"> <tt class="py-name">appCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L474"></a><tt class="py-lineno"> 474</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L475"></a><tt class="py-lineno"> 475</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L476"></a><tt class="py-lineno"> 476</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-127" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-127', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-128" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-128', 'appToIDCheck', 'link-64');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L477"></a><tt class="py-lineno"> 477</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"appToIDCheck-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L478"></a><tt class="py-lineno"> 478</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L479"></a><tt class="py-lineno"> 479</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L480"></a><tt class="py-lineno"> 480</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L481"></a><tt class="py-lineno"> 481</tt> <tt class="py-line"> </tt>
+<a name="L482"></a><tt class="py-lineno"> 482</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L483"></a><tt class="py-lineno"> 483</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L484"></a><tt class="py-lineno"> 484</tt> <tt class="py-line"> <tt class="py-name">appCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">appCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L485"></a><tt class="py-lineno"> 485</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">appCheck</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L486"></a><tt class="py-lineno"> 486</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-129" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-129', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-130" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-130', 'apps', 'link-66');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L487"></a><tt class="py-lineno"> 487</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-131" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-131', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-132" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-132', 'appIDs', 'link-68');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L488"></a><tt class="py-lineno"> 488</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">appCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L489"></a><tt class="py-lineno"> 489</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"App Ids seem to be correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L490"></a><tt class="py-lineno"> 490</tt> <tt class="py-line"> <tt id="link-133" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-133', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something is wrong with app Ids"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L491"></a><tt class="py-lineno"> 491</tt> <tt class="py-line"> </tt>
+<a name="L492"></a><tt class="py-lineno"> 492</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-134" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-134', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Discovering Hosts( Via pingall for now )"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L493"></a><tt class="py-lineno"> 493</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: Once we have a host discovery mechanism, use that instead</tt> </tt>
+<a name="L494"></a><tt class="py-lineno"> 494</tt> <tt class="py-line"> <tt class="py-comment"># REACTIVE FWD test</tt> </tt>
+<a name="L495"></a><tt class="py-lineno"> 495</tt> <tt class="py-line"> <tt class="py-name">pingResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L496"></a><tt class="py-lineno"> 496</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">2</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-comment"># Retry if pingall fails first time</tt> </tt>
+<a name="L497"></a><tt class="py-lineno"> 497</tt> <tt class="py-line"> <tt class="py-name">time1</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L498"></a><tt class="py-lineno"> 498</tt> <tt class="py-line"> <tt class="py-name">pingResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-135" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#pingall"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-135', 'pingall', 'link-135');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L499"></a><tt class="py-lineno"> 499</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
+<a name="L500"></a><tt class="py-lineno"> 500</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L501"></a><tt class="py-lineno"> 501</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L502"></a><tt class="py-lineno"> 502</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pingResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L503"></a><tt class="py-lineno"> 503</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Pingall test passed"</tt><tt class="py-op">,</tt> </tt>
+<a name="L504"></a><tt class="py-lineno"> 504</tt> <tt class="py-line"> <tt id="link-136" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-136', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Pingall failed, "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L505"></a><tt class="py-lineno"> 505</tt> <tt class="py-line"> <tt class="py-string">"one or more ping pairs failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L506"></a><tt class="py-lineno"> 506</tt> <tt class="py-line"> <tt class="py-name">time2</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L507"></a><tt class="py-lineno"> 507</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-137" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-137', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Time for pingall: %2f seconds"</tt> <tt class="py-op">%</tt> </tt>
+<a name="L508"></a><tt class="py-lineno"> 508</tt> <tt class="py-line"> <tt class="py-op">(</tt> <tt class="py-name">time2</tt> <tt class="py-op">-</tt> <tt class="py-name">time1</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L509"></a><tt class="py-lineno"> 509</tt> <tt class="py-line"> <tt class="py-comment"># timeout for fwd flows</tt> </tt>
+<a name="L510"></a><tt class="py-lineno"> 510</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">11</tt> <tt class="py-op">)</tt> </tt>
+<a name="L511"></a><tt class="py-lineno"> 511</tt> <tt class="py-line"> <tt class="py-comment"># uninstall onos-app-fwd</tt> </tt>
+<a name="L512"></a><tt class="py-lineno"> 512</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-138" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-138', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstall reactive forwarding app"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L513"></a><tt class="py-lineno"> 513</tt> <tt class="py-line"> <tt class="py-name">uninstallResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-139" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.deactivateApp()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#deactivateApp,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deactivateApp()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#deactivateApp"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.deactivateApp
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deactivateApp" class="py-name" href="#" onclick="return doclink('link-139', 'deactivateApp', 'link-139');">deactivateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L514"></a><tt class="py-lineno"> 514</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">uninstallResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L515"></a><tt class="py-lineno"> 515</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Uninstall fwd successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L516"></a><tt class="py-lineno"> 516</tt> <tt class="py-line"> <tt id="link-140" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-140', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Uninstall fwd failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L517"></a><tt class="py-lineno"> 517</tt> <tt class="py-line"> <tt class="py-string">'''</tt> </tt>
+<a name="L518"></a><tt class="py-lineno"> 518</tt> <tt class="py-line"><tt class="py-string"> main.Mininet1.handle.sendline( "py [ h.cmd( \"arping -c 1 10.1.1.1 \" ) for h in net.hosts ] ")</tt> </tt>
+<a name="L519"></a><tt class="py-lineno"> 519</tt> <tt class="py-line"><tt class="py-string"> import time</tt> </tt>
+<a name="L520"></a><tt class="py-lineno"> 520</tt> <tt class="py-line"><tt class="py-string"> time.sleep(60)</tt> </tt>
+<a name="L521"></a><tt class="py-lineno"> 521</tt> <tt class="py-line"><tt class="py-string"> '''</tt> </tt>
+<a name="L522"></a><tt class="py-lineno"> 522</tt> <tt class="py-line"> </tt>
+<a name="L523"></a><tt class="py-lineno"> 523</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-141" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-141', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check app ids"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L524"></a><tt class="py-lineno"> 524</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L525"></a><tt class="py-lineno"> 525</tt> <tt class="py-line"> <tt class="py-name">appCheck2</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L526"></a><tt class="py-lineno"> 526</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L527"></a><tt class="py-lineno"> 527</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-142" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-142', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-143" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-143', 'appToIDCheck', 'link-64');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L528"></a><tt class="py-lineno"> 528</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"appToIDCheck-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L529"></a><tt class="py-lineno"> 529</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L530"></a><tt class="py-lineno"> 530</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L531"></a><tt class="py-lineno"> 531</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L532"></a><tt class="py-lineno"> 532</tt> <tt class="py-line"> </tt>
+<a name="L533"></a><tt class="py-lineno"> 533</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L534"></a><tt class="py-lineno"> 534</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L535"></a><tt class="py-lineno"> 535</tt> <tt class="py-line"> <tt class="py-name">appCheck2</tt> <tt class="py-op">=</tt> <tt class="py-name">appCheck2</tt> <tt class="py-keyword">and</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L536"></a><tt class="py-lineno"> 536</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">appCheck2</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L537"></a><tt class="py-lineno"> 537</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-144" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-144', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-145" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-145', 'apps', 'link-66');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L538"></a><tt class="py-lineno"> 538</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-146" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-146', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-147" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-147', 'appIDs', 'link-68');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L539"></a><tt class="py-lineno"> 539</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">appCheck2</tt><tt class="py-op">,</tt> </tt>
+<a name="L540"></a><tt class="py-lineno"> 540</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"App Ids seem to be correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L541"></a><tt class="py-lineno"> 541</tt> <tt class="py-line"> <tt id="link-148" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-148', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something is wrong with app Ids"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L542"></a><tt class="py-lineno"> 542</tt> <tt class="py-line"> </tt>
+<a name="L543"></a><tt class="py-lineno"> 543</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-149" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-149', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add host intents via cli"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L544"></a><tt class="py-lineno"> 544</tt> <tt class="py-line"> <tt class="py-name">intentIds</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L545"></a><tt class="py-lineno"> 545</tt> <tt class="py-line"> <tt class="py-comment"># TODO: move the host numbers to params</tt> </tt>
+<a name="L546"></a><tt class="py-lineno"> 546</tt> <tt class="py-line"> <tt class="py-comment"># Maybe look at all the paths we ping?</tt> </tt>
+<a name="L547"></a><tt class="py-lineno"> 547</tt> <tt class="py-line"> <tt class="py-name">intentAddResult</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L548"></a><tt class="py-lineno"> 548</tt> <tt class="py-line"> <tt class="py-name">hostResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L549"></a><tt class="py-lineno"> 549</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">8</tt><tt class="py-op">,</tt> <tt class="py-number">18</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L550"></a><tt class="py-lineno"> 550</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-150" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-150', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Adding host intent between h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L551"></a><tt class="py-lineno"> 551</tt> <tt class="py-line"> <tt class="py-string">" and h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L552"></a><tt class="py-lineno"> 552</tt> <tt class="py-line"> <tt class="py-name">host1</tt> <tt class="py-op">=</tt> <tt class="py-string">"00:00:00:00:00:"</tt> <tt class="py-op">+</tt> \ </tt>
+<a name="L553"></a><tt class="py-lineno"> 553</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">hex</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">[</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">upper</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L554"></a><tt class="py-lineno"> 554</tt> <tt class="py-line"> <tt class="py-name">host2</tt> <tt class="py-op">=</tt> <tt class="py-string">"00:00:00:00:00:"</tt> <tt class="py-op">+</tt> \ </tt>
+<a name="L555"></a><tt class="py-lineno"> 555</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">hex</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt><tt class="py-op">[</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">upper</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L556"></a><tt class="py-lineno"> 556</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: getHost can return None</tt> </tt>
+<a name="L557"></a><tt class="py-lineno"> 557</tt> <tt class="py-line"> <tt class="py-name">host1Dict</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-151" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getHost()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#getHost,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getHost()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getHost"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getHost
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getHost" class="py-name" href="#" onclick="return doclink('link-151', 'getHost', 'link-151');">getHost</a></tt><tt class="py-op">(</tt> <tt class="py-name">host1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L558"></a><tt class="py-lineno"> 558</tt> <tt class="py-line"> <tt class="py-name">host2Dict</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-152" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getHost
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getHost" class="py-name" href="#" onclick="return doclink('link-152', 'getHost', 'link-151');">getHost</a></tt><tt class="py-op">(</tt> <tt class="py-name">host2</tt> <tt class="py-op">)</tt> </tt>
+<a name="L559"></a><tt class="py-lineno"> 559</tt> <tt class="py-line"> <tt class="py-name">host1Id</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L560"></a><tt class="py-lineno"> 560</tt> <tt class="py-line"> <tt class="py-name">host2Id</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L561"></a><tt class="py-lineno"> 561</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">host1Dict</tt> <tt class="py-keyword">and</tt> <tt class="py-name">host2Dict</tt><tt class="py-op">:</tt> </tt>
+<a name="L562"></a><tt class="py-lineno"> 562</tt> <tt class="py-line"> <tt class="py-name">host1Id</tt> <tt class="py-op">=</tt> <tt class="py-name">host1Dict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L563"></a><tt class="py-lineno"> 563</tt> <tt class="py-line"> <tt class="py-name">host2Id</tt> <tt class="py-op">=</tt> <tt class="py-name">host2Dict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L564"></a><tt class="py-lineno"> 564</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">host1Id</tt> <tt class="py-keyword">and</tt> <tt class="py-name">host2Id</tt><tt class="py-op">:</tt> </tt>
+<a name="L565"></a><tt class="py-lineno"> 565</tt> <tt class="py-line"> <tt class="py-name">nodeNum</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">%</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt> </tt>
+<a name="L566"></a><tt class="py-lineno"> 566</tt> <tt class="py-line"> <tt class="py-name">tmpId</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt> <tt class="py-name">nodeNum</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-153" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addHostIntent()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#addHostIntent,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addHostIntent()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#addHostIntent"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addHostIntent
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addHostIntent" class="py-name" href="#" onclick="return doclink('link-153', 'addHostIntent', 'link-153');">addHostIntent</a></tt><tt class="py-op">(</tt> <tt class="py-name">host1Id</tt><tt class="py-op">,</tt> <tt class="py-name">host2Id</tt> <tt class="py-op">)</tt> </tt>
+<a name="L567"></a><tt class="py-lineno"> 567</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">tmpId</tt><tt class="py-op">:</tt> </tt>
+<a name="L568"></a><tt class="py-lineno"> 568</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-154" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-154', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Added intent with id: "</tt> <tt class="py-op">+</tt> <tt class="py-name">tmpId</tt> <tt class="py-op">)</tt> </tt>
+<a name="L569"></a><tt class="py-lineno"> 569</tt> <tt class="py-line"> <tt class="py-name">intentIds</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">tmpId</tt> <tt class="py-op">)</tt> </tt>
+<a name="L570"></a><tt class="py-lineno"> 570</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L571"></a><tt class="py-lineno"> 571</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-155" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-155', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-156" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-156', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"addHostIntent returned: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L572"></a><tt class="py-lineno"> 572</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">tmpId</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L573"></a><tt class="py-lineno"> 573</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L574"></a><tt class="py-lineno"> 574</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-157" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-157', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-158" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-158', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error, getHost() failed for h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L575"></a><tt class="py-lineno"> 575</tt> <tt class="py-line"> <tt class="py-string">" and/or h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L576"></a><tt class="py-lineno"> 576</tt> <tt class="py-line"> <tt id="link-159" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#hosts,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#hosts"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-159', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-160" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-160', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L577"></a><tt class="py-lineno"> 577</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-161" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-161', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Hosts output: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L578"></a><tt class="py-lineno"> 578</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L579"></a><tt class="py-lineno"> 579</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-162" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-162', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-163" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-163', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L580"></a><tt class="py-lineno"> 580</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L581"></a><tt class="py-lineno"> 581</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L582"></a><tt class="py-lineno"> 582</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L583"></a><tt class="py-lineno"> 583</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L584"></a><tt class="py-lineno"> 584</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-164" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-164', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-165" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-165', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L585"></a><tt class="py-lineno"> 585</tt> <tt class="py-line"> <tt class="py-name">hostResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L586"></a><tt class="py-lineno"> 586</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">hostResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L587"></a><tt class="py-lineno"> 587</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Found a host id for each host"</tt><tt class="py-op">,</tt> </tt>
+<a name="L588"></a><tt class="py-lineno"> 588</tt> <tt class="py-line"> <tt id="link-166" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-166', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error looking up host ids"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L589"></a><tt class="py-lineno"> 589</tt> <tt class="py-line"> </tt>
+<a name="L590"></a><tt class="py-lineno"> 590</tt> <tt class="py-line"> <tt class="py-name">intentStart</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L591"></a><tt class="py-lineno"> 591</tt> <tt class="py-line"> <tt class="py-name">onosIds</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-167" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentsId()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getAllIntentsId"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentsId" class="py-name" href="#" onclick="return doclink('link-167', 'getAllIntentsId', 'link-167');">getAllIntentsId</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L592"></a><tt class="py-lineno"> 592</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-168" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-168', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Submitted intents: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">intentIds</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L593"></a><tt class="py-lineno"> 593</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-169" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-169', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Intents in ONOS: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosIds</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L594"></a><tt class="py-lineno"> 594</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-170" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#intent"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-170', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentIds</tt><tt class="py-op">:</tt> </tt>
+<a name="L595"></a><tt class="py-lineno"> 595</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-171" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-171', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">onosIds</tt><tt class="py-op">:</tt> </tt>
+<a name="L596"></a><tt class="py-lineno"> 596</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> <tt class="py-comment"># intent submitted is in onos</tt> </tt>
+<a name="L597"></a><tt class="py-lineno"> 597</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L598"></a><tt class="py-lineno"> 598</tt> <tt class="py-line"> <tt class="py-name">intentAddResult</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L599"></a><tt class="py-lineno"> 599</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">intentAddResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L600"></a><tt class="py-lineno"> 600</tt> <tt class="py-line"> <tt class="py-name">intentStop</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L601"></a><tt class="py-lineno"> 601</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L602"></a><tt class="py-lineno"> 602</tt> <tt class="py-line"> <tt class="py-name">intentStop</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L603"></a><tt class="py-lineno"> 603</tt> <tt class="py-line"> <tt class="py-comment"># Print the intent states</tt> </tt>
+<a name="L604"></a><tt class="py-lineno"> 604</tt> <tt class="py-line"> <tt id="link-172" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#intents,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#intents"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-172', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-173" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-173', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L605"></a><tt class="py-lineno"> 605</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L606"></a><tt class="py-lineno"> 606</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L607"></a><tt class="py-lineno"> 607</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-174" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-174', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt> <tt class="py-string">'Count'</tt><tt class="py-op">,</tt> <tt class="py-string">'ID'</tt><tt class="py-op">,</tt> <tt class="py-string">'State'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L608"></a><tt class="py-lineno"> 608</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L609"></a><tt class="py-lineno"> 609</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L610"></a><tt class="py-lineno"> 610</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-175" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-175', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-176" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-176', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L611"></a><tt class="py-lineno"> 611</tt> <tt class="py-line"> <tt class="py-name">state</tt> <tt class="py-op">=</tt> <tt id="link-177" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-177', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'state'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L612"></a><tt class="py-lineno"> 612</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"INSTALLED"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">state</tt><tt class="py-op">:</tt> </tt>
+<a name="L613"></a><tt class="py-lineno"> 613</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L614"></a><tt class="py-lineno"> 614</tt> <tt class="py-line"> <tt class="py-name">intentId</tt> <tt class="py-op">=</tt> <tt id="link-178" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-178', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L615"></a><tt class="py-lineno"> 615</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt> <tt class="py-name">intentId</tt><tt class="py-op">,</tt> <tt class="py-name">state</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L616"></a><tt class="py-lineno"> 616</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L617"></a><tt class="py-lineno"> 617</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-179" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-179', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L618"></a><tt class="py-lineno"> 618</tt> <tt class="py-line"> <tt class="py-comment"># add submitted intents not in the store</tt> </tt>
+<a name="L619"></a><tt class="py-lineno"> 619</tt> <tt class="py-line"> <tt class="py-name">tmplist</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentStates</tt> <tt class="py-op">]</tt> </tt>
+<a name="L620"></a><tt class="py-lineno"> 620</tt> <tt class="py-line"> <tt class="py-name">missingIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L621"></a><tt class="py-lineno"> 621</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentIds</tt><tt class="py-op">:</tt> </tt>
+<a name="L622"></a><tt class="py-lineno"> 622</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tmplist</tt><tt class="py-op">:</tt> </tt>
+<a name="L623"></a><tt class="py-lineno"> 623</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-string">" - "</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L624"></a><tt class="py-lineno"> 624</tt> <tt class="py-line"> <tt class="py-name">missingIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L625"></a><tt class="py-lineno"> 625</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">sort</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L626"></a><tt class="py-lineno"> 626</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentStates</tt><tt class="py-op">:</tt> </tt>
+<a name="L627"></a><tt class="py-lineno"> 627</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L628"></a><tt class="py-lineno"> 628</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-180" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-180', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> </tt>
+<a name="L629"></a><tt class="py-lineno"> 629</tt> <tt class="py-line"> <tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">count</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">s</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L630"></a><tt class="py-lineno"> 630</tt> <tt class="py-line"> <tt id="link-181" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#leaders"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-181', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-182" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-182', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L631"></a><tt class="py-lineno"> 631</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L632"></a><tt class="py-lineno"> 632</tt> <tt class="py-line"> <tt class="py-name">missing</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L633"></a><tt class="py-lineno"> 633</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-183" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-183', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L634"></a><tt class="py-lineno"> 634</tt> <tt class="py-line"> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-184" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-184', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L635"></a><tt class="py-lineno"> 635</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-185" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-185', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedLeaders</tt><tt class="py-op">,</tt> </tt>
+<a name="L636"></a><tt class="py-lineno"> 636</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L637"></a><tt class="py-lineno"> 637</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L638"></a><tt class="py-lineno"> 638</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L639"></a><tt class="py-lineno"> 639</tt> <tt class="py-line"> <tt class="py-comment"># check for all intent partitions</tt> </tt>
+<a name="L640"></a><tt class="py-lineno"> 640</tt> <tt class="py-line"> <tt class="py-name">topics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L641"></a><tt class="py-lineno"> 641</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">14</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L642"></a><tt class="py-lineno"> 642</tt> <tt class="py-line"> <tt class="py-name">topics</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"intent-partition-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L643"></a><tt class="py-lineno"> 643</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-186" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-186', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">topics</tt> <tt class="py-op">)</tt> </tt>
+<a name="L644"></a><tt class="py-lineno"> 644</tt> <tt class="py-line"> <tt class="py-name">ONOStopics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">j</tt><tt class="py-op">[</tt><tt class="py-string">'topic'</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">j</tt> <tt class="py-keyword">in</tt> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">]</tt> </tt>
+<a name="L645"></a><tt class="py-lineno"> 645</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">in</tt> <tt class="py-name">topics</tt><tt class="py-op">:</tt> </tt>
+<a name="L646"></a><tt class="py-lineno"> 646</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOStopics</tt><tt class="py-op">:</tt> </tt>
+<a name="L647"></a><tt class="py-lineno"> 647</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-187" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-187', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-188" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-188', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error: "</tt> <tt class="py-op">+</tt> <tt class="py-name">topic</tt> <tt class="py-op">+</tt> </tt>
+<a name="L648"></a><tt class="py-lineno"> 648</tt> <tt class="py-line"> <tt class="py-string">" not in leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L649"></a><tt class="py-lineno"> 649</tt> <tt class="py-line"> <tt class="py-name">missing</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L650"></a><tt class="py-lineno"> 650</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L651"></a><tt class="py-lineno"> 651</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-189" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-189', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-190" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-190', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"leaders() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L652"></a><tt class="py-lineno"> 652</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L653"></a><tt class="py-lineno"> 653</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-191" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-191', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L654"></a><tt class="py-lineno"> 654</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-192" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-192', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-193" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-193', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-194" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-194', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L655"></a><tt class="py-lineno"> 655</tt> <tt class="py-line"> <tt class="py-comment"># Check all nodes</tt> </tt>
+<a name="L656"></a><tt class="py-lineno"> 656</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">missing</tt><tt class="py-op">:</tt> </tt>
+<a name="L657"></a><tt class="py-lineno"> 657</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L658"></a><tt class="py-lineno"> 658</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt id="link-195" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-195', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt> <tt class="py-name">jsonFormat</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
+<a name="L659"></a><tt class="py-lineno"> 659</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-196" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-196', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" leaders output: \n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L660"></a><tt class="py-lineno"> 660</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L661"></a><tt class="py-lineno"> 661</tt> <tt class="py-line"> </tt>
+<a name="L662"></a><tt class="py-lineno"> 662</tt> <tt class="py-line"> <tt id="link-197" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#partitions"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-197', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-198" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-198', 'partitions', 'link-197');">partitions</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L663"></a><tt class="py-lineno"> 663</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L664"></a><tt class="py-lineno"> 664</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-199" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-199', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L665"></a><tt class="py-lineno"> 665</tt> <tt class="py-line"> <tt class="py-name">parsedPartitions</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-200" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-200', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L666"></a><tt class="py-lineno"> 666</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-201" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-201', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPartitions</tt><tt class="py-op">,</tt> </tt>
+<a name="L667"></a><tt class="py-lineno"> 667</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L668"></a><tt class="py-lineno"> 668</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L669"></a><tt class="py-lineno"> 669</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L670"></a><tt class="py-lineno"> 670</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for a leader in all paritions</tt> </tt>
+<a name="L671"></a><tt class="py-lineno"> 671</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for consistency among nodes</tt> </tt>
+<a name="L672"></a><tt class="py-lineno"> 672</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L673"></a><tt class="py-lineno"> 673</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-202" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-202', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-203" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-203', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"partitions() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L674"></a><tt class="py-lineno"> 674</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L675"></a><tt class="py-lineno"> 675</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-204" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-204', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing partitions"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L676"></a><tt class="py-lineno"> 676</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-205" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-205', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-206" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-206', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-207" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-207', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L677"></a><tt class="py-lineno"> 677</tt> <tt class="py-line"> <tt id="link-208" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#pendingMap"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-208', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-209" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-209', 'pendingMap', 'link-208');">pendingMap</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L678"></a><tt class="py-lineno"> 678</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L679"></a><tt class="py-lineno"> 679</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-210" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-210', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L680"></a><tt class="py-lineno"> 680</tt> <tt class="py-line"> <tt class="py-name">parsedPending</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-211" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-211', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L681"></a><tt class="py-lineno"> 681</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-212" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-212', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPending</tt><tt class="py-op">,</tt> </tt>
+<a name="L682"></a><tt class="py-lineno"> 682</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L683"></a><tt class="py-lineno"> 683</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L684"></a><tt class="py-lineno"> 684</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L685"></a><tt class="py-lineno"> 685</tt> <tt class="py-line"> <tt class="py-comment"># TODO check something here?</tt> </tt>
+<a name="L686"></a><tt class="py-lineno"> 686</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L687"></a><tt class="py-lineno"> 687</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-213" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-213', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-214" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-214', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"pendingMap() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L688"></a><tt class="py-lineno"> 688</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L689"></a><tt class="py-lineno"> 689</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-215" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-215', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing pending map"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L690"></a><tt class="py-lineno"> 690</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-216" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-216', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-217" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-217', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-218" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-218', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L691"></a><tt class="py-lineno"> 691</tt> <tt class="py-line"> </tt>
+<a name="L692"></a><tt class="py-lineno"> 692</tt> <tt class="py-line"> <tt class="py-name">intentAddResult</tt> <tt class="py-op">=</tt> <tt class="py-name">bool</tt><tt class="py-op">(</tt> <tt class="py-name">intentAddResult</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">missingIntents</tt> <tt class="py-keyword">and</tt> </tt>
+<a name="L693"></a><tt class="py-lineno"> 693</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">)</tt> </tt>
+<a name="L694"></a><tt class="py-lineno"> 694</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">intentAddResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L695"></a><tt class="py-lineno"> 695</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-219" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-219', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-220" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-220', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in pushing host intents to ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L696"></a><tt class="py-lineno"> 696</tt> <tt class="py-line"> </tt>
+<a name="L697"></a><tt class="py-lineno"> 697</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-221" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-221', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Intent Anti-Entropy dispersion"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L698"></a><tt class="py-lineno"> 698</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">100</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L699"></a><tt class="py-lineno"> 699</tt> <tt class="py-line"> <tt class="py-name">correct</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L700"></a><tt class="py-lineno"> 700</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-222" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-222', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Submitted intents: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">intentIds</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L701"></a><tt class="py-lineno"> 701</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-223" class="py-name" targets="Module TestON.bin.cli=TestON.bin.cli-module.html,Package TestON.drivers.common.cli=TestON.drivers.common.cli-module.html"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-223', 'cli', 'link-223');">cli</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L702"></a><tt class="py-lineno"> 702</tt> <tt class="py-line"> <tt class="py-name">onosIds</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L703"></a><tt class="py-lineno"> 703</tt> <tt class="py-line"> <tt class="py-name">ids</tt> <tt class="py-op">=</tt> <tt id="link-224" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-224', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-225" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentsId" class="py-name" href="#" onclick="return doclink('link-225', 'getAllIntentsId', 'link-167');">getAllIntentsId</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L704"></a><tt class="py-lineno"> 704</tt> <tt class="py-line"> <tt class="py-name">onosIds</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">ids</tt> <tt class="py-op">)</tt> </tt>
+<a name="L705"></a><tt class="py-lineno"> 705</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-226" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-226', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Intents in "</tt> <tt class="py-op">+</tt> <tt id="link-227" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-227', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L706"></a><tt class="py-lineno"> 706</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">onosIds</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L707"></a><tt class="py-lineno"> 707</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">ids</tt> <tt class="py-op">)</tt> <tt class="py-op">!=</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">intentIds</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L708"></a><tt class="py-lineno"> 708</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-228" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-228', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Set of intent IDs doesn't match"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L709"></a><tt class="py-lineno"> 709</tt> <tt class="py-line"> <tt class="py-name">correct</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L710"></a><tt class="py-lineno"> 710</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L711"></a><tt class="py-lineno"> 711</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L712"></a><tt class="py-lineno"> 712</tt> <tt class="py-line"> <tt id="link-229" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-229', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-230" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-230', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-231" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-231', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L713"></a><tt class="py-lineno"> 713</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-232" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-232', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt id="link-233" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-233', 'intents', 'link-172');">intents</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L714"></a><tt class="py-lineno"> 714</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-234" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-234', 'intent', 'link-170');">intent</a></tt><tt class="py-op">[</tt> <tt class="py-string">'state'</tt> <tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-string">"INSTALLED"</tt><tt class="py-op">:</tt> </tt>
+<a name="L715"></a><tt class="py-lineno"> 715</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-235" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-235', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Intent "</tt> <tt class="py-op">+</tt> <tt id="link-236" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-236', 'intent', 'link-170');">intent</a></tt><tt class="py-op">[</tt> <tt class="py-string">'id'</tt> <tt class="py-op">]</tt> <tt class="py-op">+</tt> </tt>
+<a name="L716"></a><tt class="py-lineno"> 716</tt> <tt class="py-line"> <tt class="py-string">" is "</tt> <tt class="py-op">+</tt> <tt id="link-237" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-237', 'intent', 'link-170');">intent</a></tt><tt class="py-op">[</tt> <tt class="py-string">'state'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L717"></a><tt class="py-lineno"> 717</tt> <tt class="py-line"> <tt class="py-name">correct</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L718"></a><tt class="py-lineno"> 718</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L719"></a><tt class="py-lineno"> 719</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">correct</tt><tt class="py-op">:</tt> </tt>
+<a name="L720"></a><tt class="py-lineno"> 720</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L721"></a><tt class="py-lineno"> 721</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L722"></a><tt class="py-lineno"> 722</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
+<a name="L723"></a><tt class="py-lineno"> 723</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">intentStop</tt><tt class="py-op">:</tt> </tt>
+<a name="L724"></a><tt class="py-lineno"> 724</tt> <tt class="py-line"> <tt class="py-name">intentStop</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L725"></a><tt class="py-lineno"> 725</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">gossipTime</tt> </tt>
+<a name="L726"></a><tt class="py-lineno"> 726</tt> <tt class="py-line"> <tt class="py-name">gossipTime</tt> <tt class="py-op">=</tt> <tt class="py-name">intentStop</tt> <tt class="py-op">-</tt> <tt class="py-name">intentStart</tt> </tt>
+<a name="L727"></a><tt class="py-lineno"> 727</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-238" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-238', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"It took about "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">gossipTime</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L728"></a><tt class="py-lineno"> 728</tt> <tt class="py-line"> <tt class="py-string">" seconds for all intents to appear in each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L729"></a><tt class="py-lineno"> 729</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: make this time configurable/calculate based off of number of</tt> </tt>
+<a name="L730"></a><tt class="py-lineno"> 730</tt> <tt class="py-line"> <tt class="py-comment"># nodes and gossip rounds</tt> </tt>
+<a name="L731"></a><tt class="py-lineno"> 731</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_greater_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L732"></a><tt class="py-lineno"> 732</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-number">40</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">gossipTime</tt><tt class="py-op">,</tt> </tt>
+<a name="L733"></a><tt class="py-lineno"> 733</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ECM anti-entropy for intents worked within "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L734"></a><tt class="py-lineno"> 734</tt> <tt class="py-line"> <tt class="py-string">"expected time"</tt><tt class="py-op">,</tt> </tt>
+<a name="L735"></a><tt class="py-lineno"> 735</tt> <tt class="py-line"> <tt id="link-239" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-239', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Intent ECM anti-entropy took too long"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L736"></a><tt class="py-lineno"> 736</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">gossipTime</tt> <tt class="py-op"><=</tt> <tt class="py-number">40</tt><tt class="py-op">:</tt> </tt>
+<a name="L737"></a><tt class="py-lineno"> 737</tt> <tt class="py-line"> <tt class="py-name">intentAddResult</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L738"></a><tt class="py-lineno"> 738</tt> <tt class="py-line"> </tt>
+<a name="L739"></a><tt class="py-lineno"> 739</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">intentAddResult</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"key"</tt> <tt class="py-keyword">in</tt> <tt id="link-240" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-240', 'pendingMap', 'link-208');">pendingMap</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L740"></a><tt class="py-lineno"> 740</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L741"></a><tt class="py-lineno"> 741</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L742"></a><tt class="py-lineno"> 742</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-241" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-241', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Sleeping 60 seconds to see if intents are found"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L743"></a><tt class="py-lineno"> 743</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt>
+<a name="L744"></a><tt class="py-lineno"> 744</tt> <tt class="py-line"> <tt class="py-name">onosIds</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-242" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentsId" class="py-name" href="#" onclick="return doclink('link-242', 'getAllIntentsId', 'link-167');">getAllIntentsId</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L745"></a><tt class="py-lineno"> 745</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-243" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-243', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Submitted intents: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">intentIds</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L746"></a><tt class="py-lineno"> 746</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-244" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-244', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Intents in ONOS: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosIds</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L747"></a><tt class="py-lineno"> 747</tt> <tt class="py-line"> <tt class="py-comment"># Print the intent states</tt> </tt>
+<a name="L748"></a><tt class="py-lineno"> 748</tt> <tt class="py-line"> <tt id="link-245" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-245', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-246" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-246', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L749"></a><tt class="py-lineno"> 749</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L750"></a><tt class="py-lineno"> 750</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-247" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-247', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt> <tt class="py-string">'Count'</tt><tt class="py-op">,</tt> <tt class="py-string">'ID'</tt><tt class="py-op">,</tt> <tt class="py-string">'State'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L751"></a><tt class="py-lineno"> 751</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L752"></a><tt class="py-lineno"> 752</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L753"></a><tt class="py-lineno"> 753</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-248" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-248', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-249" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-249', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L754"></a><tt class="py-lineno"> 754</tt> <tt class="py-line"> <tt class="py-comment"># Iter through intents of a node</tt> </tt>
+<a name="L755"></a><tt class="py-lineno"> 755</tt> <tt class="py-line"> <tt class="py-name">state</tt> <tt class="py-op">=</tt> <tt id="link-250" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-250', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'state'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L756"></a><tt class="py-lineno"> 756</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"INSTALLED"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">state</tt><tt class="py-op">:</tt> </tt>
+<a name="L757"></a><tt class="py-lineno"> 757</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L758"></a><tt class="py-lineno"> 758</tt> <tt class="py-line"> <tt class="py-name">intentId</tt> <tt class="py-op">=</tt> <tt id="link-251" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-251', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L759"></a><tt class="py-lineno"> 759</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt> <tt class="py-name">intentId</tt><tt class="py-op">,</tt> <tt class="py-name">state</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L760"></a><tt class="py-lineno"> 760</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L761"></a><tt class="py-lineno"> 761</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-252" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-252', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L762"></a><tt class="py-lineno"> 762</tt> <tt class="py-line"> <tt class="py-comment"># add submitted intents not in the store</tt> </tt>
+<a name="L763"></a><tt class="py-lineno"> 763</tt> <tt class="py-line"> <tt class="py-name">tmplist</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentStates</tt> <tt class="py-op">]</tt> </tt>
+<a name="L764"></a><tt class="py-lineno"> 764</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentIds</tt><tt class="py-op">:</tt> </tt>
+<a name="L765"></a><tt class="py-lineno"> 765</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tmplist</tt><tt class="py-op">:</tt> </tt>
+<a name="L766"></a><tt class="py-lineno"> 766</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-string">" - "</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L767"></a><tt class="py-lineno"> 767</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">sort</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L768"></a><tt class="py-lineno"> 768</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentStates</tt><tt class="py-op">:</tt> </tt>
+<a name="L769"></a><tt class="py-lineno"> 769</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L770"></a><tt class="py-lineno"> 770</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-253" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-253', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> </tt>
+<a name="L771"></a><tt class="py-lineno"> 771</tt> <tt class="py-line"> <tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">count</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">s</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L772"></a><tt class="py-lineno"> 772</tt> <tt class="py-line"> <tt id="link-254" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-254', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-255" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-255', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L773"></a><tt class="py-lineno"> 773</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L774"></a><tt class="py-lineno"> 774</tt> <tt class="py-line"> <tt class="py-name">missing</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L775"></a><tt class="py-lineno"> 775</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-256" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-256', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L776"></a><tt class="py-lineno"> 776</tt> <tt class="py-line"> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-257" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-257', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L777"></a><tt class="py-lineno"> 777</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-258" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-258', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedLeaders</tt><tt class="py-op">,</tt> </tt>
+<a name="L778"></a><tt class="py-lineno"> 778</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L779"></a><tt class="py-lineno"> 779</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L780"></a><tt class="py-lineno"> 780</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L781"></a><tt class="py-lineno"> 781</tt> <tt class="py-line"> <tt class="py-comment"># check for all intent partitions</tt> </tt>
+<a name="L782"></a><tt class="py-lineno"> 782</tt> <tt class="py-line"> <tt class="py-comment"># check for election</tt> </tt>
+<a name="L783"></a><tt class="py-lineno"> 783</tt> <tt class="py-line"> <tt class="py-name">topics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L784"></a><tt class="py-lineno"> 784</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">14</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L785"></a><tt class="py-lineno"> 785</tt> <tt class="py-line"> <tt class="py-name">topics</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"intent-partition-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L786"></a><tt class="py-lineno"> 786</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: this should only be after we start the app</tt> </tt>
+<a name="L787"></a><tt class="py-lineno"> 787</tt> <tt class="py-line"> <tt class="py-name">topics</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L788"></a><tt class="py-lineno"> 788</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-259" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-259', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">topics</tt> <tt class="py-op">)</tt> </tt>
+<a name="L789"></a><tt class="py-lineno"> 789</tt> <tt class="py-line"> <tt class="py-name">ONOStopics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">j</tt><tt class="py-op">[</tt><tt class="py-string">'topic'</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">j</tt> <tt class="py-keyword">in</tt> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">]</tt> </tt>
+<a name="L790"></a><tt class="py-lineno"> 790</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">in</tt> <tt class="py-name">topics</tt><tt class="py-op">:</tt> </tt>
+<a name="L791"></a><tt class="py-lineno"> 791</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOStopics</tt><tt class="py-op">:</tt> </tt>
+<a name="L792"></a><tt class="py-lineno"> 792</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-260" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-260', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-261" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-261', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error: "</tt> <tt class="py-op">+</tt> <tt class="py-name">topic</tt> <tt class="py-op">+</tt> </tt>
+<a name="L793"></a><tt class="py-lineno"> 793</tt> <tt class="py-line"> <tt class="py-string">" not in leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L794"></a><tt class="py-lineno"> 794</tt> <tt class="py-line"> <tt class="py-name">missing</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L795"></a><tt class="py-lineno"> 795</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L796"></a><tt class="py-lineno"> 796</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-262" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-262', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-263" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-263', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"leaders() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L797"></a><tt class="py-lineno"> 797</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L798"></a><tt class="py-lineno"> 798</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-264" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-264', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L799"></a><tt class="py-lineno"> 799</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-265" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-265', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-266" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-266', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-267" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-267', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L800"></a><tt class="py-lineno"> 800</tt> <tt class="py-line"> <tt class="py-comment"># Check all nodes</tt> </tt>
+<a name="L801"></a><tt class="py-lineno"> 801</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">missing</tt><tt class="py-op">:</tt> </tt>
+<a name="L802"></a><tt class="py-lineno"> 802</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L803"></a><tt class="py-lineno"> 803</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt id="link-268" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-268', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt> <tt class="py-name">jsonFormat</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
+<a name="L804"></a><tt class="py-lineno"> 804</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-269" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-269', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" leaders output: \n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L805"></a><tt class="py-lineno"> 805</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L806"></a><tt class="py-lineno"> 806</tt> <tt class="py-line"> </tt>
+<a name="L807"></a><tt class="py-lineno"> 807</tt> <tt class="py-line"> <tt id="link-270" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-270', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-271" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-271', 'partitions', 'link-197');">partitions</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L808"></a><tt class="py-lineno"> 808</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L809"></a><tt class="py-lineno"> 809</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-272" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-272', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L810"></a><tt class="py-lineno"> 810</tt> <tt class="py-line"> <tt class="py-name">parsedPartitions</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-273" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-273', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L811"></a><tt class="py-lineno"> 811</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-274" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-274', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPartitions</tt><tt class="py-op">,</tt> </tt>
+<a name="L812"></a><tt class="py-lineno"> 812</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L813"></a><tt class="py-lineno"> 813</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L814"></a><tt class="py-lineno"> 814</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L815"></a><tt class="py-lineno"> 815</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for a leader in all paritions</tt> </tt>
+<a name="L816"></a><tt class="py-lineno"> 816</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for consistency among nodes</tt> </tt>
+<a name="L817"></a><tt class="py-lineno"> 817</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L818"></a><tt class="py-lineno"> 818</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-275" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-275', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-276" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-276', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"partitions() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L819"></a><tt class="py-lineno"> 819</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L820"></a><tt class="py-lineno"> 820</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-277" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-277', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing partitions"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L821"></a><tt class="py-lineno"> 821</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-278" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-278', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-279" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-279', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-280" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-280', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L822"></a><tt class="py-lineno"> 822</tt> <tt class="py-line"> <tt id="link-281" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-281', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-282" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-282', 'pendingMap', 'link-208');">pendingMap</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L823"></a><tt class="py-lineno"> 823</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L824"></a><tt class="py-lineno"> 824</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-283" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-283', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L825"></a><tt class="py-lineno"> 825</tt> <tt class="py-line"> <tt class="py-name">parsedPending</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-284" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-284', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L826"></a><tt class="py-lineno"> 826</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-285" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-285', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPending</tt><tt class="py-op">,</tt> </tt>
+<a name="L827"></a><tt class="py-lineno"> 827</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L828"></a><tt class="py-lineno"> 828</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L829"></a><tt class="py-lineno"> 829</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L830"></a><tt class="py-lineno"> 830</tt> <tt class="py-line"> <tt class="py-comment"># TODO check something here?</tt> </tt>
+<a name="L831"></a><tt class="py-lineno"> 831</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L832"></a><tt class="py-lineno"> 832</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-286" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-286', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-287" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-287', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"pendingMap() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L833"></a><tt class="py-lineno"> 833</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L834"></a><tt class="py-lineno"> 834</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-288" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-288', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing pending map"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L835"></a><tt class="py-lineno"> 835</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-289" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-289', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-290" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-290', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-291" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-291', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L836"></a><tt class="py-lineno"> 836</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE4"></a><div id="HAsanity.CASE4-def"><a name="L837"></a><tt class="py-lineno"> 837</tt> <a class="py-toggle" href="#" id="HAsanity.CASE4-toggle" onclick="return toggle('HAsanity.CASE4');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE4">CASE4</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE4-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE4-expanded"><a name="L838"></a><tt class="py-lineno"> 838</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L839"></a><tt class="py-lineno"> 839</tt> <tt class="py-line"><tt class="py-docstring"> Ping across added host intents</tt> </tt>
+<a name="L840"></a><tt class="py-lineno"> 840</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L841"></a><tt class="py-lineno"> 841</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt>
+<a name="L842"></a><tt class="py-lineno"> 842</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L843"></a><tt class="py-lineno"> 843</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L844"></a><tt class="py-lineno"> 844</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L845"></a><tt class="py-lineno"> 845</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L846"></a><tt class="py-lineno"> 846</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L847"></a><tt class="py-lineno"> 847</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-292" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-292', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L848"></a><tt class="py-lineno"> 848</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-293" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-293', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify connectivity by sendind traffic across Intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L849"></a><tt class="py-lineno"> 849</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Ping across added host intents to check "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L850"></a><tt class="py-lineno"> 850</tt> <tt class="py-line"> <tt class="py-string">"functionality and check the state of "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L851"></a><tt class="py-lineno"> 851</tt> <tt class="py-line"> <tt class="py-string">"the intent"</tt> </tt>
+<a name="L852"></a><tt class="py-lineno"> 852</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-294" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-294', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Ping across added host intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L853"></a><tt class="py-lineno"> 853</tt> <tt class="py-line"> <tt class="py-name">PingResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L854"></a><tt class="py-lineno"> 854</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">8</tt><tt class="py-op">,</tt> <tt class="py-number">18</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L855"></a><tt class="py-lineno"> 855</tt> <tt class="py-line"> <tt class="py-name">ping</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-295" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingHost()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#pingHost,Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingHost()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#pingHost"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingHost
+TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingHost" class="py-name" href="#" onclick="return doclink('link-295', 'pingHost', 'link-295');">pingHost</a></tt><tt class="py-op">(</tt> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-string">"h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L856"></a><tt class="py-lineno"> 856</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-string">"h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L857"></a><tt class="py-lineno"> 857</tt> <tt class="py-line"> <tt class="py-name">PingResult</tt> <tt class="py-op">=</tt> <tt class="py-name">PingResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ping</tt> </tt>
+<a name="L858"></a><tt class="py-lineno"> 858</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ping</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L859"></a><tt class="py-lineno"> 859</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-296" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-296', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Ping failed between h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L860"></a><tt class="py-lineno"> 860</tt> <tt class="py-line"> <tt class="py-string">" and h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L861"></a><tt class="py-lineno"> 861</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">ping</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L862"></a><tt class="py-lineno"> 862</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-297" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-297', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Ping test passed!"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L863"></a><tt class="py-lineno"> 863</tt> <tt class="py-line"> <tt class="py-comment"># Don't set PingResult or you'd override failures</tt> </tt>
+<a name="L864"></a><tt class="py-lineno"> 864</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">PingResult</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L865"></a><tt class="py-lineno"> 865</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-298" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-298', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-299" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-299', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L866"></a><tt class="py-lineno"> 866</tt> <tt class="py-line"> <tt class="py-string">"Intents have not been installed correctly, pings failed."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L867"></a><tt class="py-lineno"> 867</tt> <tt class="py-line"> <tt class="py-comment"># TODO: pretty print</tt> </tt>
+<a name="L868"></a><tt class="py-lineno"> 868</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-300" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-300', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS1 intents: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L869"></a><tt class="py-lineno"> 869</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L870"></a><tt class="py-lineno"> 870</tt> <tt class="py-line"> <tt class="py-name">tmpIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-301" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-301', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L871"></a><tt class="py-lineno"> 871</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-302" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-302', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">tmpIntents</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L872"></a><tt class="py-lineno"> 872</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L873"></a><tt class="py-lineno"> 873</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L874"></a><tt class="py-lineno"> 874</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L875"></a><tt class="py-lineno"> 875</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L876"></a><tt class="py-lineno"> 876</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-303" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-303', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">tmpIntents</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L877"></a><tt class="py-lineno"> 877</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L878"></a><tt class="py-lineno"> 878</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L879"></a><tt class="py-lineno"> 879</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">PingResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L880"></a><tt class="py-lineno"> 880</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intents have been installed correctly and pings work"</tt><tt class="py-op">,</tt> </tt>
+<a name="L881"></a><tt class="py-lineno"> 881</tt> <tt class="py-line"> <tt id="link-304" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-304', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Intents have not been installed correctly, pings failed."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L882"></a><tt class="py-lineno"> 882</tt> <tt class="py-line"> </tt>
+<a name="L883"></a><tt class="py-lineno"> 883</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-305" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-305', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check Intent state"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L884"></a><tt class="py-lineno"> 884</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L885"></a><tt class="py-lineno"> 885</tt> <tt class="py-line"> <tt class="py-name">loopCount</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L886"></a><tt class="py-lineno"> 886</tt> <tt class="py-line"> <tt class="py-keyword">while</tt> <tt class="py-keyword">not</tt> <tt class="py-name">installedCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">loopCount</tt> <tt class="py-op"><</tt> <tt class="py-number">40</tt><tt class="py-op">:</tt> </tt>
+<a name="L887"></a><tt class="py-lineno"> 887</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L888"></a><tt class="py-lineno"> 888</tt> <tt class="py-line"> <tt class="py-comment"># Print the intent states</tt> </tt>
+<a name="L889"></a><tt class="py-lineno"> 889</tt> <tt class="py-line"> <tt id="link-306" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-306', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-307" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-307', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L890"></a><tt class="py-lineno"> 890</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L891"></a><tt class="py-lineno"> 891</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-308" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-308', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt> <tt class="py-string">'Count'</tt><tt class="py-op">,</tt> <tt class="py-string">'ID'</tt><tt class="py-op">,</tt> <tt class="py-string">'State'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L892"></a><tt class="py-lineno"> 892</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L893"></a><tt class="py-lineno"> 893</tt> <tt class="py-line"> <tt class="py-comment"># Iter through intents of a node</tt> </tt>
+<a name="L894"></a><tt class="py-lineno"> 894</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L895"></a><tt class="py-lineno"> 895</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-309" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-309', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-310" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-310', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L896"></a><tt class="py-lineno"> 896</tt> <tt class="py-line"> <tt class="py-name">state</tt> <tt class="py-op">=</tt> <tt id="link-311" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-311', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'state'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L897"></a><tt class="py-lineno"> 897</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"INSTALLED"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">state</tt><tt class="py-op">:</tt> </tt>
+<a name="L898"></a><tt class="py-lineno"> 898</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L899"></a><tt class="py-lineno"> 899</tt> <tt class="py-line"> <tt class="py-name">intentId</tt> <tt class="py-op">=</tt> <tt id="link-312" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-312', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L900"></a><tt class="py-lineno"> 900</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt> <tt class="py-name">intentId</tt><tt class="py-op">,</tt> <tt class="py-name">state</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L901"></a><tt class="py-lineno"> 901</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L902"></a><tt class="py-lineno"> 902</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-313" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-313', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing intents."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L903"></a><tt class="py-lineno"> 903</tt> <tt class="py-line"> <tt class="py-comment"># Print states</tt> </tt>
+<a name="L904"></a><tt class="py-lineno"> 904</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">sort</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L905"></a><tt class="py-lineno"> 905</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentStates</tt><tt class="py-op">:</tt> </tt>
+<a name="L906"></a><tt class="py-lineno"> 906</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L907"></a><tt class="py-lineno"> 907</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-314" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-314', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> </tt>
+<a name="L908"></a><tt class="py-lineno"> 908</tt> <tt class="py-line"> <tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">count</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">s</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L909"></a><tt class="py-lineno"> 909</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">installedCheck</tt><tt class="py-op">:</tt> </tt>
+<a name="L910"></a><tt class="py-lineno"> 910</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L911"></a><tt class="py-lineno"> 911</tt> <tt class="py-line"> <tt class="py-name">loopCount</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L912"></a><tt class="py-lineno"> 912</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">installedCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L913"></a><tt class="py-lineno"> 913</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intents are all INSTALLED"</tt><tt class="py-op">,</tt> </tt>
+<a name="L914"></a><tt class="py-lineno"> 914</tt> <tt class="py-line"> <tt id="link-315" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-315', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Intents are not all in "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L915"></a><tt class="py-lineno"> 915</tt> <tt class="py-line"> <tt class="py-string">"INSTALLED state"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L916"></a><tt class="py-lineno"> 916</tt> <tt class="py-line"> </tt>
+<a name="L917"></a><tt class="py-lineno"> 917</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-316" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-316', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check leadership of topics"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L918"></a><tt class="py-lineno"> 918</tt> <tt class="py-line"> <tt id="link-317" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-317', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-318" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-318', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L919"></a><tt class="py-lineno"> 919</tt> <tt class="py-line"> <tt class="py-name">topicCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L920"></a><tt class="py-lineno"> 920</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L921"></a><tt class="py-lineno"> 921</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-319" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-319', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L922"></a><tt class="py-lineno"> 922</tt> <tt class="py-line"> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-320" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-320', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L923"></a><tt class="py-lineno"> 923</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-321" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-321', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedLeaders</tt><tt class="py-op">,</tt> </tt>
+<a name="L924"></a><tt class="py-lineno"> 924</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L925"></a><tt class="py-lineno"> 925</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L926"></a><tt class="py-lineno"> 926</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L927"></a><tt class="py-lineno"> 927</tt> <tt class="py-line"> <tt class="py-comment"># check for all intent partitions</tt> </tt>
+<a name="L928"></a><tt class="py-lineno"> 928</tt> <tt class="py-line"> <tt class="py-comment"># check for election</tt> </tt>
+<a name="L929"></a><tt class="py-lineno"> 929</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Look at Devices as topics now that it uses this system</tt> </tt>
+<a name="L930"></a><tt class="py-lineno"> 930</tt> <tt class="py-line"> <tt class="py-name">topics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L931"></a><tt class="py-lineno"> 931</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">14</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L932"></a><tt class="py-lineno"> 932</tt> <tt class="py-line"> <tt class="py-name">topics</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"intent-partition-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L933"></a><tt class="py-lineno"> 933</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: this should only be after we start the app</tt> </tt>
+<a name="L934"></a><tt class="py-lineno"> 934</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: topics.append( "org.onosproject.election" )</tt> </tt>
+<a name="L935"></a><tt class="py-lineno"> 935</tt> <tt class="py-line"> <tt class="py-comment"># Print leaders output</tt> </tt>
+<a name="L936"></a><tt class="py-lineno"> 936</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-322" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-322', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">topics</tt> <tt class="py-op">)</tt> </tt>
+<a name="L937"></a><tt class="py-lineno"> 937</tt> <tt class="py-line"> <tt class="py-name">ONOStopics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">j</tt><tt class="py-op">[</tt><tt class="py-string">'topic'</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">j</tt> <tt class="py-keyword">in</tt> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">]</tt> </tt>
+<a name="L938"></a><tt class="py-lineno"> 938</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">in</tt> <tt class="py-name">topics</tt><tt class="py-op">:</tt> </tt>
+<a name="L939"></a><tt class="py-lineno"> 939</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOStopics</tt><tt class="py-op">:</tt> </tt>
+<a name="L940"></a><tt class="py-lineno"> 940</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-323" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-323', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-324" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-324', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error: "</tt> <tt class="py-op">+</tt> <tt class="py-name">topic</tt> <tt class="py-op">+</tt> </tt>
+<a name="L941"></a><tt class="py-lineno"> 941</tt> <tt class="py-line"> <tt class="py-string">" not in leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L942"></a><tt class="py-lineno"> 942</tt> <tt class="py-line"> <tt class="py-name">topicCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L943"></a><tt class="py-lineno"> 943</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L944"></a><tt class="py-lineno"> 944</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-325" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-325', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-326" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-326', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"leaders() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L945"></a><tt class="py-lineno"> 945</tt> <tt class="py-line"> <tt class="py-name">topicCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L946"></a><tt class="py-lineno"> 946</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L947"></a><tt class="py-lineno"> 947</tt> <tt class="py-line"> <tt class="py-name">topicCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L948"></a><tt class="py-lineno"> 948</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-327" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-327', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L949"></a><tt class="py-lineno"> 949</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-328" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-328', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-329" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-329', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-330" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-330', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L950"></a><tt class="py-lineno"> 950</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Check for a leader of these topics</tt> </tt>
+<a name="L951"></a><tt class="py-lineno"> 951</tt> <tt class="py-line"> <tt class="py-comment"># Check all nodes</tt> </tt>
+<a name="L952"></a><tt class="py-lineno"> 952</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">topicCheck</tt><tt class="py-op">:</tt> </tt>
+<a name="L953"></a><tt class="py-lineno"> 953</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L954"></a><tt class="py-lineno"> 954</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt id="link-331" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-331', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt> <tt class="py-name">jsonFormat</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
+<a name="L955"></a><tt class="py-lineno"> 955</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-332" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-332', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" leaders output: \n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L956"></a><tt class="py-lineno"> 956</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L957"></a><tt class="py-lineno"> 957</tt> <tt class="py-line"> </tt>
+<a name="L958"></a><tt class="py-lineno"> 958</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">topicCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L959"></a><tt class="py-lineno"> 959</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"intent Partitions is in leaders"</tt><tt class="py-op">,</tt> </tt>
+<a name="L960"></a><tt class="py-lineno"> 960</tt> <tt class="py-line"> <tt id="link-333" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-333', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Some topics were lost "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L961"></a><tt class="py-lineno"> 961</tt> <tt class="py-line"> <tt class="py-comment"># Print partitions</tt> </tt>
+<a name="L962"></a><tt class="py-lineno"> 962</tt> <tt class="py-line"> <tt id="link-334" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-334', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-335" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-335', 'partitions', 'link-197');">partitions</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L963"></a><tt class="py-lineno"> 963</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L964"></a><tt class="py-lineno"> 964</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-336" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-336', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L965"></a><tt class="py-lineno"> 965</tt> <tt class="py-line"> <tt class="py-name">parsedPartitions</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-337" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-337', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L966"></a><tt class="py-lineno"> 966</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-338" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-338', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPartitions</tt><tt class="py-op">,</tt> </tt>
+<a name="L967"></a><tt class="py-lineno"> 967</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L968"></a><tt class="py-lineno"> 968</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L969"></a><tt class="py-lineno"> 969</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L970"></a><tt class="py-lineno"> 970</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for a leader in all paritions</tt> </tt>
+<a name="L971"></a><tt class="py-lineno"> 971</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for consistency among nodes</tt> </tt>
+<a name="L972"></a><tt class="py-lineno"> 972</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L973"></a><tt class="py-lineno"> 973</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-339" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-339', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-340" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-340', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"partitions() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L974"></a><tt class="py-lineno"> 974</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L975"></a><tt class="py-lineno"> 975</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-341" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-341', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing partitions"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L976"></a><tt class="py-lineno"> 976</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-342" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-342', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-343" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-343', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-344" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-344', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L977"></a><tt class="py-lineno"> 977</tt> <tt class="py-line"> <tt class="py-comment"># Print Pending Map</tt> </tt>
+<a name="L978"></a><tt class="py-lineno"> 978</tt> <tt class="py-line"> <tt id="link-345" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-345', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-346" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-346', 'pendingMap', 'link-208');">pendingMap</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L979"></a><tt class="py-lineno"> 979</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L980"></a><tt class="py-lineno"> 980</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-347" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-347', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L981"></a><tt class="py-lineno"> 981</tt> <tt class="py-line"> <tt class="py-name">parsedPending</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-348" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-348', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L982"></a><tt class="py-lineno"> 982</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-349" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-349', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPending</tt><tt class="py-op">,</tt> </tt>
+<a name="L983"></a><tt class="py-lineno"> 983</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L984"></a><tt class="py-lineno"> 984</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L985"></a><tt class="py-lineno"> 985</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L986"></a><tt class="py-lineno"> 986</tt> <tt class="py-line"> <tt class="py-comment"># TODO check something here?</tt> </tt>
+<a name="L987"></a><tt class="py-lineno"> 987</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L988"></a><tt class="py-lineno"> 988</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-350" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-350', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-351" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-351', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"pendingMap() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L989"></a><tt class="py-lineno"> 989</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L990"></a><tt class="py-lineno"> 990</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-352" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-352', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing pending map"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L991"></a><tt class="py-lineno"> 991</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-353" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-353', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-354" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-354', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-355" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-355', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L992"></a><tt class="py-lineno"> 992</tt> <tt class="py-line"> </tt>
+<a name="L993"></a><tt class="py-lineno"> 993</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">installedCheck</tt><tt class="py-op">:</tt> </tt>
+<a name="L994"></a><tt class="py-lineno"> 994</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-356" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-356', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Waiting 60 seconds to see if the state of "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L995"></a><tt class="py-lineno"> 995</tt> <tt class="py-line"> <tt class="py-string">"intents change"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L996"></a><tt class="py-lineno"> 996</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt>
+<a name="L997"></a><tt class="py-lineno"> 997</tt> <tt class="py-line"> <tt class="py-comment"># Print the intent states</tt> </tt>
+<a name="L998"></a><tt class="py-lineno"> 998</tt> <tt class="py-line"> <tt id="link-357" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-357', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-358" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-358', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L999"></a><tt class="py-lineno"> 999</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1000"></a><tt class="py-lineno">1000</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-359" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-359', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt> <tt class="py-string">'Count'</tt><tt class="py-op">,</tt> <tt class="py-string">'ID'</tt><tt class="py-op">,</tt> <tt class="py-string">'State'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1001"></a><tt class="py-lineno">1001</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L1002"></a><tt class="py-lineno">1002</tt> <tt class="py-line"> <tt class="py-comment"># Iter through intents of a node</tt> </tt>
+<a name="L1003"></a><tt class="py-lineno">1003</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1004"></a><tt class="py-lineno">1004</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-360" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-360', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-361" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-361', 'intents', 'link-172');">intents</a></tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1005"></a><tt class="py-lineno">1005</tt> <tt class="py-line"> <tt class="py-name">state</tt> <tt class="py-op">=</tt> <tt id="link-362" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-362', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'state'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1006"></a><tt class="py-lineno">1006</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"INSTALLED"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">state</tt><tt class="py-op">:</tt> </tt>
+<a name="L1007"></a><tt class="py-lineno">1007</tt> <tt class="py-line"> <tt class="py-name">installedCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1008"></a><tt class="py-lineno">1008</tt> <tt class="py-line"> <tt class="py-name">intentId</tt> <tt class="py-op">=</tt> <tt id="link-363" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-363', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1009"></a><tt class="py-lineno">1009</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt> <tt class="py-name">intentId</tt><tt class="py-op">,</tt> <tt class="py-name">state</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1010"></a><tt class="py-lineno">1010</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1011"></a><tt class="py-lineno">1011</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-364" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-364', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing intents."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1012"></a><tt class="py-lineno">1012</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">sort</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1013"></a><tt class="py-lineno">1013</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt> <tt class="py-keyword">in</tt> <tt class="py-name">intentStates</tt><tt class="py-op">:</tt> </tt>
+<a name="L1014"></a><tt class="py-lineno">1014</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L1015"></a><tt class="py-lineno">1015</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-365" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-365', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"%-6s%-15s%-15s"</tt> <tt class="py-op">%</tt> </tt>
+<a name="L1016"></a><tt class="py-lineno">1016</tt> <tt class="py-line"> <tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">count</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">s</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1017"></a><tt class="py-lineno">1017</tt> <tt class="py-line"> <tt id="link-366" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-366', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-367" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-367', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1018"></a><tt class="py-lineno">1018</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1019"></a><tt class="py-lineno">1019</tt> <tt class="py-line"> <tt class="py-name">missing</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1020"></a><tt class="py-lineno">1020</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-368" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-368', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L1021"></a><tt class="py-lineno">1021</tt> <tt class="py-line"> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-369" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-369', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L1022"></a><tt class="py-lineno">1022</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-370" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-370', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedLeaders</tt><tt class="py-op">,</tt> </tt>
+<a name="L1023"></a><tt class="py-lineno">1023</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1024"></a><tt class="py-lineno">1024</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1025"></a><tt class="py-lineno">1025</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1026"></a><tt class="py-lineno">1026</tt> <tt class="py-line"> <tt class="py-comment"># check for all intent partitions</tt> </tt>
+<a name="L1027"></a><tt class="py-lineno">1027</tt> <tt class="py-line"> <tt class="py-comment"># check for election</tt> </tt>
+<a name="L1028"></a><tt class="py-lineno">1028</tt> <tt class="py-line"> <tt class="py-name">topics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1029"></a><tt class="py-lineno">1029</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">14</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1030"></a><tt class="py-lineno">1030</tt> <tt class="py-line"> <tt class="py-name">topics</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"intent-partition-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1031"></a><tt class="py-lineno">1031</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: this should only be after we start the app</tt> </tt>
+<a name="L1032"></a><tt class="py-lineno">1032</tt> <tt class="py-line"> <tt class="py-name">topics</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1033"></a><tt class="py-lineno">1033</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-371" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-371', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">topics</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1034"></a><tt class="py-lineno">1034</tt> <tt class="py-line"> <tt class="py-name">ONOStopics</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">j</tt><tt class="py-op">[</tt><tt class="py-string">'topic'</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">j</tt> <tt class="py-keyword">in</tt> <tt class="py-name">parsedLeaders</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1035"></a><tt class="py-lineno">1035</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">in</tt> <tt class="py-name">topics</tt><tt class="py-op">:</tt> </tt>
+<a name="L1036"></a><tt class="py-lineno">1036</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">topic</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOStopics</tt><tt class="py-op">:</tt> </tt>
+<a name="L1037"></a><tt class="py-lineno">1037</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-372" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-372', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-373" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-373', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error: "</tt> <tt class="py-op">+</tt> <tt class="py-name">topic</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1038"></a><tt class="py-lineno">1038</tt> <tt class="py-line"> <tt class="py-string">" not in leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1039"></a><tt class="py-lineno">1039</tt> <tt class="py-line"> <tt class="py-name">missing</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1040"></a><tt class="py-lineno">1040</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1041"></a><tt class="py-lineno">1041</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-374" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-374', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-375" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-375', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"leaders() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1042"></a><tt class="py-lineno">1042</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1043"></a><tt class="py-lineno">1043</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-376" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-376', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1044"></a><tt class="py-lineno">1044</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-377" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-377', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-378" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-378', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-379" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-379', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1045"></a><tt class="py-lineno">1045</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">missing</tt><tt class="py-op">:</tt> </tt>
+<a name="L1046"></a><tt class="py-lineno">1046</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L1047"></a><tt class="py-lineno">1047</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt id="link-380" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-380', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">(</tt> <tt class="py-name">jsonFormat</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
+<a name="L1048"></a><tt class="py-lineno">1048</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-381" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-381', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" leaders output: \n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1049"></a><tt class="py-lineno">1049</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1050"></a><tt class="py-lineno">1050</tt> <tt class="py-line"> </tt>
+<a name="L1051"></a><tt class="py-lineno">1051</tt> <tt class="py-line"> <tt id="link-382" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-382', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-383" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-383', 'partitions', 'link-197');">partitions</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1052"></a><tt class="py-lineno">1052</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1053"></a><tt class="py-lineno">1053</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-384" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-384', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L1054"></a><tt class="py-lineno">1054</tt> <tt class="py-line"> <tt class="py-name">parsedPartitions</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-385" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-385', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L1055"></a><tt class="py-lineno">1055</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-386" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-386', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPartitions</tt><tt class="py-op">,</tt> </tt>
+<a name="L1056"></a><tt class="py-lineno">1056</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1057"></a><tt class="py-lineno">1057</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1058"></a><tt class="py-lineno">1058</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1059"></a><tt class="py-lineno">1059</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for a leader in all paritions</tt> </tt>
+<a name="L1060"></a><tt class="py-lineno">1060</tt> <tt class="py-line"> <tt class="py-comment"># TODO check for consistency among nodes</tt> </tt>
+<a name="L1061"></a><tt class="py-lineno">1061</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1062"></a><tt class="py-lineno">1062</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-387" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-387', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-388" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-388', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"partitions() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1063"></a><tt class="py-lineno">1063</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1064"></a><tt class="py-lineno">1064</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-389" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-389', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing partitions"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1065"></a><tt class="py-lineno">1065</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-390" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-390', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-391" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-391', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-392" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.partitions" class="py-name" href="#" onclick="return doclink('link-392', 'partitions', 'link-197');">partitions</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1066"></a><tt class="py-lineno">1066</tt> <tt class="py-line"> <tt id="link-393" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-393', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-394" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-394', 'pendingMap', 'link-208');">pendingMap</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1067"></a><tt class="py-lineno">1067</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1068"></a><tt class="py-lineno">1068</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-395" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-395', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">:</tt> </tt>
+<a name="L1069"></a><tt class="py-lineno">1069</tt> <tt class="py-line"> <tt class="py-name">parsedPending</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-396" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-396', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> </tt>
+<a name="L1070"></a><tt class="py-lineno">1070</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-397" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-397', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">parsedPending</tt><tt class="py-op">,</tt> </tt>
+<a name="L1071"></a><tt class="py-lineno">1071</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1072"></a><tt class="py-lineno">1072</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1073"></a><tt class="py-lineno">1073</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1074"></a><tt class="py-lineno">1074</tt> <tt class="py-line"> <tt class="py-comment"># TODO check something here?</tt> </tt>
+<a name="L1075"></a><tt class="py-lineno">1075</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1076"></a><tt class="py-lineno">1076</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-398" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-398', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-399" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-399', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"pendingMap() returned None"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1077"></a><tt class="py-lineno">1077</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1078"></a><tt class="py-lineno">1078</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-400" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-400', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing pending map"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1079"></a><tt class="py-lineno">1079</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-401" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-401', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-402" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-402', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-403" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.pendingMap" class="py-name" href="#" onclick="return doclink('link-403', 'pendingMap', 'link-208');">pendingMap</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1080"></a><tt class="py-lineno">1080</tt> <tt class="py-line"> <tt class="py-comment"># Print flowrules</tt> </tt>
+<a name="L1081"></a><tt class="py-lineno">1081</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-404" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-404', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-405" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#flows,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#flows"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-405', 'flows', 'link-405');">flows</a></tt><tt class="py-op">(</tt> <tt class="py-name">jsonFormat</tt><tt class="py-op">=</tt><tt class="py-name">False</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1082"></a><tt class="py-lineno">1082</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-406" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-406', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Wait a minute then ping again"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1083"></a><tt class="py-lineno">1083</tt> <tt class="py-line"> <tt class="py-comment"># the wait is above</tt> </tt>
+<a name="L1084"></a><tt class="py-lineno">1084</tt> <tt class="py-line"> <tt class="py-name">PingResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1085"></a><tt class="py-lineno">1085</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">8</tt><tt class="py-op">,</tt> <tt class="py-number">18</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1086"></a><tt class="py-lineno">1086</tt> <tt class="py-line"> <tt class="py-name">ping</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-407" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingHost
+TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingHost" class="py-name" href="#" onclick="return doclink('link-407', 'pingHost', 'link-295');">pingHost</a></tt><tt class="py-op">(</tt> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-string">"h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1087"></a><tt class="py-lineno">1087</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-string">"h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1088"></a><tt class="py-lineno">1088</tt> <tt class="py-line"> <tt class="py-name">PingResult</tt> <tt class="py-op">=</tt> <tt class="py-name">PingResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ping</tt> </tt>
+<a name="L1089"></a><tt class="py-lineno">1089</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ping</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L1090"></a><tt class="py-lineno">1090</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-408" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-408', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Ping failed between h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1091"></a><tt class="py-lineno">1091</tt> <tt class="py-line"> <tt class="py-string">" and h"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1092"></a><tt class="py-lineno">1092</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">ping</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L1093"></a><tt class="py-lineno">1093</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-409" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-409', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Ping test passed!"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1094"></a><tt class="py-lineno">1094</tt> <tt class="py-line"> <tt class="py-comment"># Don't set PingResult or you'd override failures</tt> </tt>
+<a name="L1095"></a><tt class="py-lineno">1095</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">PingResult</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L1096"></a><tt class="py-lineno">1096</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-410" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-410', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-411" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-411', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1097"></a><tt class="py-lineno">1097</tt> <tt class="py-line"> <tt class="py-string">"Intents have not been installed correctly, pings failed."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1098"></a><tt class="py-lineno">1098</tt> <tt class="py-line"> <tt class="py-comment"># TODO: pretty print</tt> </tt>
+<a name="L1099"></a><tt class="py-lineno">1099</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-412" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-412', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS1 intents: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1100"></a><tt class="py-lineno">1100</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1101"></a><tt class="py-lineno">1101</tt> <tt class="py-line"> <tt class="py-name">tmpIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-413" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-413', 'intents', 'link-172');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1102"></a><tt class="py-lineno">1102</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-414" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-414', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">tmpIntents</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1103"></a><tt class="py-lineno">1103</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1104"></a><tt class="py-lineno">1104</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1105"></a><tt class="py-lineno">1105</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1106"></a><tt class="py-lineno">1106</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1107"></a><tt class="py-lineno">1107</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-415" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-415', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">tmpIntents</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1108"></a><tt class="py-lineno">1108</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1109"></a><tt class="py-lineno">1109</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1110"></a><tt class="py-lineno">1110</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">PingResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1111"></a><tt class="py-lineno">1111</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intents have been installed correctly and pings work"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1112"></a><tt class="py-lineno">1112</tt> <tt class="py-line"> <tt id="link-416" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-416', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Intents have not been installed correctly, pings failed."</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L1113"></a><tt class="py-lineno">1113</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE5"></a><div id="HAsanity.CASE5-def"><a name="L1114"></a><tt class="py-lineno">1114</tt> <a class="py-toggle" href="#" id="HAsanity.CASE5-toggle" onclick="return toggle('HAsanity.CASE5');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE5">CASE5</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE5-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE5-expanded"><a name="L1115"></a><tt class="py-lineno">1115</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L1116"></a><tt class="py-lineno">1116</tt> <tt class="py-line"><tt class="py-docstring"> Reading state of ONOS</tt> </tt>
+<a name="L1117"></a><tt class="py-lineno">1117</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L1118"></a><tt class="py-lineno">1118</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt>
+<a name="L1119"></a><tt class="py-lineno">1119</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L1120"></a><tt class="py-lineno">1120</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L1121"></a><tt class="py-lineno">1121</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L1122"></a><tt class="py-lineno">1122</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L1123"></a><tt class="py-lineno">1123</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L1124"></a><tt class="py-lineno">1124</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-417" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-417', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L1125"></a><tt class="py-lineno">1125</tt> <tt class="py-line"> </tt>
+<a name="L1126"></a><tt class="py-lineno">1126</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-418" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-418', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Setting up and gathering data for current state"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1127"></a><tt class="py-lineno">1127</tt> <tt class="py-line"> <tt class="py-comment"># The general idea for this test case is to pull the state of</tt> </tt>
+<a name="L1128"></a><tt class="py-lineno">1128</tt> <tt class="py-line"> <tt class="py-comment"># ( intents,flows, topology,... ) from each ONOS node</tt> </tt>
+<a name="L1129"></a><tt class="py-lineno">1129</tt> <tt class="py-line"> <tt class="py-comment"># We can then compare them with each other and also with past states</tt> </tt>
+<a name="L1130"></a><tt class="py-lineno">1130</tt> <tt class="py-line"> </tt>
+<a name="L1131"></a><tt class="py-lineno">1131</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-419" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-419', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check that each switch has a master"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1132"></a><tt class="py-lineno">1132</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">mastershipState</tt> </tt>
+<a name="L1133"></a><tt class="py-lineno">1133</tt> <tt class="py-line"> <tt class="py-name">mastershipState</tt> <tt class="py-op">=</tt> <tt class="py-string">'[]'</tt> </tt>
+<a name="L1134"></a><tt class="py-lineno">1134</tt> <tt class="py-line"> </tt>
+<a name="L1135"></a><tt class="py-lineno">1135</tt> <tt class="py-line"> <tt class="py-comment"># Assert that each device has a master</tt> </tt>
+<a name="L1136"></a><tt class="py-lineno">1136</tt> <tt class="py-line"> <tt id="link-420" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#rolesNotNull"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-420', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1137"></a><tt class="py-lineno">1137</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1138"></a><tt class="py-lineno">1138</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1139"></a><tt class="py-lineno">1139</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-421" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-421', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-422" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-422', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1140"></a><tt class="py-lineno">1140</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"rolesNotNull-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1141"></a><tt class="py-lineno">1141</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1142"></a><tt class="py-lineno">1142</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1143"></a><tt class="py-lineno">1143</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1144"></a><tt class="py-lineno">1144</tt> <tt class="py-line"> </tt>
+<a name="L1145"></a><tt class="py-lineno">1145</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1146"></a><tt class="py-lineno">1146</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1147"></a><tt class="py-lineno">1147</tt> <tt class="py-line"> <tt id="link-423" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-423', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt> <tt class="py-op">=</tt> <tt id="link-424" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-424', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L1148"></a><tt class="py-lineno">1148</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1149"></a><tt class="py-lineno">1149</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1150"></a><tt class="py-lineno">1150</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt id="link-425" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-425', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1151"></a><tt class="py-lineno">1151</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Each device has a master"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1152"></a><tt class="py-lineno">1152</tt> <tt class="py-line"> <tt id="link-426" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-426', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Some devices don't have a master assigned"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1153"></a><tt class="py-lineno">1153</tt> <tt class="py-line"> </tt>
+<a name="L1154"></a><tt class="py-lineno">1154</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-427" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-427', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get the Mastership of each switch from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1155"></a><tt class="py-lineno">1155</tt> <tt class="py-line"> <tt class="py-name">ONOSMastership</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1156"></a><tt class="py-lineno">1156</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1157"></a><tt class="py-lineno">1157</tt> <tt class="py-line"> <tt class="py-name">consistentMastership</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1158"></a><tt class="py-lineno">1158</tt> <tt class="py-line"> <tt class="py-name">rolesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1159"></a><tt class="py-lineno">1159</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1160"></a><tt class="py-lineno">1160</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1161"></a><tt class="py-lineno">1161</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-428" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-428', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-429" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.roles()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#roles"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.roles" class="py-name" href="#" onclick="return doclink('link-429', 'roles', 'link-429');">roles</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1162"></a><tt class="py-lineno">1162</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"roles-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1163"></a><tt class="py-lineno">1163</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1164"></a><tt class="py-lineno">1164</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1165"></a><tt class="py-lineno">1165</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1166"></a><tt class="py-lineno">1166</tt> <tt class="py-line"> </tt>
+<a name="L1167"></a><tt class="py-lineno">1167</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1168"></a><tt class="py-lineno">1168</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1169"></a><tt class="py-lineno">1169</tt> <tt class="py-line"> <tt class="py-name">ONOSMastership</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1170"></a><tt class="py-lineno">1170</tt> <tt class="py-line"> </tt>
+<a name="L1171"></a><tt class="py-lineno">1171</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1172"></a><tt class="py-lineno">1172</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1173"></a><tt class="py-lineno">1173</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-430" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-430', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-431" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-431', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1174"></a><tt class="py-lineno">1174</tt> <tt class="py-line"> <tt class="py-string">" roles"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1175"></a><tt class="py-lineno">1175</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-432" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-432', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> </tt>
+<a name="L1176"></a><tt class="py-lineno">1176</tt> <tt class="py-line"> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" mastership response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1177"></a><tt class="py-lineno">1177</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1178"></a><tt class="py-lineno">1178</tt> <tt class="py-line"> <tt class="py-name">rolesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1179"></a><tt class="py-lineno">1179</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1180"></a><tt class="py-lineno">1180</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1181"></a><tt class="py-lineno">1181</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">rolesResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1182"></a><tt class="py-lineno">1182</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"No error in reading roles output"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1183"></a><tt class="py-lineno">1183</tt> <tt class="py-line"> <tt id="link-433" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-433', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error in reading roles from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1184"></a><tt class="py-lineno">1184</tt> <tt class="py-line"> </tt>
+<a name="L1185"></a><tt class="py-lineno">1185</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-434" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-434', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check for consistency in roles from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1186"></a><tt class="py-lineno">1186</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSMastership</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1187"></a><tt class="py-lineno">1187</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-435" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-435', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt>
+<a name="L1188"></a><tt class="py-lineno">1188</tt> <tt class="py-line"> <tt class="py-string">"Switch roles are consistent across all ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1189"></a><tt class="py-lineno">1189</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1190"></a><tt class="py-lineno">1190</tt> <tt class="py-line"> <tt class="py-name">consistentMastership</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1191"></a><tt class="py-lineno">1191</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1192"></a><tt class="py-lineno">1192</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1193"></a><tt class="py-lineno">1193</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentMastership</tt><tt class="py-op">,</tt> </tt>
+<a name="L1194"></a><tt class="py-lineno">1194</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Switch roles are consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1195"></a><tt class="py-lineno">1195</tt> <tt class="py-line"> <tt id="link-436" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-436', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of switch roles"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1196"></a><tt class="py-lineno">1196</tt> <tt class="py-line"> </tt>
+<a name="L1197"></a><tt class="py-lineno">1197</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">rolesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">consistentMastership</tt><tt class="py-op">:</tt> </tt>
+<a name="L1198"></a><tt class="py-lineno">1198</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1199"></a><tt class="py-lineno">1199</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1200"></a><tt class="py-lineno">1200</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-437" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-437', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> </tt>
+<a name="L1201"></a><tt class="py-lineno">1201</tt> <tt class="py-line"> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" roles: "</tt><tt class="py-op">,</tt> </tt>
+<a name="L1202"></a><tt class="py-lineno">1202</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> </tt>
+<a name="L1203"></a><tt class="py-lineno">1203</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1204"></a><tt class="py-lineno">1204</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1205"></a><tt class="py-lineno">1205</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1206"></a><tt class="py-lineno">1206</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1207"></a><tt class="py-lineno">1207</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1208"></a><tt class="py-lineno">1208</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-438" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-438', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1209"></a><tt class="py-lineno">1209</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">rolesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentMastership</tt><tt class="py-op">:</tt> </tt>
+<a name="L1210"></a><tt class="py-lineno">1210</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1211"></a><tt class="py-lineno">1211</tt> <tt class="py-line"> <tt class="py-name">mastershipState</tt> <tt class="py-op">=</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1212"></a><tt class="py-lineno">1212</tt> <tt class="py-line"> </tt>
+<a name="L1213"></a><tt class="py-lineno">1213</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-439" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-439', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get the intents from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1214"></a><tt class="py-lineno">1214</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">intentState</tt> </tt>
+<a name="L1215"></a><tt class="py-lineno">1215</tt> <tt class="py-line"> <tt class="py-name">intentState</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1216"></a><tt class="py-lineno">1216</tt> <tt class="py-line"> <tt class="py-name">ONOSIntents</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1217"></a><tt class="py-lineno">1217</tt> <tt class="py-line"> <tt class="py-name">intentCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1218"></a><tt class="py-lineno">1218</tt> <tt class="py-line"> <tt class="py-name">consistentIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1219"></a><tt class="py-lineno">1219</tt> <tt class="py-line"> <tt class="py-name">intentsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1220"></a><tt class="py-lineno">1220</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1221"></a><tt class="py-lineno">1221</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1222"></a><tt class="py-lineno">1222</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-440" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-440', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-441" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-441', 'intents', 'link-172');">intents</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1223"></a><tt class="py-lineno">1223</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"intents-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1224"></a><tt class="py-lineno">1224</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1225"></a><tt class="py-lineno">1225</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">'jsonFormat'</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1226"></a><tt class="py-lineno">1226</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1227"></a><tt class="py-lineno">1227</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1228"></a><tt class="py-lineno">1228</tt> <tt class="py-line"> </tt>
+<a name="L1229"></a><tt class="py-lineno">1229</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1230"></a><tt class="py-lineno">1230</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1231"></a><tt class="py-lineno">1231</tt> <tt class="py-line"> <tt class="py-name">ONOSIntents</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1232"></a><tt class="py-lineno">1232</tt> <tt class="py-line"> </tt>
+<a name="L1233"></a><tt class="py-lineno">1233</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1234"></a><tt class="py-lineno">1234</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1235"></a><tt class="py-lineno">1235</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-442" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-442', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-443" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-443', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1236"></a><tt class="py-lineno">1236</tt> <tt class="py-line"> <tt class="py-string">" intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1237"></a><tt class="py-lineno">1237</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-444" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-444', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1238"></a><tt class="py-lineno">1238</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1239"></a><tt class="py-lineno">1239</tt> <tt class="py-line"> <tt class="py-name">intentsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1240"></a><tt class="py-lineno">1240</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1241"></a><tt class="py-lineno">1241</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1242"></a><tt class="py-lineno">1242</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">intentsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1243"></a><tt class="py-lineno">1243</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"No error in reading intents output"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1244"></a><tt class="py-lineno">1244</tt> <tt class="py-line"> <tt id="link-445" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-445', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error in reading intents from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1245"></a><tt class="py-lineno">1245</tt> <tt class="py-line"> </tt>
+<a name="L1246"></a><tt class="py-lineno">1246</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-446" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-446', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check for consistency in Intents from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1247"></a><tt class="py-lineno">1247</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt><tt class="py-op">[</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1248"></a><tt class="py-lineno">1248</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-447" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-447', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Intents are consistent across all ONOS "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1249"></a><tt class="py-lineno">1249</tt> <tt class="py-line"> <tt class="py-string">"nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1250"></a><tt class="py-lineno">1250</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1251"></a><tt class="py-lineno">1251</tt> <tt class="py-line"> <tt class="py-name">consistentIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1252"></a><tt class="py-lineno">1252</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-448" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-448', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-449" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-449', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Intents not consistent"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1253"></a><tt class="py-lineno">1253</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1254"></a><tt class="py-lineno">1254</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1255"></a><tt class="py-lineno">1255</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentIntents</tt><tt class="py-op">,</tt> </tt>
+<a name="L1256"></a><tt class="py-lineno">1256</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intents are consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1257"></a><tt class="py-lineno">1257</tt> <tt class="py-line"> <tt id="link-450" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-450', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1258"></a><tt class="py-lineno">1258</tt> <tt class="py-line"> </tt>
+<a name="L1259"></a><tt class="py-lineno">1259</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">intentsResults</tt><tt class="py-op">:</tt> </tt>
+<a name="L1260"></a><tt class="py-lineno">1260</tt> <tt class="py-line"> <tt class="py-comment"># Try to make it easy to figure out what is happening</tt> </tt>
+<a name="L1261"></a><tt class="py-lineno">1261</tt> <tt class="py-line"> <tt class="py-comment">#</tt> </tt>
+<a name="L1262"></a><tt class="py-lineno">1262</tt> <tt class="py-line"> <tt class="py-comment"># Intent ONOS1 ONOS2 ...</tt> </tt>
+<a name="L1263"></a><tt class="py-lineno">1263</tt> <tt class="py-line"> <tt class="py-comment"># 0x01 INSTALLED INSTALLING</tt> </tt>
+<a name="L1264"></a><tt class="py-lineno">1264</tt> <tt class="py-line"> <tt class="py-comment"># ... ... ...</tt> </tt>
+<a name="L1265"></a><tt class="py-lineno">1265</tt> <tt class="py-line"> <tt class="py-comment"># ... ... ...</tt> </tt>
+<a name="L1266"></a><tt class="py-lineno">1266</tt> <tt class="py-line"> <tt class="py-name">title</tt> <tt class="py-op">=</tt> <tt class="py-string">" Id"</tt> </tt>
+<a name="L1267"></a><tt class="py-lineno">1267</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">n</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1268"></a><tt class="py-lineno">1268</tt> <tt class="py-line"> <tt class="py-name">title</tt> <tt class="py-op">+=</tt> <tt class="py-string">" "</tt> <tt class="py-op">*</tt> <tt class="py-number">10</tt> <tt class="py-op">+</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">n</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1269"></a><tt class="py-lineno">1269</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-451" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-451', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">title</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1270"></a><tt class="py-lineno">1270</tt> <tt class="py-line"> <tt class="py-comment"># get all intent keys in the cluster</tt> </tt>
+<a name="L1271"></a><tt class="py-lineno">1271</tt> <tt class="py-line"> <tt class="py-name">keys</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1272"></a><tt class="py-lineno">1272</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1273"></a><tt class="py-lineno">1273</tt> <tt class="py-line"> <tt class="py-comment"># Get the set of all intent keys</tt> </tt>
+<a name="L1274"></a><tt class="py-lineno">1274</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">nodeStr</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1275"></a><tt class="py-lineno">1275</tt> <tt class="py-line"> <tt class="py-name">node</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1276"></a><tt class="py-lineno">1276</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-452" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-452', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">node</tt><tt class="py-op">:</tt> </tt>
+<a name="L1277"></a><tt class="py-lineno">1277</tt> <tt class="py-line"> <tt class="py-name">keys</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt id="link-453" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-453', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1278"></a><tt class="py-lineno">1278</tt> <tt class="py-line"> <tt class="py-name">keys</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">keys</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1279"></a><tt class="py-lineno">1279</tt> <tt class="py-line"> <tt class="py-comment"># For each intent key, print the state on each node</tt> </tt>
+<a name="L1280"></a><tt class="py-lineno">1280</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">keys</tt><tt class="py-op">:</tt> </tt>
+<a name="L1281"></a><tt class="py-lineno">1281</tt> <tt class="py-line"> <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-string">"%-13s"</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
+<a name="L1282"></a><tt class="py-lineno">1282</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">nodeStr</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1283"></a><tt class="py-lineno">1283</tt> <tt class="py-line"> <tt class="py-name">node</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1284"></a><tt class="py-lineno">1284</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-454" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-454', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">node</tt><tt class="py-op">:</tt> </tt>
+<a name="L1285"></a><tt class="py-lineno">1285</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-455" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-455', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-string">"Error"</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">key</tt><tt class="py-op">:</tt> </tt>
+<a name="L1286"></a><tt class="py-lineno">1286</tt> <tt class="py-line"> <tt class="py-name">row</tt> <tt class="py-op">+=</tt> <tt class="py-string">"%-15s"</tt> <tt class="py-op">%</tt> <tt id="link-456" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-456', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'state'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1287"></a><tt class="py-lineno">1287</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-457" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-457', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">row</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1288"></a><tt class="py-lineno">1288</tt> <tt class="py-line"> <tt class="py-comment"># End of intent state table</tt> </tt>
+<a name="L1289"></a><tt class="py-lineno">1289</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">ValueError</tt> <tt class="py-keyword">as</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt>
+<a name="L1290"></a><tt class="py-lineno">1290</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-458" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-458', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">e</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1291"></a><tt class="py-lineno">1291</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-459" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-459', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"nodeStr was: "</tt> <tt class="py-op">+</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStr</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1292"></a><tt class="py-lineno">1292</tt> <tt class="py-line"> </tt>
+<a name="L1293"></a><tt class="py-lineno">1293</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">intentsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">consistentIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1294"></a><tt class="py-lineno">1294</tt> <tt class="py-line"> <tt class="py-comment"># print the json objects</tt> </tt>
+<a name="L1295"></a><tt class="py-lineno">1295</tt> <tt class="py-line"> <tt class="py-name">n</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIntents</tt><tt class="py-op">)</tt> </tt>
+<a name="L1296"></a><tt class="py-lineno">1296</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-460" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-460', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">n</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1297"></a><tt class="py-lineno">1297</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-461" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-461', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-op">-</tt><tt class="py-number">1</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1298"></a><tt class="py-lineno">1298</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1299"></a><tt class="py-lineno">1299</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1300"></a><tt class="py-lineno">1300</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1301"></a><tt class="py-lineno">1301</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1302"></a><tt class="py-lineno">1302</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-op">-</tt><tt class="py-number">1</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1303"></a><tt class="py-lineno">1303</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-462" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-462', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1304"></a><tt class="py-lineno">1304</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-463" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-463', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1305"></a><tt class="py-lineno">1305</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1306"></a><tt class="py-lineno">1306</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1307"></a><tt class="py-lineno">1307</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1308"></a><tt class="py-lineno">1308</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1309"></a><tt class="py-lineno">1309</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-464" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-464', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-465" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-465', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents match ONOS"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1310"></a><tt class="py-lineno">1310</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">n</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1311"></a><tt class="py-lineno">1311</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">intentsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1312"></a><tt class="py-lineno">1312</tt> <tt class="py-line"> <tt class="py-name">intentCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1313"></a><tt class="py-lineno">1313</tt> <tt class="py-line"> <tt class="py-name">intentState</tt> <tt class="py-op">=</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1314"></a><tt class="py-lineno">1314</tt> <tt class="py-line"> </tt>
+<a name="L1315"></a><tt class="py-lineno">1315</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-466" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-466', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get the flows from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1316"></a><tt class="py-lineno">1316</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">flowState</tt> </tt>
+<a name="L1317"></a><tt class="py-lineno">1317</tt> <tt class="py-line"> <tt class="py-name">flowState</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1318"></a><tt class="py-lineno">1318</tt> <tt class="py-line"> <tt class="py-name">ONOSFlows</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1319"></a><tt class="py-lineno">1319</tt> <tt class="py-line"> <tt class="py-name">ONOSFlowsJson</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1320"></a><tt class="py-lineno">1320</tt> <tt class="py-line"> <tt class="py-name">flowCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1321"></a><tt class="py-lineno">1321</tt> <tt class="py-line"> <tt class="py-name">consistentFlows</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1322"></a><tt class="py-lineno">1322</tt> <tt class="py-line"> <tt class="py-name">flowsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1323"></a><tt class="py-lineno">1323</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1324"></a><tt class="py-lineno">1324</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1325"></a><tt class="py-lineno">1325</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-467" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-467', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-468" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-468', 'flows', 'link-405');">flows</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1326"></a><tt class="py-lineno">1326</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"flows-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1327"></a><tt class="py-lineno">1327</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1328"></a><tt class="py-lineno">1328</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">'jsonFormat'</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1329"></a><tt class="py-lineno">1329</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1330"></a><tt class="py-lineno">1330</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1331"></a><tt class="py-lineno">1331</tt> <tt class="py-line"> </tt>
+<a name="L1332"></a><tt class="py-lineno">1332</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: Flows command can take some time to run</tt> </tt>
+<a name="L1333"></a><tt class="py-lineno">1333</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt><tt class="py-number">30</tt><tt class="py-op">)</tt> </tt>
+<a name="L1334"></a><tt class="py-lineno">1334</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1335"></a><tt class="py-lineno">1335</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1336"></a><tt class="py-lineno">1336</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L1337"></a><tt class="py-lineno">1337</tt> <tt class="py-line"> <tt class="py-name">ONOSFlows</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1338"></a><tt class="py-lineno">1338</tt> <tt class="py-line"> </tt>
+<a name="L1339"></a><tt class="py-lineno">1339</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1340"></a><tt class="py-lineno">1340</tt> <tt class="py-line"> <tt class="py-name">num</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1341"></a><tt class="py-lineno">1341</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1342"></a><tt class="py-lineno">1342</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-469" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-469', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-470" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-470', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">num</tt> <tt class="py-op">+</tt> <tt class="py-string">" flows"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1343"></a><tt class="py-lineno">1343</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-471" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-471', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">num</tt> <tt class="py-op">+</tt> <tt class="py-string">" flows response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1344"></a><tt class="py-lineno">1344</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1345"></a><tt class="py-lineno">1345</tt> <tt class="py-line"> <tt class="py-name">flowsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1346"></a><tt class="py-lineno">1346</tt> <tt class="py-line"> <tt class="py-name">ONOSFlowsJson</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1347"></a><tt class="py-lineno">1347</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1348"></a><tt class="py-lineno">1348</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1349"></a><tt class="py-lineno">1349</tt> <tt class="py-line"> <tt class="py-name">ONOSFlowsJson</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1350"></a><tt class="py-lineno">1350</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1351"></a><tt class="py-lineno">1351</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: change this to log.error?</tt> </tt>
+<a name="L1352"></a><tt class="py-lineno">1352</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-472" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-472', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error in parsing ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">num</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1353"></a><tt class="py-lineno">1353</tt> <tt class="py-line"> <tt class="py-string">" response as json."</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1354"></a><tt class="py-lineno">1354</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-473" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-473', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-474" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-474', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1355"></a><tt class="py-lineno">1355</tt> <tt class="py-line"> <tt class="py-name">ONOSFlowsJson</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1356"></a><tt class="py-lineno">1356</tt> <tt class="py-line"> <tt class="py-name">flowsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1357"></a><tt class="py-lineno">1357</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1358"></a><tt class="py-lineno">1358</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1359"></a><tt class="py-lineno">1359</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">flowsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1360"></a><tt class="py-lineno">1360</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"No error in reading flows output"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1361"></a><tt class="py-lineno">1361</tt> <tt class="py-line"> <tt id="link-475" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-475', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error in reading flows from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1362"></a><tt class="py-lineno">1362</tt> <tt class="py-line"> </tt>
+<a name="L1363"></a><tt class="py-lineno">1363</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-476" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-476', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check for consistency in Flows from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1364"></a><tt class="py-lineno">1364</tt> <tt class="py-line"> <tt class="py-name">tmp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSFlowsJson</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSFlowsJson</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1365"></a><tt class="py-lineno">1365</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt> <tt class="py-name">tmp</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1366"></a><tt class="py-lineno">1366</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-477" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-477', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Flow count is consistent across all ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1367"></a><tt class="py-lineno">1367</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1368"></a><tt class="py-lineno">1368</tt> <tt class="py-line"> <tt class="py-name">consistentFlows</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1369"></a><tt class="py-lineno">1369</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1370"></a><tt class="py-lineno">1370</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1371"></a><tt class="py-lineno">1371</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentFlows</tt><tt class="py-op">,</tt> </tt>
+<a name="L1372"></a><tt class="py-lineno">1372</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"The flow count is consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1373"></a><tt class="py-lineno">1373</tt> <tt class="py-line"> <tt id="link-478" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-478', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different flow counts"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1374"></a><tt class="py-lineno">1374</tt> <tt class="py-line"> </tt>
+<a name="L1375"></a><tt class="py-lineno">1375</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">flowsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">consistentFlows</tt><tt class="py-op">:</tt> </tt>
+<a name="L1376"></a><tt class="py-lineno">1376</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1377"></a><tt class="py-lineno">1377</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1378"></a><tt class="py-lineno">1378</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-479" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-479', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> </tt>
+<a name="L1379"></a><tt class="py-lineno">1379</tt> <tt class="py-line"> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" flows: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1380"></a><tt class="py-lineno">1380</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1381"></a><tt class="py-lineno">1381</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1382"></a><tt class="py-lineno">1382</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1383"></a><tt class="py-lineno">1383</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-480" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-480', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> </tt>
+<a name="L1384"></a><tt class="py-lineno">1384</tt> <tt class="py-line"> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" flows: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1385"></a><tt class="py-lineno">1385</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1386"></a><tt class="py-lineno">1386</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">flowsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentFlows</tt><tt class="py-op">:</tt> </tt>
+<a name="L1387"></a><tt class="py-lineno">1387</tt> <tt class="py-line"> <tt class="py-name">flowCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1388"></a><tt class="py-lineno">1388</tt> <tt class="py-line"> <tt class="py-name">flowState</tt> <tt class="py-op">=</tt> <tt class="py-name">ONOSFlows</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1389"></a><tt class="py-lineno">1389</tt> <tt class="py-line"> </tt>
+<a name="L1390"></a><tt class="py-lineno">1390</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-481" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-481', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get the OF Table entries"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1391"></a><tt class="py-lineno">1391</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt id="link-482" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-482', 'flows', 'link-405');">flows</a></tt> </tt>
+<a name="L1392"></a><tt class="py-lineno">1392</tt> <tt class="py-line"> <tt id="link-483" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-483', 'flows', 'link-405');">flows</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1393"></a><tt class="py-lineno">1393</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-number">29</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1394"></a><tt class="py-lineno">1394</tt> <tt class="py-line"> <tt id="link-484" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-484', 'flows', 'link-405');">flows</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-485" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getFlowTable()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getFlowTable"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getFlowTable" class="py-name" href="#" onclick="return doclink('link-485', 'getFlowTable', 'link-485');">getFlowTable</a></tt><tt class="py-op">(</tt> <tt class="py-number">1.3</tt><tt class="py-op">,</tt> <tt class="py-string">"s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1395"></a><tt class="py-lineno">1395</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">flowCheck</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L1396"></a><tt class="py-lineno">1396</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">table</tt> <tt class="py-keyword">in</tt> <tt id="link-486" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-486', 'flows', 'link-405');">flows</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L1397"></a><tt class="py-lineno">1397</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-487" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-487', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">table</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1398"></a><tt class="py-lineno">1398</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Compare switch flow tables with ONOS flow tables</tt> </tt>
+<a name="L1399"></a><tt class="py-lineno">1399</tt> <tt class="py-line"> </tt>
+<a name="L1400"></a><tt class="py-lineno">1400</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-488" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-488', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Start continuous pings"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1401"></a><tt class="py-lineno">1401</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-489" class="py-name" targets="Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#pingLong"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-489', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1402"></a><tt class="py-lineno">1402</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source1'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1403"></a><tt class="py-lineno">1403</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target1'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1404"></a><tt class="py-lineno">1404</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1405"></a><tt class="py-lineno">1405</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-490" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-490', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1406"></a><tt class="py-lineno">1406</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source2'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1407"></a><tt class="py-lineno">1407</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target2'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1408"></a><tt class="py-lineno">1408</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1409"></a><tt class="py-lineno">1409</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-491" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-491', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1410"></a><tt class="py-lineno">1410</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source3'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1411"></a><tt class="py-lineno">1411</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target3'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1412"></a><tt class="py-lineno">1412</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1413"></a><tt class="py-lineno">1413</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-492" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-492', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1414"></a><tt class="py-lineno">1414</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source4'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1415"></a><tt class="py-lineno">1415</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target4'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1416"></a><tt class="py-lineno">1416</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1417"></a><tt class="py-lineno">1417</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-493" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-493', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1418"></a><tt class="py-lineno">1418</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source5'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1419"></a><tt class="py-lineno">1419</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target5'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1420"></a><tt class="py-lineno">1420</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1421"></a><tt class="py-lineno">1421</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-494" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-494', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1422"></a><tt class="py-lineno">1422</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source6'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1423"></a><tt class="py-lineno">1423</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target6'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1424"></a><tt class="py-lineno">1424</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1425"></a><tt class="py-lineno">1425</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-495" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-495', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1426"></a><tt class="py-lineno">1426</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source7'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1427"></a><tt class="py-lineno">1427</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target7'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1428"></a><tt class="py-lineno">1428</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1429"></a><tt class="py-lineno">1429</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-496" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-496', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1430"></a><tt class="py-lineno">1430</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source8'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1431"></a><tt class="py-lineno">1431</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target8'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1432"></a><tt class="py-lineno">1432</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1433"></a><tt class="py-lineno">1433</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-497" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-497', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1434"></a><tt class="py-lineno">1434</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source9'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1435"></a><tt class="py-lineno">1435</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target9'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1436"></a><tt class="py-lineno">1436</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1437"></a><tt class="py-lineno">1437</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-498" class="py-name"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLong" class="py-name" href="#" onclick="return doclink('link-498', 'pingLong', 'link-489');">pingLong</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1438"></a><tt class="py-lineno">1438</tt> <tt class="py-line"> <tt class="py-name">src</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'source10'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1439"></a><tt class="py-lineno">1439</tt> <tt class="py-line"> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'PING'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'target10'</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1440"></a><tt class="py-lineno">1440</tt> <tt class="py-line"> <tt class="py-name">pingTime</tt><tt class="py-op">=</tt><tt class="py-number">500</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1441"></a><tt class="py-lineno">1441</tt> <tt class="py-line"> </tt>
+<a name="L1442"></a><tt class="py-lineno">1442</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-499" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-499', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collecting topology information from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1443"></a><tt class="py-lineno">1443</tt> <tt class="py-line"> <tt id="link-500" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-500', 'devices', 'link-114');">devices</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1444"></a><tt class="py-lineno">1444</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1445"></a><tt class="py-lineno">1445</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1446"></a><tt class="py-lineno">1446</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-501" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-501', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-502" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-502', 'devices', 'link-114');">devices</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1447"></a><tt class="py-lineno">1447</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"devices-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1448"></a><tt class="py-lineno">1448</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1449"></a><tt class="py-lineno">1449</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1450"></a><tt class="py-lineno">1450</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1451"></a><tt class="py-lineno">1451</tt> <tt class="py-line"> </tt>
+<a name="L1452"></a><tt class="py-lineno">1452</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1453"></a><tt class="py-lineno">1453</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1454"></a><tt class="py-lineno">1454</tt> <tt class="py-line"> <tt id="link-503" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-503', 'devices', 'link-114');">devices</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1455"></a><tt class="py-lineno">1455</tt> <tt class="py-line"> <tt id="link-504" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-504', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1456"></a><tt class="py-lineno">1456</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1457"></a><tt class="py-lineno">1457</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1458"></a><tt class="py-lineno">1458</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-505" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-505', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-506" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-506', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1459"></a><tt class="py-lineno">1459</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"hosts-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1460"></a><tt class="py-lineno">1460</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1461"></a><tt class="py-lineno">1461</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1462"></a><tt class="py-lineno">1462</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1463"></a><tt class="py-lineno">1463</tt> <tt class="py-line"> </tt>
+<a name="L1464"></a><tt class="py-lineno">1464</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1465"></a><tt class="py-lineno">1465</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1466"></a><tt class="py-lineno">1466</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1467"></a><tt class="py-lineno">1467</tt> <tt class="py-line"> <tt id="link-507" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-507', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1468"></a><tt class="py-lineno">1468</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1469"></a><tt class="py-lineno">1469</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: better handling of this, print which node</tt> </tt>
+<a name="L1470"></a><tt class="py-lineno">1470</tt> <tt class="py-line"> <tt class="py-comment"># Maybe use thread name?</tt> </tt>
+<a name="L1471"></a><tt class="py-lineno">1471</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-508" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-508', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing json output of hosts"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1472"></a><tt class="py-lineno">1472</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: should this be an empty json object instead?</tt> </tt>
+<a name="L1473"></a><tt class="py-lineno">1473</tt> <tt class="py-line"> <tt id="link-509" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-509', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">None</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1474"></a><tt class="py-lineno">1474</tt> <tt class="py-line"> </tt>
+<a name="L1475"></a><tt class="py-lineno">1475</tt> <tt class="py-line"> <tt id="link-510" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#ports"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-510', 'ports', 'link-510');">ports</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1476"></a><tt class="py-lineno">1476</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1477"></a><tt class="py-lineno">1477</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1478"></a><tt class="py-lineno">1478</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-511" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-511', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-512" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-512', 'ports', 'link-510');">ports</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1479"></a><tt class="py-lineno">1479</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"ports-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1480"></a><tt class="py-lineno">1480</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1481"></a><tt class="py-lineno">1481</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1482"></a><tt class="py-lineno">1482</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1483"></a><tt class="py-lineno">1483</tt> <tt class="py-line"> </tt>
+<a name="L1484"></a><tt class="py-lineno">1484</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1485"></a><tt class="py-lineno">1485</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1486"></a><tt class="py-lineno">1486</tt> <tt class="py-line"> <tt id="link-513" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-513', 'ports', 'link-510');">ports</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1487"></a><tt class="py-lineno">1487</tt> <tt class="py-line"> <tt id="link-514" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#links,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#links"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-514', 'links', 'link-514');">links</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1488"></a><tt class="py-lineno">1488</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1489"></a><tt class="py-lineno">1489</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1490"></a><tt class="py-lineno">1490</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-515" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-515', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-516" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-516', 'links', 'link-514');">links</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1491"></a><tt class="py-lineno">1491</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"links-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1492"></a><tt class="py-lineno">1492</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1493"></a><tt class="py-lineno">1493</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1494"></a><tt class="py-lineno">1494</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1495"></a><tt class="py-lineno">1495</tt> <tt class="py-line"> </tt>
+<a name="L1496"></a><tt class="py-lineno">1496</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1497"></a><tt class="py-lineno">1497</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1498"></a><tt class="py-lineno">1498</tt> <tt class="py-line"> <tt id="link-517" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-517', 'links', 'link-514');">links</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1499"></a><tt class="py-lineno">1499</tt> <tt class="py-line"> <tt id="link-518" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#clusters"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-518', 'clusters', 'link-518');">clusters</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1500"></a><tt class="py-lineno">1500</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1501"></a><tt class="py-lineno">1501</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1502"></a><tt class="py-lineno">1502</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-519" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-519', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-520" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-520', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1503"></a><tt class="py-lineno">1503</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"clusters-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1504"></a><tt class="py-lineno">1504</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1505"></a><tt class="py-lineno">1505</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1506"></a><tt class="py-lineno">1506</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1507"></a><tt class="py-lineno">1507</tt> <tt class="py-line"> </tt>
+<a name="L1508"></a><tt class="py-lineno">1508</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1509"></a><tt class="py-lineno">1509</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1510"></a><tt class="py-lineno">1510</tt> <tt class="py-line"> <tt id="link-521" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-521', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1511"></a><tt class="py-lineno">1511</tt> <tt class="py-line"> <tt class="py-comment"># Compare json objects for hosts and dataplane clusters</tt> </tt>
+<a name="L1512"></a><tt class="py-lineno">1512</tt> <tt class="py-line"> </tt>
+<a name="L1513"></a><tt class="py-lineno">1513</tt> <tt class="py-line"> <tt class="py-comment"># hosts</tt> </tt>
+<a name="L1514"></a><tt class="py-lineno">1514</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-522" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-522', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Host view is consistent across ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1515"></a><tt class="py-lineno">1515</tt> <tt class="py-line"> <tt class="py-name">consistentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1516"></a><tt class="py-lineno">1516</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-523" class="py-name" targets="Package TestON.drivers.common.api.controller=TestON.drivers.common.api.controller-module.html"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-523', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt id="link-524" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-524', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1517"></a><tt class="py-lineno">1517</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-525" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-525', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1518"></a><tt class="py-lineno">1518</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-526" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-526', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-527" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-527', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1519"></a><tt class="py-lineno">1519</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-528" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-528', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-529" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-529', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt id="link-530" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-530', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1520"></a><tt class="py-lineno">1520</tt> <tt class="py-line"> <tt class="py-keyword">continue</tt> </tt>
+<a name="L1521"></a><tt class="py-lineno">1521</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-comment"># hosts not consistent</tt> </tt>
+<a name="L1522"></a><tt class="py-lineno">1522</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-531" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-531', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-532" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-532', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"hosts from ONOS"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1523"></a><tt class="py-lineno">1523</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1524"></a><tt class="py-lineno">1524</tt> <tt class="py-line"> <tt class="py-string">" is inconsistent with ONOS1"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1525"></a><tt class="py-lineno">1525</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-533" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-533', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-534" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-534', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-535" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-535', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1526"></a><tt class="py-lineno">1526</tt> <tt class="py-line"> <tt class="py-name">consistentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1527"></a><tt class="py-lineno">1527</tt> <tt class="py-line"> </tt>
+<a name="L1528"></a><tt class="py-lineno">1528</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1529"></a><tt class="py-lineno">1529</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-536" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-536', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-537" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-537', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS hosts from ONOS"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1530"></a><tt class="py-lineno">1530</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1531"></a><tt class="py-lineno">1531</tt> <tt class="py-line"> <tt class="py-name">consistentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1532"></a><tt class="py-lineno">1532</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-538" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-538', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1533"></a><tt class="py-lineno">1533</tt> <tt class="py-line"> <tt class="py-string">" hosts response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1534"></a><tt class="py-lineno">1534</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-539" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-539', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-540" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-540', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1535"></a><tt class="py-lineno">1535</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1536"></a><tt class="py-lineno">1536</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1537"></a><tt class="py-lineno">1537</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentHostsResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1538"></a><tt class="py-lineno">1538</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Hosts view is consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1539"></a><tt class="py-lineno">1539</tt> <tt class="py-line"> <tt id="link-541" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-541', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of hosts"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1540"></a><tt class="py-lineno">1540</tt> <tt class="py-line"> </tt>
+<a name="L1541"></a><tt class="py-lineno">1541</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-542" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-542', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Each host has an IP address"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1542"></a><tt class="py-lineno">1542</tt> <tt class="py-line"> <tt class="py-name">ipResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1543"></a><tt class="py-lineno">1543</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-543" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-543', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt id="link-544" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-544', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1544"></a><tt class="py-lineno">1544</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-545" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-545', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1545"></a><tt class="py-lineno">1545</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">host</tt> <tt class="py-keyword">in</tt> <tt id="link-546" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-546', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-547" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-547', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1546"></a><tt class="py-lineno">1546</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'ipAddresses'</tt><tt class="py-op">,</tt> <tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1547"></a><tt class="py-lineno">1547</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-548" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-548', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-549" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-549', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"DEBUG:Error with host ips on controller"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1548"></a><tt class="py-lineno">1548</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">host</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1549"></a><tt class="py-lineno">1549</tt> <tt class="py-line"> <tt class="py-name">ipResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1550"></a><tt class="py-lineno">1550</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1551"></a><tt class="py-lineno">1551</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1552"></a><tt class="py-lineno">1552</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">ipResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1553"></a><tt class="py-lineno">1553</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"The ips of the hosts aren't empty"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1554"></a><tt class="py-lineno">1554</tt> <tt class="py-line"> <tt id="link-550" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-550', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"The ip of at least one host is missing"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1555"></a><tt class="py-lineno">1555</tt> <tt class="py-line"> </tt>
+<a name="L1556"></a><tt class="py-lineno">1556</tt> <tt class="py-line"> <tt class="py-comment"># Strongly connected clusters of devices</tt> </tt>
+<a name="L1557"></a><tt class="py-lineno">1557</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-551" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-551', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cluster view is consistent across ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1558"></a><tt class="py-lineno">1558</tt> <tt class="py-line"> <tt class="py-name">consistentClustersResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1559"></a><tt class="py-lineno">1559</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-552" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-552', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt id="link-553" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-553', 'clusters', 'link-518');">clusters</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1560"></a><tt class="py-lineno">1560</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-554" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-554', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1561"></a><tt class="py-lineno">1561</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-555" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-555', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt id="link-556" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-556', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1562"></a><tt class="py-lineno">1562</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-557" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-557', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt id="link-558" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-558', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt id="link-559" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-559', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1563"></a><tt class="py-lineno">1563</tt> <tt class="py-line"> <tt class="py-keyword">continue</tt> </tt>
+<a name="L1564"></a><tt class="py-lineno">1564</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-comment"># clusters not consistent</tt> </tt>
+<a name="L1565"></a><tt class="py-lineno">1565</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-560" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-560', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-561" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-561', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"clusters from ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1566"></a><tt class="py-lineno">1566</tt> <tt class="py-line"> <tt class="py-string">" is inconsistent with ONOS1"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1567"></a><tt class="py-lineno">1567</tt> <tt class="py-line"> <tt class="py-name">consistentClustersResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1568"></a><tt class="py-lineno">1568</tt> <tt class="py-line"> </tt>
+<a name="L1569"></a><tt class="py-lineno">1569</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1570"></a><tt class="py-lineno">1570</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-562" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-562', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-563" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-563', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting dataplane clusters "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1571"></a><tt class="py-lineno">1571</tt> <tt class="py-line"> <tt class="py-string">"from ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1572"></a><tt class="py-lineno">1572</tt> <tt class="py-line"> <tt class="py-name">consistentClustersResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1573"></a><tt class="py-lineno">1573</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-564" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-564', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1574"></a><tt class="py-lineno">1574</tt> <tt class="py-line"> <tt class="py-string">" clusters response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1575"></a><tt class="py-lineno">1575</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-565" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-565', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt id="link-566" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-566', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1576"></a><tt class="py-lineno">1576</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1577"></a><tt class="py-lineno">1577</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1578"></a><tt class="py-lineno">1578</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentClustersResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1579"></a><tt class="py-lineno">1579</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Clusters view is consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1580"></a><tt class="py-lineno">1580</tt> <tt class="py-line"> <tt id="link-567" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-567', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of clusters"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1581"></a><tt class="py-lineno">1581</tt> <tt class="py-line"> <tt class="py-comment"># there should always only be one cluster</tt> </tt>
+<a name="L1582"></a><tt class="py-lineno">1582</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-568" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-568', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cluster view correct across ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1583"></a><tt class="py-lineno">1583</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1584"></a><tt class="py-lineno">1584</tt> <tt class="py-line"> <tt class="py-name">numClusters</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-569" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-569', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1585"></a><tt class="py-lineno">1585</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1586"></a><tt class="py-lineno">1586</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-570" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-570', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing clusters[0]: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1587"></a><tt class="py-lineno">1587</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-571" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-571', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1588"></a><tt class="py-lineno">1588</tt> <tt class="py-line"> <tt class="py-name">clusterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1589"></a><tt class="py-lineno">1589</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">numClusters</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L1590"></a><tt class="py-lineno">1590</tt> <tt class="py-line"> <tt class="py-name">clusterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1591"></a><tt class="py-lineno">1591</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1592"></a><tt class="py-lineno">1592</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-number">1</tt><tt class="py-op">,</tt> </tt>
+<a name="L1593"></a><tt class="py-lineno">1593</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">numClusters</tt><tt class="py-op">,</tt> </tt>
+<a name="L1594"></a><tt class="py-lineno">1594</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS shows 1 SCC"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1595"></a><tt class="py-lineno">1595</tt> <tt class="py-line"> <tt id="link-572" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-572', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS shows "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">numClusters</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" SCCs"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1596"></a><tt class="py-lineno">1596</tt> <tt class="py-line"> </tt>
+<a name="L1597"></a><tt class="py-lineno">1597</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-573" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-573', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Comparing ONOS topology to MN"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1598"></a><tt class="py-lineno">1598</tt> <tt class="py-line"> <tt class="py-name">devicesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1599"></a><tt class="py-lineno">1599</tt> <tt class="py-line"> <tt class="py-name">linksResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1600"></a><tt class="py-lineno">1600</tt> <tt class="py-line"> <tt class="py-name">hostsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1601"></a><tt class="py-lineno">1601</tt> <tt class="py-line"> <tt class="py-name">mnSwitches</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-574" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwitches()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getSwitches"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwitches" class="py-name" href="#" onclick="return doclink('link-574', 'getSwitches', 'link-574');">getSwitches</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1602"></a><tt class="py-lineno">1602</tt> <tt class="py-line"> <tt class="py-name">mnLinks</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-575" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getLinks()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getLinks"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getLinks" class="py-name" href="#" onclick="return doclink('link-575', 'getLinks', 'link-575');">getLinks</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1603"></a><tt class="py-lineno">1603</tt> <tt class="py-line"> <tt class="py-name">mnHosts</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-576" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getHosts()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getHosts"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getHosts" class="py-name" href="#" onclick="return doclink('link-576', 'getHosts', 'link-576');">getHosts</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1604"></a><tt class="py-lineno">1604</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-577" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-577', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1605"></a><tt class="py-lineno">1605</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-578" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-578', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1606"></a><tt class="py-lineno">1606</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-579" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-579', 'devices', 'link-114');">devices</a></tt><tt class="py-op">[</tt> <tt id="link-580" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-580', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt> <tt id="link-581" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-581', 'ports', 'link-510');">ports</a></tt><tt class="py-op">[</tt> <tt id="link-582" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-582', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L1607"></a><tt class="py-lineno">1607</tt> <tt class="py-line"> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-583" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-583', 'devices', 'link-114');">devices</a></tt><tt class="py-op">[</tt> <tt id="link-584" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-584', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L1608"></a><tt class="py-lineno">1608</tt> <tt class="py-line"> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-585" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-585', 'ports', 'link-510');">ports</a></tt><tt class="py-op">[</tt> <tt id="link-586" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-586', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1609"></a><tt class="py-lineno">1609</tt> <tt class="py-line"> </tt>
+<a name="L1610"></a><tt class="py-lineno">1610</tt> <tt class="py-line"> <tt class="py-name">currentDevicesResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-587" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareSwitches()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#compareSwitches"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareSwitches" class="py-name" href="#" onclick="return doclink('link-587', 'compareSwitches', 'link-587');">compareSwitches</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1611"></a><tt class="py-lineno">1611</tt> <tt class="py-line"> <tt class="py-name">mnSwitches</tt><tt class="py-op">,</tt> </tt>
+<a name="L1612"></a><tt class="py-lineno">1612</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-588" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-588', 'devices', 'link-114');">devices</a></tt><tt class="py-op">[</tt> <tt id="link-589" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-589', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1613"></a><tt class="py-lineno">1613</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-590" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-590', 'ports', 'link-510');">ports</a></tt><tt class="py-op">[</tt> <tt id="link-591" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-591', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1614"></a><tt class="py-lineno">1614</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1615"></a><tt class="py-lineno">1615</tt> <tt class="py-line"> <tt class="py-name">currentDevicesResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1616"></a><tt class="py-lineno">1616</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1617"></a><tt class="py-lineno">1617</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">currentDevicesResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1618"></a><tt class="py-lineno">1618</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1619"></a><tt class="py-lineno">1619</tt> <tt class="py-line"> <tt class="py-string">" Switches view is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1620"></a><tt class="py-lineno">1620</tt> <tt class="py-line"> <tt id="link-592" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-592', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1621"></a><tt class="py-lineno">1621</tt> <tt class="py-line"> <tt class="py-string">" Switches view is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1622"></a><tt class="py-lineno">1622</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-593" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-593', 'links', 'link-514');">links</a></tt><tt class="py-op">[</tt> <tt id="link-594" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-594', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-595" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-595', 'links', 'link-514');">links</a></tt><tt class="py-op">[</tt> <tt id="link-596" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-596', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1623"></a><tt class="py-lineno">1623</tt> <tt class="py-line"> <tt class="py-name">currentLinksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-597" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareLinks()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#compareLinks"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareLinks" class="py-name" href="#" onclick="return doclink('link-597', 'compareLinks', 'link-597');">compareLinks</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1624"></a><tt class="py-lineno">1624</tt> <tt class="py-line"> <tt class="py-name">mnSwitches</tt><tt class="py-op">,</tt> <tt class="py-name">mnLinks</tt><tt class="py-op">,</tt> </tt>
+<a name="L1625"></a><tt class="py-lineno">1625</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-598" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-598', 'links', 'link-514');">links</a></tt><tt class="py-op">[</tt> <tt id="link-599" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-599', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1626"></a><tt class="py-lineno">1626</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1627"></a><tt class="py-lineno">1627</tt> <tt class="py-line"> <tt class="py-name">currentLinksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1628"></a><tt class="py-lineno">1628</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1629"></a><tt class="py-lineno">1629</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">currentLinksResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1630"></a><tt class="py-lineno">1630</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1631"></a><tt class="py-lineno">1631</tt> <tt class="py-line"> <tt class="py-string">" links view is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1632"></a><tt class="py-lineno">1632</tt> <tt class="py-line"> <tt id="link-600" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-600', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1633"></a><tt class="py-lineno">1633</tt> <tt class="py-line"> <tt class="py-string">" links view is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1634"></a><tt class="py-lineno">1634</tt> <tt class="py-line"> </tt>
+<a name="L1635"></a><tt class="py-lineno">1635</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-601" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-601', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-602" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-602', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-603" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-603', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-604" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-604', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1636"></a><tt class="py-lineno">1636</tt> <tt class="py-line"> <tt class="py-name">currentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-605" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareHosts()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#compareHosts"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareHosts" class="py-name" href="#" onclick="return doclink('link-605', 'compareHosts', 'link-605');">compareHosts</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1637"></a><tt class="py-lineno">1637</tt> <tt class="py-line"> <tt class="py-name">mnHosts</tt><tt class="py-op">,</tt> </tt>
+<a name="L1638"></a><tt class="py-lineno">1638</tt> <tt class="py-line"> <tt id="link-606" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-606', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-607" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-607', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1639"></a><tt class="py-lineno">1639</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1640"></a><tt class="py-lineno">1640</tt> <tt class="py-line"> <tt class="py-name">currentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1641"></a><tt class="py-lineno">1641</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1642"></a><tt class="py-lineno">1642</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">currentHostsResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L1643"></a><tt class="py-lineno">1643</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1644"></a><tt class="py-lineno">1644</tt> <tt class="py-line"> <tt class="py-string">" hosts exist in Mininet"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1645"></a><tt class="py-lineno">1645</tt> <tt class="py-line"> <tt id="link-608" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-608', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1646"></a><tt class="py-lineno">1646</tt> <tt class="py-line"> <tt class="py-string">" hosts don't match Mininet"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1647"></a><tt class="py-lineno">1647</tt> <tt class="py-line"> </tt>
+<a name="L1648"></a><tt class="py-lineno">1648</tt> <tt class="py-line"> <tt class="py-name">devicesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">devicesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentDevicesResult</tt> </tt>
+<a name="L1649"></a><tt class="py-lineno">1649</tt> <tt class="py-line"> <tt class="py-name">linksResults</tt> <tt class="py-op">=</tt> <tt class="py-name">linksResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentLinksResult</tt> </tt>
+<a name="L1650"></a><tt class="py-lineno">1650</tt> <tt class="py-line"> <tt class="py-name">hostsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">hostsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentHostsResult</tt> </tt>
+<a name="L1651"></a><tt class="py-lineno">1651</tt> <tt class="py-line"> </tt>
+<a name="L1652"></a><tt class="py-lineno">1652</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-609" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-609', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Device information is correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1653"></a><tt class="py-lineno">1653</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1654"></a><tt class="py-lineno">1654</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1655"></a><tt class="py-lineno">1655</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">devicesResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1656"></a><tt class="py-lineno">1656</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Device information is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1657"></a><tt class="py-lineno">1657</tt> <tt class="py-line"> <tt id="link-610" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-610', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Device information is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1658"></a><tt class="py-lineno">1658</tt> <tt class="py-line"> </tt>
+<a name="L1659"></a><tt class="py-lineno">1659</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-611" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-611', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Links are correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1660"></a><tt class="py-lineno">1660</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1661"></a><tt class="py-lineno">1661</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1662"></a><tt class="py-lineno">1662</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linksResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1663"></a><tt class="py-lineno">1663</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1664"></a><tt class="py-lineno">1664</tt> <tt class="py-line"> <tt id="link-612" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-612', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Links are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1665"></a><tt class="py-lineno">1665</tt> <tt class="py-line"> </tt>
+<a name="L1666"></a><tt class="py-lineno">1666</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-613" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-613', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Hosts are correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1667"></a><tt class="py-lineno">1667</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1668"></a><tt class="py-lineno">1668</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1669"></a><tt class="py-lineno">1669</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">hostsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1670"></a><tt class="py-lineno">1670</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Hosts are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1671"></a><tt class="py-lineno">1671</tt> <tt class="py-line"> <tt id="link-614" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-614', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Hosts are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L1672"></a><tt class="py-lineno">1672</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE6"></a><div id="HAsanity.CASE6-def"><a name="L1673"></a><tt class="py-lineno">1673</tt> <a class="py-toggle" href="#" id="HAsanity.CASE6-toggle" onclick="return toggle('HAsanity.CASE6');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE6">CASE6</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE6-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE6-expanded"><a name="L1674"></a><tt class="py-lineno">1674</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L1675"></a><tt class="py-lineno">1675</tt> <tt class="py-line"><tt class="py-docstring"> The Failure case. Since this is the Sanity test, we do nothing.</tt> </tt>
+<a name="L1676"></a><tt class="py-lineno">1676</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L1677"></a><tt class="py-lineno">1677</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L1678"></a><tt class="py-lineno">1678</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L1679"></a><tt class="py-lineno">1679</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L1680"></a><tt class="py-lineno">1680</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L1681"></a><tt class="py-lineno">1681</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L1682"></a><tt class="py-lineno">1682</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-615" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-615', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L1683"></a><tt class="py-lineno">1683</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-616" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-616', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Wait 60 seconds instead of inducing a failure"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1684"></a><tt class="py-lineno">1684</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1685"></a><tt class="py-lineno">1685</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1686"></a><tt class="py-lineno">1686</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1687"></a><tt class="py-lineno">1687</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1688"></a><tt class="py-lineno">1688</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Sleeping 60 seconds"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1689"></a><tt class="py-lineno">1689</tt> <tt class="py-line"> <tt id="link-617" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-617', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something is terribly wrong with my math"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L1690"></a><tt class="py-lineno">1690</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE7"></a><div id="HAsanity.CASE7-def"><a name="L1691"></a><tt class="py-lineno">1691</tt> <a class="py-toggle" href="#" id="HAsanity.CASE7-toggle" onclick="return toggle('HAsanity.CASE7');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE7">CASE7</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE7-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE7-expanded"><a name="L1692"></a><tt class="py-lineno">1692</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L1693"></a><tt class="py-lineno">1693</tt> <tt class="py-line"><tt class="py-docstring"> Check state after ONOS failure</tt> </tt>
+<a name="L1694"></a><tt class="py-lineno">1694</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L1695"></a><tt class="py-lineno">1695</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt>
+<a name="L1696"></a><tt class="py-lineno">1696</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L1697"></a><tt class="py-lineno">1697</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L1698"></a><tt class="py-lineno">1698</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L1699"></a><tt class="py-lineno">1699</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L1700"></a><tt class="py-lineno">1700</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-618" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-618', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L1701"></a><tt class="py-lineno">1701</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-619" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-619', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Running ONOS Constant State Tests"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1702"></a><tt class="py-lineno">1702</tt> <tt class="py-line"> </tt>
+<a name="L1703"></a><tt class="py-lineno">1703</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-620" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-620', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check that each switch has a master"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1704"></a><tt class="py-lineno">1704</tt> <tt class="py-line"> <tt class="py-comment"># Assert that each device has a master</tt> </tt>
+<a name="L1705"></a><tt class="py-lineno">1705</tt> <tt class="py-line"> <tt id="link-621" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-621', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1706"></a><tt class="py-lineno">1706</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1707"></a><tt class="py-lineno">1707</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1708"></a><tt class="py-lineno">1708</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-622" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-622', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-623" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-623', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1709"></a><tt class="py-lineno">1709</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"rolesNotNull-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1710"></a><tt class="py-lineno">1710</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1711"></a><tt class="py-lineno">1711</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1712"></a><tt class="py-lineno">1712</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1713"></a><tt class="py-lineno">1713</tt> <tt class="py-line"> </tt>
+<a name="L1714"></a><tt class="py-lineno">1714</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1715"></a><tt class="py-lineno">1715</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1716"></a><tt class="py-lineno">1716</tt> <tt class="py-line"> <tt id="link-624" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-624', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt> <tt class="py-op">=</tt> <tt id="link-625" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-625', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
+<a name="L1717"></a><tt class="py-lineno">1717</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1718"></a><tt class="py-lineno">1718</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1719"></a><tt class="py-lineno">1719</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt id="link-626" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.rolesNotNull" class="py-name" href="#" onclick="return doclink('link-626', 'rolesNotNull', 'link-420');">rolesNotNull</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1720"></a><tt class="py-lineno">1720</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Each device has a master"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1721"></a><tt class="py-lineno">1721</tt> <tt class="py-line"> <tt id="link-627" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-627', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Some devices don't have a master assigned"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1722"></a><tt class="py-lineno">1722</tt> <tt class="py-line"> </tt>
+<a name="L1723"></a><tt class="py-lineno">1723</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-628" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-628', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Read device roles from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1724"></a><tt class="py-lineno">1724</tt> <tt class="py-line"> <tt class="py-name">ONOSMastership</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1725"></a><tt class="py-lineno">1725</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1726"></a><tt class="py-lineno">1726</tt> <tt class="py-line"> <tt class="py-name">consistentMastership</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1727"></a><tt class="py-lineno">1727</tt> <tt class="py-line"> <tt class="py-name">rolesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1728"></a><tt class="py-lineno">1728</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1729"></a><tt class="py-lineno">1729</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1730"></a><tt class="py-lineno">1730</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-629" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-629', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-630" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.roles" class="py-name" href="#" onclick="return doclink('link-630', 'roles', 'link-429');">roles</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1731"></a><tt class="py-lineno">1731</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"roles-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1732"></a><tt class="py-lineno">1732</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1733"></a><tt class="py-lineno">1733</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1734"></a><tt class="py-lineno">1734</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1735"></a><tt class="py-lineno">1735</tt> <tt class="py-line"> </tt>
+<a name="L1736"></a><tt class="py-lineno">1736</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1737"></a><tt class="py-lineno">1737</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1738"></a><tt class="py-lineno">1738</tt> <tt class="py-line"> <tt class="py-name">ONOSMastership</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1739"></a><tt class="py-lineno">1739</tt> <tt class="py-line"> </tt>
+<a name="L1740"></a><tt class="py-lineno">1740</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1741"></a><tt class="py-lineno">1741</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1742"></a><tt class="py-lineno">1742</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-631" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-631', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-632" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-632', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1743"></a><tt class="py-lineno">1743</tt> <tt class="py-line"> <tt class="py-string">" roles"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1744"></a><tt class="py-lineno">1744</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-633" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-633', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> </tt>
+<a name="L1745"></a><tt class="py-lineno">1745</tt> <tt class="py-line"> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" mastership response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1746"></a><tt class="py-lineno">1746</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1747"></a><tt class="py-lineno">1747</tt> <tt class="py-line"> <tt class="py-name">rolesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1748"></a><tt class="py-lineno">1748</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1749"></a><tt class="py-lineno">1749</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1750"></a><tt class="py-lineno">1750</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">rolesResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1751"></a><tt class="py-lineno">1751</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"No error in reading roles output"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1752"></a><tt class="py-lineno">1752</tt> <tt class="py-line"> <tt id="link-634" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-634', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error in reading roles from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1753"></a><tt class="py-lineno">1753</tt> <tt class="py-line"> </tt>
+<a name="L1754"></a><tt class="py-lineno">1754</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-635" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-635', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check for consistency in roles from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1755"></a><tt class="py-lineno">1755</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSMastership</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1756"></a><tt class="py-lineno">1756</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-636" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-636', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt>
+<a name="L1757"></a><tt class="py-lineno">1757</tt> <tt class="py-line"> <tt class="py-string">"Switch roles are consistent across all ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1758"></a><tt class="py-lineno">1758</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1759"></a><tt class="py-lineno">1759</tt> <tt class="py-line"> <tt class="py-name">consistentMastership</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1760"></a><tt class="py-lineno">1760</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1761"></a><tt class="py-lineno">1761</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1762"></a><tt class="py-lineno">1762</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentMastership</tt><tt class="py-op">,</tt> </tt>
+<a name="L1763"></a><tt class="py-lineno">1763</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Switch roles are consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1764"></a><tt class="py-lineno">1764</tt> <tt class="py-line"> <tt id="link-637" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-637', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of switch roles"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1765"></a><tt class="py-lineno">1765</tt> <tt class="py-line"> </tt>
+<a name="L1766"></a><tt class="py-lineno">1766</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">rolesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">consistentMastership</tt><tt class="py-op">:</tt> </tt>
+<a name="L1767"></a><tt class="py-lineno">1767</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1768"></a><tt class="py-lineno">1768</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-638" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-638', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> </tt>
+<a name="L1769"></a><tt class="py-lineno">1769</tt> <tt class="py-line"> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" roles: "</tt><tt class="py-op">,</tt> </tt>
+<a name="L1770"></a><tt class="py-lineno">1770</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> </tt>
+<a name="L1771"></a><tt class="py-lineno">1771</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1772"></a><tt class="py-lineno">1772</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1773"></a><tt class="py-lineno">1773</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1774"></a><tt class="py-lineno">1774</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1775"></a><tt class="py-lineno">1775</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">rolesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">consistentMastership</tt><tt class="py-op">:</tt> </tt>
+<a name="L1776"></a><tt class="py-lineno">1776</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1777"></a><tt class="py-lineno">1777</tt> <tt class="py-line"> </tt>
+<a name="L1778"></a><tt class="py-lineno">1778</tt> <tt class="py-line"> <tt class="py-name">description2</tt> <tt class="py-op">=</tt> <tt class="py-string">"Compare switch roles from before failure"</tt> </tt>
+<a name="L1779"></a><tt class="py-lineno">1779</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-639" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-639', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-name">description2</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1780"></a><tt class="py-lineno">1780</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1781"></a><tt class="py-lineno">1781</tt> <tt class="py-line"> <tt class="py-name">currentJson</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1782"></a><tt class="py-lineno">1782</tt> <tt class="py-line"> <tt class="py-name">oldJson</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">mastershipState</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1783"></a><tt class="py-lineno">1783</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1784"></a><tt class="py-lineno">1784</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-640" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-640', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Something is wrong with parsing "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1785"></a><tt class="py-lineno">1785</tt> <tt class="py-line"> <tt class="py-string">"ONOSMastership[0] or mastershipState"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1786"></a><tt class="py-lineno">1786</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-641" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-641', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-642" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-642', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOSMastership[0]: "</tt> <tt class="py-op">+</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSMastership</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1787"></a><tt class="py-lineno">1787</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-643" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-643', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-644" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-644', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"mastershipState"</tt> <tt class="py-op">+</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">mastershipState</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1788"></a><tt class="py-lineno">1788</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-645" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-645', 'cleanup', 'link-7');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1789"></a><tt class="py-lineno">1789</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-646" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-646', 'exit', 'link-8');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1790"></a><tt class="py-lineno">1790</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1791"></a><tt class="py-lineno">1791</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-number">29</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1792"></a><tt class="py-lineno">1792</tt> <tt class="py-line"> <tt class="py-name">switchDPID</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt>
+<a name="L1793"></a><tt class="py-lineno">1793</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-647" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwitchDPID()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#getSwitchDPID"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwitchDPID" class="py-name" href="#" onclick="return doclink('link-647', 'getSwitchDPID', 'link-647');">getSwitchDPID</a></tt><tt class="py-op">(</tt> <tt class="py-name">switch</tt><tt class="py-op">=</tt><tt class="py-string">"s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1794"></a><tt class="py-lineno">1794</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">switch</tt><tt class="py-op">[</tt> <tt class="py-string">'master'</tt> <tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">switch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">currentJson</tt> </tt>
+<a name="L1795"></a><tt class="py-lineno">1795</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switchDPID</tt> <tt class="py-keyword">in</tt> <tt class="py-name">switch</tt><tt class="py-op">[</tt> <tt class="py-string">'id'</tt> <tt class="py-op">]</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1796"></a><tt class="py-lineno">1796</tt> <tt class="py-line"> <tt class="py-name">old</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">switch</tt><tt class="py-op">[</tt> <tt class="py-string">'master'</tt> <tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">switch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">oldJson</tt> </tt>
+<a name="L1797"></a><tt class="py-lineno">1797</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switchDPID</tt> <tt class="py-keyword">in</tt> <tt class="py-name">switch</tt><tt class="py-op">[</tt> <tt class="py-string">'id'</tt> <tt class="py-op">]</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1798"></a><tt class="py-lineno">1798</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">current</tt> <tt class="py-op">==</tt> <tt class="py-name">old</tt><tt class="py-op">:</tt> </tt>
+<a name="L1799"></a><tt class="py-lineno">1799</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">mastershipCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1800"></a><tt class="py-lineno">1800</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1801"></a><tt class="py-lineno">1801</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-648" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-648', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Mastership of switch %s changed"</tt> <tt class="py-op">%</tt> <tt class="py-name">switchDPID</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1802"></a><tt class="py-lineno">1802</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1803"></a><tt class="py-lineno">1803</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1804"></a><tt class="py-lineno">1804</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1805"></a><tt class="py-lineno">1805</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">mastershipCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L1806"></a><tt class="py-lineno">1806</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Mastership of Switches was not changed"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1807"></a><tt class="py-lineno">1807</tt> <tt class="py-line"> <tt id="link-649" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-649', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Mastership of some switches changed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1808"></a><tt class="py-lineno">1808</tt> <tt class="py-line"> <tt class="py-name">mastershipCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">mastershipCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentMastership</tt> </tt>
+<a name="L1809"></a><tt class="py-lineno">1809</tt> <tt class="py-line"> </tt>
+<a name="L1810"></a><tt class="py-lineno">1810</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-650" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-650', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get the intents and compare across all nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1811"></a><tt class="py-lineno">1811</tt> <tt class="py-line"> <tt class="py-name">ONOSIntents</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1812"></a><tt class="py-lineno">1812</tt> <tt class="py-line"> <tt class="py-name">intentCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1813"></a><tt class="py-lineno">1813</tt> <tt class="py-line"> <tt class="py-name">consistentIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1814"></a><tt class="py-lineno">1814</tt> <tt class="py-line"> <tt class="py-name">intentsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L1815"></a><tt class="py-lineno">1815</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1816"></a><tt class="py-lineno">1816</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1817"></a><tt class="py-lineno">1817</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-651" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-651', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-652" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-652', 'intents', 'link-172');">intents</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L1818"></a><tt class="py-lineno">1818</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"intents-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1819"></a><tt class="py-lineno">1819</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1820"></a><tt class="py-lineno">1820</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">'jsonFormat'</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1821"></a><tt class="py-lineno">1821</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1822"></a><tt class="py-lineno">1822</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1823"></a><tt class="py-lineno">1823</tt> <tt class="py-line"> </tt>
+<a name="L1824"></a><tt class="py-lineno">1824</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L1825"></a><tt class="py-lineno">1825</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1826"></a><tt class="py-lineno">1826</tt> <tt class="py-line"> <tt class="py-name">ONOSIntents</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1827"></a><tt class="py-lineno">1827</tt> <tt class="py-line"> </tt>
+<a name="L1828"></a><tt class="py-lineno">1828</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1829"></a><tt class="py-lineno">1829</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1830"></a><tt class="py-lineno">1830</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-653" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-653', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-654" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-654', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1831"></a><tt class="py-lineno">1831</tt> <tt class="py-line"> <tt class="py-string">" intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1832"></a><tt class="py-lineno">1832</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-655" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-655', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1833"></a><tt class="py-lineno">1833</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1834"></a><tt class="py-lineno">1834</tt> <tt class="py-line"> <tt class="py-name">intentsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1835"></a><tt class="py-lineno">1835</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1836"></a><tt class="py-lineno">1836</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1837"></a><tt class="py-lineno">1837</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">intentsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L1838"></a><tt class="py-lineno">1838</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"No error in reading intents output"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1839"></a><tt class="py-lineno">1839</tt> <tt class="py-line"> <tt id="link-656" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-656', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error in reading intents from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1840"></a><tt class="py-lineno">1840</tt> <tt class="py-line"> </tt>
+<a name="L1841"></a><tt class="py-lineno">1841</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-657" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-657', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check for consistency in Intents from each controller"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1842"></a><tt class="py-lineno">1842</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt><tt class="py-op">[</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1843"></a><tt class="py-lineno">1843</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-658" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-658', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Intents are consistent across all ONOS "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1844"></a><tt class="py-lineno">1844</tt> <tt class="py-line"> <tt class="py-string">"nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1845"></a><tt class="py-lineno">1845</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L1846"></a><tt class="py-lineno">1846</tt> <tt class="py-line"> <tt class="py-name">consistentIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L1847"></a><tt class="py-lineno">1847</tt> <tt class="py-line"> </tt>
+<a name="L1848"></a><tt class="py-lineno">1848</tt> <tt class="py-line"> <tt class="py-comment"># Try to make it easy to figure out what is happening</tt> </tt>
+<a name="L1849"></a><tt class="py-lineno">1849</tt> <tt class="py-line"> <tt class="py-comment">#</tt> </tt>
+<a name="L1850"></a><tt class="py-lineno">1850</tt> <tt class="py-line"> <tt class="py-comment"># Intent ONOS1 ONOS2 ...</tt> </tt>
+<a name="L1851"></a><tt class="py-lineno">1851</tt> <tt class="py-line"> <tt class="py-comment"># 0x01 INSTALLED INSTALLING</tt> </tt>
+<a name="L1852"></a><tt class="py-lineno">1852</tt> <tt class="py-line"> <tt class="py-comment"># ... ... ...</tt> </tt>
+<a name="L1853"></a><tt class="py-lineno">1853</tt> <tt class="py-line"> <tt class="py-comment"># ... ... ...</tt> </tt>
+<a name="L1854"></a><tt class="py-lineno">1854</tt> <tt class="py-line"> <tt class="py-name">title</tt> <tt class="py-op">=</tt> <tt class="py-string">" ID"</tt> </tt>
+<a name="L1855"></a><tt class="py-lineno">1855</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">n</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1856"></a><tt class="py-lineno">1856</tt> <tt class="py-line"> <tt class="py-name">title</tt> <tt class="py-op">+=</tt> <tt class="py-string">" "</tt> <tt class="py-op">*</tt> <tt class="py-number">10</tt> <tt class="py-op">+</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">n</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1857"></a><tt class="py-lineno">1857</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-659" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-659', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">title</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1858"></a><tt class="py-lineno">1858</tt> <tt class="py-line"> <tt class="py-comment"># get all intent keys in the cluster</tt> </tt>
+<a name="L1859"></a><tt class="py-lineno">1859</tt> <tt class="py-line"> <tt class="py-name">keys</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1860"></a><tt class="py-lineno">1860</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">nodeStr</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1861"></a><tt class="py-lineno">1861</tt> <tt class="py-line"> <tt class="py-name">node</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1862"></a><tt class="py-lineno">1862</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-660" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-660', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">node</tt><tt class="py-op">:</tt> </tt>
+<a name="L1863"></a><tt class="py-lineno">1863</tt> <tt class="py-line"> <tt class="py-name">keys</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt id="link-661" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-661', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1864"></a><tt class="py-lineno">1864</tt> <tt class="py-line"> <tt class="py-name">keys</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">keys</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1865"></a><tt class="py-lineno">1865</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">keys</tt><tt class="py-op">:</tt> </tt>
+<a name="L1866"></a><tt class="py-lineno">1866</tt> <tt class="py-line"> <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-string">"%-13s"</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
+<a name="L1867"></a><tt class="py-lineno">1867</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">nodeStr</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1868"></a><tt class="py-lineno">1868</tt> <tt class="py-line"> <tt class="py-name">node</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1869"></a><tt class="py-lineno">1869</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-662" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-662', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">node</tt><tt class="py-op">:</tt> </tt>
+<a name="L1870"></a><tt class="py-lineno">1870</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-663" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-663', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'id'</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">key</tt><tt class="py-op">:</tt> </tt>
+<a name="L1871"></a><tt class="py-lineno">1871</tt> <tt class="py-line"> <tt class="py-name">row</tt> <tt class="py-op">+=</tt> <tt class="py-string">"%-15s"</tt> <tt class="py-op">%</tt> <tt id="link-664" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-664', 'intent', 'link-170');">intent</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'state'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1872"></a><tt class="py-lineno">1872</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-665" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-665', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">row</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1873"></a><tt class="py-lineno">1873</tt> <tt class="py-line"> <tt class="py-comment"># End table view</tt> </tt>
+<a name="L1874"></a><tt class="py-lineno">1874</tt> <tt class="py-line"> </tt>
+<a name="L1875"></a><tt class="py-lineno">1875</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1876"></a><tt class="py-lineno">1876</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1877"></a><tt class="py-lineno">1877</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentIntents</tt><tt class="py-op">,</tt> </tt>
+<a name="L1878"></a><tt class="py-lineno">1878</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intents are consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1879"></a><tt class="py-lineno">1879</tt> <tt class="py-line"> <tt id="link-666" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-666', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1880"></a><tt class="py-lineno">1880</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1881"></a><tt class="py-lineno">1881</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">:</tt> <tt class="py-comment"># Iter through ONOS nodes</tt> </tt>
+<a name="L1882"></a><tt class="py-lineno">1882</tt> <tt class="py-line"> <tt class="py-name">nodeStates</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1883"></a><tt class="py-lineno">1883</tt> <tt class="py-line"> <tt class="py-comment"># Iter through intents of a node</tt> </tt>
+<a name="L1884"></a><tt class="py-lineno">1884</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1885"></a><tt class="py-lineno">1885</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-667" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-667', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1886"></a><tt class="py-lineno">1886</tt> <tt class="py-line"> <tt class="py-name">nodeStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt id="link-668" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-668', 'intent', 'link-170');">intent</a></tt><tt class="py-op">[</tt> <tt class="py-string">'state'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1887"></a><tt class="py-lineno">1887</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1888"></a><tt class="py-lineno">1888</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-669" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-669', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error in parsing intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1889"></a><tt class="py-lineno">1889</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-670" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-670', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-671" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-671', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1890"></a><tt class="py-lineno">1890</tt> <tt class="py-line"> <tt class="py-name">intentStates</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStates</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1891"></a><tt class="py-lineno">1891</tt> <tt class="py-line"> <tt class="py-name">out</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">nodeStates</tt><tt class="py-op">.</tt><tt class="py-name">count</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">nodeStates</tt> <tt class="py-op">)</tt> <tt class="py-op">]</tt> </tt>
+<a name="L1892"></a><tt class="py-lineno">1892</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-672" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-672', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt> <tt class="py-name">out</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1893"></a><tt class="py-lineno">1893</tt> <tt class="py-line"> </tt>
+<a name="L1894"></a><tt class="py-lineno">1894</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">intentsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">consistentIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1895"></a><tt class="py-lineno">1895</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1896"></a><tt class="py-lineno">1896</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-673" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-673', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" intents: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1897"></a><tt class="py-lineno">1897</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-674" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-674', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> </tt>
+<a name="L1898"></a><tt class="py-lineno">1898</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1899"></a><tt class="py-lineno">1899</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L1900"></a><tt class="py-lineno">1900</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1901"></a><tt class="py-lineno">1901</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1902"></a><tt class="py-lineno">1902</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">intentsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentIntents</tt><tt class="py-op">:</tt> </tt>
+<a name="L1903"></a><tt class="py-lineno">1903</tt> <tt class="py-line"> <tt class="py-name">intentCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1904"></a><tt class="py-lineno">1904</tt> <tt class="py-line"> </tt>
+<a name="L1905"></a><tt class="py-lineno">1905</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: Store has no durability, so intents are lost across system</tt> </tt>
+<a name="L1906"></a><tt class="py-lineno">1906</tt> <tt class="py-line"> <tt class="py-comment"># restarts</tt> </tt>
+<a name="L1907"></a><tt class="py-lineno">1907</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-675" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-675', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Compare current intents with intents before the failure"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1908"></a><tt class="py-lineno">1908</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: this requires case 5 to pass for intentState to be set.</tt> </tt>
+<a name="L1909"></a><tt class="py-lineno">1909</tt> <tt class="py-line"> <tt class="py-comment"># maybe we should stop the test if that fails?</tt> </tt>
+<a name="L1910"></a><tt class="py-lineno">1910</tt> <tt class="py-line"> <tt class="py-name">sameIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1911"></a><tt class="py-lineno">1911</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">intentState</tt> <tt class="py-keyword">and</tt> <tt class="py-name">intentState</tt> <tt class="py-op">==</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L1912"></a><tt class="py-lineno">1912</tt> <tt class="py-line"> <tt class="py-name">sameIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1913"></a><tt class="py-lineno">1913</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-676" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-676', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Intents are consistent with before failure"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1914"></a><tt class="py-lineno">1914</tt> <tt class="py-line"> <tt class="py-comment"># TODO: possibly the states have changed? we may need to figure out</tt> </tt>
+<a name="L1915"></a><tt class="py-lineno">1915</tt> <tt class="py-line"> <tt class="py-comment"># what the acceptable states are</tt> </tt>
+<a name="L1916"></a><tt class="py-lineno">1916</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">intentState</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1917"></a><tt class="py-lineno">1917</tt> <tt class="py-line"> <tt class="py-name">sameIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1918"></a><tt class="py-lineno">1918</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1919"></a><tt class="py-lineno">1919</tt> <tt class="py-line"> <tt class="py-name">before</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">intentState</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1920"></a><tt class="py-lineno">1920</tt> <tt class="py-line"> <tt class="py-name">after</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1921"></a><tt class="py-lineno">1921</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-677" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-677', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">before</tt><tt class="py-op">:</tt> </tt>
+<a name="L1922"></a><tt class="py-lineno">1922</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-678" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-678', 'intent', 'link-170');">intent</a></tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">after</tt><tt class="py-op">:</tt> </tt>
+<a name="L1923"></a><tt class="py-lineno">1923</tt> <tt class="py-line"> <tt class="py-name">sameIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L1924"></a><tt class="py-lineno">1924</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-679" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-679', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Intent is not currently in ONOS "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1925"></a><tt class="py-lineno">1925</tt> <tt class="py-line"> <tt class="py-string">"(at least in the same form):"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1926"></a><tt class="py-lineno">1926</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-680" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-680', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt id="link-681" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intent" class="py-name" href="#" onclick="return doclink('link-681', 'intent', 'link-170');">intent</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1927"></a><tt class="py-lineno">1927</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1928"></a><tt class="py-lineno">1928</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-682" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-682', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Exception printing intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1929"></a><tt class="py-lineno">1929</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-683" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-683', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1930"></a><tt class="py-lineno">1930</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-684" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-684', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">intentState</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1931"></a><tt class="py-lineno">1931</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">sameIntents</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L1932"></a><tt class="py-lineno">1932</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L1933"></a><tt class="py-lineno">1933</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-685" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-685', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS intents before: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1934"></a><tt class="py-lineno">1934</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-686" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-686', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">intentState</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1935"></a><tt class="py-lineno">1935</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1936"></a><tt class="py-lineno">1936</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1937"></a><tt class="py-lineno">1937</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-687" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-687', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Current ONOS intents: "</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1938"></a><tt class="py-lineno">1938</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-688" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-688', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L1939"></a><tt class="py-lineno">1939</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L1940"></a><tt class="py-lineno">1940</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1941"></a><tt class="py-lineno">1941</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1942"></a><tt class="py-lineno">1942</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-689" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-689', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Exception printing intents"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1943"></a><tt class="py-lineno">1943</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-690" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-690', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIntents</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1944"></a><tt class="py-lineno">1944</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-691" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-691', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">intentState</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1945"></a><tt class="py-lineno">1945</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1946"></a><tt class="py-lineno">1946</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1947"></a><tt class="py-lineno">1947</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">sameIntents</tt><tt class="py-op">,</tt> </tt>
+<a name="L1948"></a><tt class="py-lineno">1948</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intents are consistent with before failure"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1949"></a><tt class="py-lineno">1949</tt> <tt class="py-line"> <tt id="link-692" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-692', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"The Intents changed during failure"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1950"></a><tt class="py-lineno">1950</tt> <tt class="py-line"> <tt class="py-name">intentCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">intentCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sameIntents</tt> </tt>
+<a name="L1951"></a><tt class="py-lineno">1951</tt> <tt class="py-line"> </tt>
+<a name="L1952"></a><tt class="py-lineno">1952</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-693" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-693', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get the OF Table entries and compare to before "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1953"></a><tt class="py-lineno">1953</tt> <tt class="py-line"> <tt class="py-string">"component failure"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1954"></a><tt class="py-lineno">1954</tt> <tt class="py-line"> <tt class="py-name">FlowTables</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L1955"></a><tt class="py-lineno">1955</tt> <tt class="py-line"> <tt class="py-name">flows2</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L1956"></a><tt class="py-lineno">1956</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">28</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L1957"></a><tt class="py-lineno">1957</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-694" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-694', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Checking flow table on s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1958"></a><tt class="py-lineno">1958</tt> <tt class="py-line"> <tt class="py-name">tmpFlows</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-695" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getFlowTable" class="py-name" href="#" onclick="return doclink('link-695', 'getFlowTable', 'link-485');">getFlowTable</a></tt><tt class="py-op">(</tt> <tt class="py-number">1.3</tt><tt class="py-op">,</tt> <tt class="py-string">"s"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1959"></a><tt class="py-lineno">1959</tt> <tt class="py-line"> <tt class="py-name">flows2</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">tmpFlows</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1960"></a><tt class="py-lineno">1960</tt> <tt class="py-line"> <tt class="py-name">tempResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-696" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.flowComp()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#flowComp"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.flowComp" class="py-name" href="#" onclick="return doclink('link-696', 'flowComp', 'link-696');">flowComp</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L1961"></a><tt class="py-lineno">1961</tt> <tt class="py-line"> <tt class="py-name">flow1</tt><tt class="py-op">=</tt><tt id="link-697" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.flows
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.flows" class="py-name" href="#" onclick="return doclink('link-697', 'flows', 'link-405');">flows</a></tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L1962"></a><tt class="py-lineno">1962</tt> <tt class="py-line"> <tt class="py-name">flow2</tt><tt class="py-op">=</tt><tt class="py-name">tmpFlows</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1963"></a><tt class="py-lineno">1963</tt> <tt class="py-line"> <tt class="py-name">FlowTables</tt> <tt class="py-op">=</tt> <tt class="py-name">FlowTables</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tempResult</tt> </tt>
+<a name="L1964"></a><tt class="py-lineno">1964</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">FlowTables</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L1965"></a><tt class="py-lineno">1965</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-698" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-698', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Differences in flow table for switch: s"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L1966"></a><tt class="py-lineno">1966</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1967"></a><tt class="py-lineno">1967</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L1968"></a><tt class="py-lineno">1968</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L1969"></a><tt class="py-lineno">1969</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">FlowTables</tt><tt class="py-op">,</tt> </tt>
+<a name="L1970"></a><tt class="py-lineno">1970</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"No changes were found in the flow tables"</tt><tt class="py-op">,</tt> </tt>
+<a name="L1971"></a><tt class="py-lineno">1971</tt> <tt class="py-line"> <tt id="link-699" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-699', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Changes were found in the flow tables"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L1972"></a><tt class="py-lineno">1972</tt> <tt class="py-line"> </tt>
+<a name="L1973"></a><tt class="py-lineno">1973</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-700" class="py-name" targets="Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLongKill()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#pingLongKill"><a title="TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.pingLongKill" class="py-name" href="#" onclick="return doclink('link-700', 'pingLongKill', 'link-700');">pingLongKill</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L1974"></a><tt class="py-lineno">1974</tt> <tt class="py-line"> <tt class="py-string">'''</tt> </tt>
+<a name="L1975"></a><tt class="py-lineno">1975</tt> <tt class="py-line"><tt class="py-string"> main.step( "Check the continuous pings to ensure that no packets " +</tt> </tt>
+<a name="L1976"></a><tt class="py-lineno">1976</tt> <tt class="py-line"><tt class="py-string"> "were dropped during component failure" )</tt> </tt>
+<a name="L1977"></a><tt class="py-lineno">1977</tt> <tt class="py-line"><tt class="py-string"> main.Mininet2.pingKill( main.params[ 'TESTONUSER' ],</tt> </tt>
+<a name="L1978"></a><tt class="py-lineno">1978</tt> <tt class="py-line"><tt class="py-string"> main.params[ 'TESTONIP' ] )</tt> </tt>
+<a name="L1979"></a><tt class="py-lineno">1979</tt> <tt class="py-line"><tt class="py-string"> LossInPings = main.FALSE</tt> </tt>
+<a name="L1980"></a><tt class="py-lineno">1980</tt> <tt class="py-line"><tt class="py-string"> # NOTE: checkForLoss returns main.FALSE with 0% packet loss</tt> </tt>
+<a name="L1981"></a><tt class="py-lineno">1981</tt> <tt class="py-line"><tt class="py-string"> for i in range( 8, 18 ):</tt> </tt>
+<a name="L1982"></a><tt class="py-lineno">1982</tt> <tt class="py-line"><tt class="py-string"> main.log.info(</tt> </tt>
+<a name="L1983"></a><tt class="py-lineno">1983</tt> <tt class="py-line"><tt class="py-string"> "Checking for a loss in pings along flow from s" +</tt> </tt>
+<a name="L1984"></a><tt class="py-lineno">1984</tt> <tt class="py-line"><tt class="py-string"> str( i ) )</tt> </tt>
+<a name="L1985"></a><tt class="py-lineno">1985</tt> <tt class="py-line"><tt class="py-string"> LossInPings = main.Mininet2.checkForLoss(</tt> </tt>
+<a name="L1986"></a><tt class="py-lineno">1986</tt> <tt class="py-line"><tt class="py-string"> "/tmp/ping.h" +</tt> </tt>
+<a name="L1987"></a><tt class="py-lineno">1987</tt> <tt class="py-line"><tt class="py-string"> str( i ) ) or LossInPings</tt> </tt>
+<a name="L1988"></a><tt class="py-lineno">1988</tt> <tt class="py-line"><tt class="py-string"> if LossInPings == main.TRUE:</tt> </tt>
+<a name="L1989"></a><tt class="py-lineno">1989</tt> <tt class="py-line"><tt class="py-string"> main.log.info( "Loss in ping detected" )</tt> </tt>
+<a name="L1990"></a><tt class="py-lineno">1990</tt> <tt class="py-line"><tt class="py-string"> elif LossInPings == main.ERROR:</tt> </tt>
+<a name="L1991"></a><tt class="py-lineno">1991</tt> <tt class="py-line"><tt class="py-string"> main.log.info( "There are multiple mininet process running" )</tt> </tt>
+<a name="L1992"></a><tt class="py-lineno">1992</tt> <tt class="py-line"><tt class="py-string"> elif LossInPings == main.FALSE:</tt> </tt>
+<a name="L1993"></a><tt class="py-lineno">1993</tt> <tt class="py-line"><tt class="py-string"> main.log.info( "No Loss in the pings" )</tt> </tt>
+<a name="L1994"></a><tt class="py-lineno">1994</tt> <tt class="py-line"><tt class="py-string"> main.log.info( "No loss of dataplane connectivity" )</tt> </tt>
+<a name="L1995"></a><tt class="py-lineno">1995</tt> <tt class="py-line"><tt class="py-string"> utilities.assert_equals(</tt> </tt>
+<a name="L1996"></a><tt class="py-lineno">1996</tt> <tt class="py-line"><tt class="py-string"> expect=main.FALSE,</tt> </tt>
+<a name="L1997"></a><tt class="py-lineno">1997</tt> <tt class="py-line"><tt class="py-string"> actual=LossInPings,</tt> </tt>
+<a name="L1998"></a><tt class="py-lineno">1998</tt> <tt class="py-line"><tt class="py-string"> onpass="No Loss of connectivity",</tt> </tt>
+<a name="L1999"></a><tt class="py-lineno">1999</tt> <tt class="py-line"><tt class="py-string"> onfail="Loss of dataplane connectivity detected" )</tt> </tt>
+<a name="L2000"></a><tt class="py-lineno">2000</tt> <tt class="py-line"><tt class="py-string"> '''</tt> </tt>
+<a name="L2001"></a><tt class="py-lineno">2001</tt> <tt class="py-line"> </tt>
+<a name="L2002"></a><tt class="py-lineno">2002</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-701" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-701', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Leadership Election is still functional"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2003"></a><tt class="py-lineno">2003</tt> <tt class="py-line"> <tt class="py-comment"># Test of LeadershipElection</tt> </tt>
+<a name="L2004"></a><tt class="py-lineno">2004</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: this only works for the sanity test. In case of failures,</tt> </tt>
+<a name="L2005"></a><tt class="py-lineno">2005</tt> <tt class="py-line"> <tt class="py-comment"># leader will likely change</tt> </tt>
+<a name="L2006"></a><tt class="py-lineno">2006</tt> <tt class="py-line"> <tt class="py-name">leader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-702" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-702', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> </tt>
+<a name="L2007"></a><tt class="py-lineno">2007</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2008"></a><tt class="py-lineno">2008</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-703" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-703', 'cli', 'link-223');">cli</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L2009"></a><tt class="py-lineno">2009</tt> <tt class="py-line"> <tt class="py-name">leaderN</tt> <tt class="py-op">=</tt> <tt id="link-704" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-704', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-705" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#electionTestLeader"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-705', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2010"></a><tt class="py-lineno">2010</tt> <tt class="py-line"> <tt class="py-comment"># verify leader is ONOS1</tt> </tt>
+<a name="L2011"></a><tt class="py-lineno">2011</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">==</tt> <tt class="py-name">leader</tt><tt class="py-op">:</tt> </tt>
+<a name="L2012"></a><tt class="py-lineno">2012</tt> <tt class="py-line"> <tt class="py-comment"># all is well</tt> </tt>
+<a name="L2013"></a><tt class="py-lineno">2013</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: In failure scenario, this could be a new node, maybe</tt> </tt>
+<a name="L2014"></a><tt class="py-lineno">2014</tt> <tt class="py-line"> <tt class="py-comment"># check != ONOS1</tt> </tt>
+<a name="L2015"></a><tt class="py-lineno">2015</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L2016"></a><tt class="py-lineno">2016</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L2017"></a><tt class="py-lineno">2017</tt> <tt class="py-line"> <tt class="py-comment"># error in response</tt> </tt>
+<a name="L2018"></a><tt class="py-lineno">2018</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-706" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-706', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-707" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-707', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Something is wrong with "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2019"></a><tt class="py-lineno">2019</tt> <tt class="py-line"> <tt class="py-string">"electionTestLeader function, check the"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2020"></a><tt class="py-lineno">2020</tt> <tt class="py-line"> <tt class="py-string">" error logs"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2021"></a><tt class="py-lineno">2021</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2022"></a><tt class="py-lineno">2022</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">leader</tt> <tt class="py-op">!=</tt> <tt class="py-name">leaderN</tt><tt class="py-op">:</tt> </tt>
+<a name="L2023"></a><tt class="py-lineno">2023</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2024"></a><tt class="py-lineno">2024</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-708" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-708', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-709" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-709', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt id="link-710" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-710', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">" sees "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2025"></a><tt class="py-lineno">2025</tt> <tt class="py-line"> <tt class="py-string">" as the leader of the election app. "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2026"></a><tt class="py-lineno">2026</tt> <tt class="py-line"> <tt class="py-string">"Leader should be "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leader</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2027"></a><tt class="py-lineno">2027</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2028"></a><tt class="py-lineno">2028</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2029"></a><tt class="py-lineno">2029</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">leaderResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2030"></a><tt class="py-lineno">2030</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Leadership election passed"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2031"></a><tt class="py-lineno">2031</tt> <tt class="py-line"> <tt id="link-711" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-711', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something went wrong with Leadership election"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2032"></a><tt class="py-lineno">2032</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE8"></a><div id="HAsanity.CASE8-def"><a name="L2033"></a><tt class="py-lineno">2033</tt> <a class="py-toggle" href="#" id="HAsanity.CASE8-toggle" onclick="return toggle('HAsanity.CASE8');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE8">CASE8</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE8-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE8-expanded"><a name="L2034"></a><tt class="py-lineno">2034</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2035"></a><tt class="py-lineno">2035</tt> <tt class="py-line"><tt class="py-docstring"> Compare topo</tt> </tt>
+<a name="L2036"></a><tt class="py-lineno">2036</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2037"></a><tt class="py-lineno">2037</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt>
+<a name="L2038"></a><tt class="py-lineno">2038</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2039"></a><tt class="py-lineno">2039</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2040"></a><tt class="py-lineno">2040</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2041"></a><tt class="py-lineno">2041</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2042"></a><tt class="py-lineno">2042</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2043"></a><tt class="py-lineno">2043</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-712" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-712', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2044"></a><tt class="py-lineno">2044</tt> <tt class="py-line"> </tt>
+<a name="L2045"></a><tt class="py-lineno">2045</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-713" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-713', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Compare ONOS Topology view to Mininet topology"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2046"></a><tt class="py-lineno">2046</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Compare topology objects between Mininet"</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L2047"></a><tt class="py-lineno">2047</tt> <tt class="py-line"> <tt class="py-string">" and ONOS"</tt> </tt>
+<a name="L2048"></a><tt class="py-lineno">2048</tt> <tt class="py-line"> </tt>
+<a name="L2049"></a><tt class="py-lineno">2049</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-714" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-714', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Comparing ONOS topology to MN"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2050"></a><tt class="py-lineno">2050</tt> <tt class="py-line"> <tt class="py-name">devicesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2051"></a><tt class="py-lineno">2051</tt> <tt class="py-line"> <tt class="py-name">linksResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2052"></a><tt class="py-lineno">2052</tt> <tt class="py-line"> <tt class="py-name">hostsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2053"></a><tt class="py-lineno">2053</tt> <tt class="py-line"> <tt class="py-name">hostAttachmentResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L2054"></a><tt class="py-lineno">2054</tt> <tt class="py-line"> <tt class="py-name">topoResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2055"></a><tt class="py-lineno">2055</tt> <tt class="py-line"> <tt class="py-name">elapsed</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L2056"></a><tt class="py-lineno">2056</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L2057"></a><tt class="py-lineno">2057</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-715" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-715', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collecting topology information from ONOS"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2058"></a><tt class="py-lineno">2058</tt> <tt class="py-line"> <tt class="py-name">startTime</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2059"></a><tt class="py-lineno">2059</tt> <tt class="py-line"> <tt class="py-comment"># Give time for Gossip to work</tt> </tt>
+<a name="L2060"></a><tt class="py-lineno">2060</tt> <tt class="py-line"> <tt class="py-keyword">while</tt> <tt class="py-name">topoResult</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> <tt class="py-keyword">and</tt> <tt class="py-name">elapsed</tt> <tt class="py-op"><</tt> <tt class="py-number">60</tt><tt class="py-op">:</tt> </tt>
+<a name="L2061"></a><tt class="py-lineno">2061</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L2062"></a><tt class="py-lineno">2062</tt> <tt class="py-line"> <tt class="py-name">cliStart</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2063"></a><tt class="py-lineno">2063</tt> <tt class="py-line"> <tt id="link-716" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-716', 'devices', 'link-114');">devices</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2064"></a><tt class="py-lineno">2064</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2065"></a><tt class="py-lineno">2065</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2066"></a><tt class="py-lineno">2066</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-717" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-717', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-718" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-718', 'devices', 'link-114');">devices</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2067"></a><tt class="py-lineno">2067</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"devices-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2068"></a><tt class="py-lineno">2068</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2069"></a><tt class="py-lineno">2069</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2070"></a><tt class="py-lineno">2070</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2071"></a><tt class="py-lineno">2071</tt> <tt class="py-line"> </tt>
+<a name="L2072"></a><tt class="py-lineno">2072</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2073"></a><tt class="py-lineno">2073</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2074"></a><tt class="py-lineno">2074</tt> <tt class="py-line"> <tt id="link-719" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-719', 'devices', 'link-114');">devices</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2075"></a><tt class="py-lineno">2075</tt> <tt class="py-line"> <tt id="link-720" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-720', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2076"></a><tt class="py-lineno">2076</tt> <tt class="py-line"> <tt class="py-name">ipResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2077"></a><tt class="py-lineno">2077</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2078"></a><tt class="py-lineno">2078</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2079"></a><tt class="py-lineno">2079</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-721" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-721', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-722" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-722', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2080"></a><tt class="py-lineno">2080</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"hosts-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2081"></a><tt class="py-lineno">2081</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2082"></a><tt class="py-lineno">2082</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2083"></a><tt class="py-lineno">2083</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2084"></a><tt class="py-lineno">2084</tt> <tt class="py-line"> </tt>
+<a name="L2085"></a><tt class="py-lineno">2085</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2086"></a><tt class="py-lineno">2086</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2087"></a><tt class="py-lineno">2087</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2088"></a><tt class="py-lineno">2088</tt> <tt class="py-line"> <tt id="link-723" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-723', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2089"></a><tt class="py-lineno">2089</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2090"></a><tt class="py-lineno">2090</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-724" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-724', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing hosts results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2091"></a><tt class="py-lineno">2091</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-725" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-725', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-726" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-726', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2092"></a><tt class="py-lineno">2092</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-727" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-727', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt id="link-728" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-728', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2093"></a><tt class="py-lineno">2093</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-729" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-729', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2094"></a><tt class="py-lineno">2094</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">host</tt> <tt class="py-keyword">in</tt> <tt id="link-730" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-730', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-731" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-731', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2095"></a><tt class="py-lineno">2095</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">host</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-name">host</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'ipAddresses'</tt><tt class="py-op">,</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2096"></a><tt class="py-lineno">2096</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-732" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-732', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-733" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-733', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2097"></a><tt class="py-lineno">2097</tt> <tt class="py-line"> <tt class="py-string">"DEBUG:Error with host ipAddresses on controller"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2098"></a><tt class="py-lineno">2098</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">host</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2099"></a><tt class="py-lineno">2099</tt> <tt class="py-line"> <tt class="py-name">ipResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2100"></a><tt class="py-lineno">2100</tt> <tt class="py-line"> <tt id="link-734" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-734', 'ports', 'link-510');">ports</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2101"></a><tt class="py-lineno">2101</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2102"></a><tt class="py-lineno">2102</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2103"></a><tt class="py-lineno">2103</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-735" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-735', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-736" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-736', 'ports', 'link-510');">ports</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2104"></a><tt class="py-lineno">2104</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"ports-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2105"></a><tt class="py-lineno">2105</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2106"></a><tt class="py-lineno">2106</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2107"></a><tt class="py-lineno">2107</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2108"></a><tt class="py-lineno">2108</tt> <tt class="py-line"> </tt>
+<a name="L2109"></a><tt class="py-lineno">2109</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2110"></a><tt class="py-lineno">2110</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2111"></a><tt class="py-lineno">2111</tt> <tt class="py-line"> <tt id="link-737" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-737', 'ports', 'link-510');">ports</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2112"></a><tt class="py-lineno">2112</tt> <tt class="py-line"> <tt id="link-738" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-738', 'links', 'link-514');">links</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2113"></a><tt class="py-lineno">2113</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2114"></a><tt class="py-lineno">2114</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2115"></a><tt class="py-lineno">2115</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-739" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-739', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-740" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-740', 'links', 'link-514');">links</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2116"></a><tt class="py-lineno">2116</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"links-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2117"></a><tt class="py-lineno">2117</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2118"></a><tt class="py-lineno">2118</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2119"></a><tt class="py-lineno">2119</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2120"></a><tt class="py-lineno">2120</tt> <tt class="py-line"> </tt>
+<a name="L2121"></a><tt class="py-lineno">2121</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2122"></a><tt class="py-lineno">2122</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2123"></a><tt class="py-lineno">2123</tt> <tt class="py-line"> <tt id="link-741" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-741', 'links', 'link-514');">links</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2124"></a><tt class="py-lineno">2124</tt> <tt class="py-line"> <tt id="link-742" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-742', 'clusters', 'link-518');">clusters</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2125"></a><tt class="py-lineno">2125</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2126"></a><tt class="py-lineno">2126</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2127"></a><tt class="py-lineno">2127</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-743" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-743', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-744" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-744', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2128"></a><tt class="py-lineno">2128</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"clusters-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2129"></a><tt class="py-lineno">2129</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2130"></a><tt class="py-lineno">2130</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2131"></a><tt class="py-lineno">2131</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2132"></a><tt class="py-lineno">2132</tt> <tt class="py-line"> </tt>
+<a name="L2133"></a><tt class="py-lineno">2133</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2134"></a><tt class="py-lineno">2134</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2135"></a><tt class="py-lineno">2135</tt> <tt class="py-line"> <tt id="link-745" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-745', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2136"></a><tt class="py-lineno">2136</tt> <tt class="py-line"> </tt>
+<a name="L2137"></a><tt class="py-lineno">2137</tt> <tt class="py-line"> <tt class="py-name">elapsed</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-name">startTime</tt> </tt>
+<a name="L2138"></a><tt class="py-lineno">2138</tt> <tt class="py-line"> <tt class="py-name">cliTime</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">time</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-name">cliStart</tt> </tt>
+<a name="L2139"></a><tt class="py-lineno">2139</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Elapsed time: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">elapsed</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2140"></a><tt class="py-lineno">2140</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"CLI time: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">cliTime</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2141"></a><tt class="py-lineno">2141</tt> <tt class="py-line"> </tt>
+<a name="L2142"></a><tt class="py-lineno">2142</tt> <tt class="py-line"> <tt class="py-name">mnSwitches</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-746" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwitches" class="py-name" href="#" onclick="return doclink('link-746', 'getSwitches', 'link-574');">getSwitches</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2143"></a><tt class="py-lineno">2143</tt> <tt class="py-line"> <tt class="py-name">mnLinks</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-747" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getLinks" class="py-name" href="#" onclick="return doclink('link-747', 'getLinks', 'link-575');">getLinks</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2144"></a><tt class="py-lineno">2144</tt> <tt class="py-line"> <tt class="py-name">mnHosts</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-748" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getHosts" class="py-name" href="#" onclick="return doclink('link-748', 'getHosts', 'link-576');">getHosts</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2145"></a><tt class="py-lineno">2145</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-749" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-749', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2146"></a><tt class="py-lineno">2146</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-750" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-750', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2147"></a><tt class="py-lineno">2147</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-751" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-751', 'devices', 'link-114');">devices</a></tt><tt class="py-op">[</tt> <tt id="link-752" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-752', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt> <tt id="link-753" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-753', 'ports', 'link-510');">ports</a></tt><tt class="py-op">[</tt> <tt id="link-754" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-754', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L2148"></a><tt class="py-lineno">2148</tt> <tt class="py-line"> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-755" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-755', 'devices', 'link-114');">devices</a></tt><tt class="py-op">[</tt> <tt id="link-756" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-756', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L2149"></a><tt class="py-lineno">2149</tt> <tt class="py-line"> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-757" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-757', 'ports', 'link-510');">ports</a></tt><tt class="py-op">[</tt> <tt id="link-758" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-758', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2150"></a><tt class="py-lineno">2150</tt> <tt class="py-line"> </tt>
+<a name="L2151"></a><tt class="py-lineno">2151</tt> <tt class="py-line"> <tt class="py-name">currentDevicesResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-759" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareSwitches" class="py-name" href="#" onclick="return doclink('link-759', 'compareSwitches', 'link-587');">compareSwitches</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2152"></a><tt class="py-lineno">2152</tt> <tt class="py-line"> <tt class="py-name">mnSwitches</tt><tt class="py-op">,</tt> </tt>
+<a name="L2153"></a><tt class="py-lineno">2153</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-760" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-760', 'devices', 'link-114');">devices</a></tt><tt class="py-op">[</tt> <tt id="link-761" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-761', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2154"></a><tt class="py-lineno">2154</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-762" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.ports" class="py-name" href="#" onclick="return doclink('link-762', 'ports', 'link-510');">ports</a></tt><tt class="py-op">[</tt> <tt id="link-763" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-763', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2155"></a><tt class="py-lineno">2155</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2156"></a><tt class="py-lineno">2156</tt> <tt class="py-line"> <tt class="py-name">currentDevicesResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2157"></a><tt class="py-lineno">2157</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2158"></a><tt class="py-lineno">2158</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">currentDevicesResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2159"></a><tt class="py-lineno">2159</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2160"></a><tt class="py-lineno">2160</tt> <tt class="py-line"> <tt class="py-string">" Switches view is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2161"></a><tt class="py-lineno">2161</tt> <tt class="py-line"> <tt id="link-764" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-764', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2162"></a><tt class="py-lineno">2162</tt> <tt class="py-line"> <tt class="py-string">" Switches view is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2163"></a><tt class="py-lineno">2163</tt> <tt class="py-line"> </tt>
+<a name="L2164"></a><tt class="py-lineno">2164</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-765" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-765', 'links', 'link-514');">links</a></tt><tt class="py-op">[</tt> <tt id="link-766" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-766', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">and</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-767" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-767', 'links', 'link-514');">links</a></tt><tt class="py-op">[</tt> <tt id="link-768" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-768', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2165"></a><tt class="py-lineno">2165</tt> <tt class="py-line"> <tt class="py-name">currentLinksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-769" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareLinks" class="py-name" href="#" onclick="return doclink('link-769', 'compareLinks', 'link-597');">compareLinks</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2166"></a><tt class="py-lineno">2166</tt> <tt class="py-line"> <tt class="py-name">mnSwitches</tt><tt class="py-op">,</tt> <tt class="py-name">mnLinks</tt><tt class="py-op">,</tt> </tt>
+<a name="L2167"></a><tt class="py-lineno">2167</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-770" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-770', 'links', 'link-514');">links</a></tt><tt class="py-op">[</tt> <tt id="link-771" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-771', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2168"></a><tt class="py-lineno">2168</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2169"></a><tt class="py-lineno">2169</tt> <tt class="py-line"> <tt class="py-name">currentLinksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2170"></a><tt class="py-lineno">2170</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2171"></a><tt class="py-lineno">2171</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">currentLinksResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2172"></a><tt class="py-lineno">2172</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2173"></a><tt class="py-lineno">2173</tt> <tt class="py-line"> <tt class="py-string">" links view is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2174"></a><tt class="py-lineno">2174</tt> <tt class="py-line"> <tt id="link-772" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-772', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2175"></a><tt class="py-lineno">2175</tt> <tt class="py-line"> <tt class="py-string">" links view is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2176"></a><tt class="py-lineno">2176</tt> <tt class="py-line"> </tt>
+<a name="L2177"></a><tt class="py-lineno">2177</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-773" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-773', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-774" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-774', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-775" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-775', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-776" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-776', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2178"></a><tt class="py-lineno">2178</tt> <tt class="py-line"> <tt class="py-name">currentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-777" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.compareHosts" class="py-name" href="#" onclick="return doclink('link-777', 'compareHosts', 'link-605');">compareHosts</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2179"></a><tt class="py-lineno">2179</tt> <tt class="py-line"> <tt class="py-name">mnHosts</tt><tt class="py-op">,</tt> </tt>
+<a name="L2180"></a><tt class="py-lineno">2180</tt> <tt class="py-line"> <tt id="link-778" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-778', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-779" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-779', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2181"></a><tt class="py-lineno">2181</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2182"></a><tt class="py-lineno">2182</tt> <tt class="py-line"> <tt class="py-name">currentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2183"></a><tt class="py-lineno">2183</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2184"></a><tt class="py-lineno">2184</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">currentHostsResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2185"></a><tt class="py-lineno">2185</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2186"></a><tt class="py-lineno">2186</tt> <tt class="py-line"> <tt class="py-string">" hosts exist in Mininet"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2187"></a><tt class="py-lineno">2187</tt> <tt class="py-line"> <tt id="link-780" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-780', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2188"></a><tt class="py-lineno">2188</tt> <tt class="py-line"> <tt class="py-string">" hosts don't match Mininet"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2189"></a><tt class="py-lineno">2189</tt> <tt class="py-line"> <tt class="py-comment"># CHECKING HOST ATTACHMENT POINTS</tt> </tt>
+<a name="L2190"></a><tt class="py-lineno">2190</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L2191"></a><tt class="py-lineno">2191</tt> <tt class="py-line"> <tt class="py-name">zeroHosts</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L2192"></a><tt class="py-lineno">2192</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: topo-HA/obelisk specific mappings:</tt> </tt>
+<a name="L2193"></a><tt class="py-lineno">2193</tt> <tt class="py-line"> <tt class="py-comment"># key is mac and value is dpid</tt> </tt>
+<a name="L2194"></a><tt class="py-lineno">2194</tt> <tt class="py-line"> <tt class="py-name">mappings</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
+<a name="L2195"></a><tt class="py-lineno">2195</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-number">29</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-comment"># hosts 1 through 28</tt> </tt>
+<a name="L2196"></a><tt class="py-lineno">2196</tt> <tt class="py-line"> <tt class="py-comment"># set up correct variables:</tt> </tt>
+<a name="L2197"></a><tt class="py-lineno">2197</tt> <tt class="py-line"> <tt class="py-name">macId</tt> <tt class="py-op">=</tt> <tt class="py-string">"00:"</tt> <tt class="py-op">*</tt> <tt class="py-number">5</tt> <tt class="py-op">+</tt> <tt class="py-name">hex</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt> <tt class="py-string">"0x"</tt> <tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">upper</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">2</tt><tt class="py-op">)</tt> </tt>
+<a name="L2198"></a><tt class="py-lineno">2198</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L2199"></a><tt class="py-lineno">2199</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"1000"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2200"></a><tt class="py-lineno">2200</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt>
+<a name="L2201"></a><tt class="py-lineno">2201</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"2000"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2202"></a><tt class="py-lineno">2202</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt>
+<a name="L2203"></a><tt class="py-lineno">2203</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"3000"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2204"></a><tt class="py-lineno">2204</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">4</tt><tt class="py-op">:</tt> </tt>
+<a name="L2205"></a><tt class="py-lineno">2205</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"3004"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2206"></a><tt class="py-lineno">2206</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">5</tt><tt class="py-op">:</tt> </tt>
+<a name="L2207"></a><tt class="py-lineno">2207</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"5000"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2208"></a><tt class="py-lineno">2208</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">6</tt><tt class="py-op">:</tt> </tt>
+<a name="L2209"></a><tt class="py-lineno">2209</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"6000"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2210"></a><tt class="py-lineno">2210</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">7</tt><tt class="py-op">:</tt> </tt>
+<a name="L2211"></a><tt class="py-lineno">2211</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"6007"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2212"></a><tt class="py-lineno">2212</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">>=</tt> <tt class="py-number">8</tt> <tt class="py-keyword">and</tt> <tt class="py-name">i</tt> <tt class="py-op"><=</tt> <tt class="py-number">17</tt><tt class="py-op">:</tt> </tt>
+<a name="L2213"></a><tt class="py-lineno">2213</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">'3'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt> <tt class="py-number">3</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2214"></a><tt class="py-lineno">2214</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">dpid</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2215"></a><tt class="py-lineno">2215</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">>=</tt> <tt class="py-number">18</tt> <tt class="py-keyword">and</tt> <tt class="py-name">i</tt> <tt class="py-op"><=</tt> <tt class="py-number">27</tt><tt class="py-op">:</tt> </tt>
+<a name="L2216"></a><tt class="py-lineno">2216</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">'6'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt> <tt class="py-number">3</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2217"></a><tt class="py-lineno">2217</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-name">dpid</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2218"></a><tt class="py-lineno">2218</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">28</tt><tt class="py-op">:</tt> </tt>
+<a name="L2219"></a><tt class="py-lineno">2219</tt> <tt class="py-line"> <tt class="py-name">deviceId</tt> <tt class="py-op">=</tt> <tt class="py-string">"2800"</tt><tt class="py-op">.</tt><tt class="py-name">zfill</tt><tt class="py-op">(</tt><tt class="py-number">16</tt><tt class="py-op">)</tt> </tt>
+<a name="L2220"></a><tt class="py-lineno">2220</tt> <tt class="py-line"> <tt class="py-name">mappings</tt><tt class="py-op">[</tt> <tt class="py-name">macId</tt> <tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceId</tt> </tt>
+<a name="L2221"></a><tt class="py-lineno">2221</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-781" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-781', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-782" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-782', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-783" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-783', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-784" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-784', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2222"></a><tt class="py-lineno">2222</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-785" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-785', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-786" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-786', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2223"></a><tt class="py-lineno">2223</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-787" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-787', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"There are no hosts discovered"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2224"></a><tt class="py-lineno">2224</tt> <tt class="py-line"> <tt class="py-name">zeroHosts</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L2225"></a><tt class="py-lineno">2225</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2226"></a><tt class="py-lineno">2226</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">host</tt> <tt class="py-keyword">in</tt> <tt id="link-788" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-788', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-789" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-789', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2227"></a><tt class="py-lineno">2227</tt> <tt class="py-line"> <tt class="py-name">mac</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L2228"></a><tt class="py-lineno">2228</tt> <tt class="py-line"> <tt id="link-790" class="py-name" targets="Variable TestON.bin.cli.location=TestON.bin.cli-module.html#location,Variable TestON.core.teston.location=TestON.core.teston-module.html#location"><a title="TestON.bin.cli.location
+TestON.core.teston.location" class="py-name" href="#" onclick="return doclink('link-790', 'location', 'link-790');">location</a></tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L2229"></a><tt class="py-lineno">2229</tt> <tt class="py-line"> <tt class="py-name">device</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L2230"></a><tt class="py-lineno">2230</tt> <tt class="py-line"> <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L2231"></a><tt class="py-lineno">2231</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2232"></a><tt class="py-lineno">2232</tt> <tt class="py-line"> <tt class="py-name">mac</tt> <tt class="py-op">=</tt> <tt class="py-name">host</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'mac'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2233"></a><tt class="py-lineno">2233</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">mac</tt><tt class="py-op">,</tt> <tt class="py-string">"mac field could not be found for this host object"</tt> </tt>
+<a name="L2234"></a><tt class="py-lineno">2234</tt> <tt class="py-line"> </tt>
+<a name="L2235"></a><tt class="py-lineno">2235</tt> <tt class="py-line"> <tt id="link-791" class="py-name"><a title="TestON.bin.cli.location
+TestON.core.teston.location" class="py-name" href="#" onclick="return doclink('link-791', 'location', 'link-790');">location</a></tt> <tt class="py-op">=</tt> <tt class="py-name">host</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'location'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2236"></a><tt class="py-lineno">2236</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt id="link-792" class="py-name"><a title="TestON.bin.cli.location
+TestON.core.teston.location" class="py-name" href="#" onclick="return doclink('link-792', 'location', 'link-790');">location</a></tt><tt class="py-op">,</tt> <tt class="py-string">"location field could not be found for this host object"</tt> </tt>
+<a name="L2237"></a><tt class="py-lineno">2237</tt> <tt class="py-line"> </tt>
+<a name="L2238"></a><tt class="py-lineno">2238</tt> <tt class="py-line"> <tt class="py-comment"># Trim the protocol identifier off deviceId</tt> </tt>
+<a name="L2239"></a><tt class="py-lineno">2239</tt> <tt class="py-line"> <tt class="py-name">device</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-793" class="py-name"><a title="TestON.bin.cli.location
+TestON.core.teston.location" class="py-name" href="#" onclick="return doclink('link-793', 'location', 'link-790');">location</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'elementId'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
+<a name="L2240"></a><tt class="py-lineno">2240</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">device</tt><tt class="py-op">,</tt> <tt class="py-string">"elementId field could not be found for this host location object"</tt> </tt>
+<a name="L2241"></a><tt class="py-lineno">2241</tt> <tt class="py-line"> </tt>
+<a name="L2242"></a><tt class="py-lineno">2242</tt> <tt class="py-line"> <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt id="link-794" class="py-name"><a title="TestON.bin.cli.location
+TestON.core.teston.location" class="py-name" href="#" onclick="return doclink('link-794', 'location', 'link-790');">location</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'port'</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2243"></a><tt class="py-lineno">2243</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">port</tt><tt class="py-op">,</tt> <tt class="py-string">"port field could not be found for this host location object"</tt> </tt>
+<a name="L2244"></a><tt class="py-lineno">2244</tt> <tt class="py-line"> </tt>
+<a name="L2245"></a><tt class="py-lineno">2245</tt> <tt class="py-line"> <tt class="py-comment"># Now check if this matches where they should be</tt> </tt>
+<a name="L2246"></a><tt class="py-lineno">2246</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">mac</tt> <tt class="py-keyword">and</tt> <tt class="py-name">device</tt> <tt class="py-keyword">and</tt> <tt class="py-name">port</tt><tt class="py-op">:</tt> </tt>
+<a name="L2247"></a><tt class="py-lineno">2247</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">port</tt> <tt class="py-op">)</tt> <tt class="py-op">!=</tt> <tt class="py-string">"1"</tt><tt class="py-op">:</tt> </tt>
+<a name="L2248"></a><tt class="py-lineno">2248</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-795" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-795', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-796" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-796', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"The attachment port is incorrect for "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2249"></a><tt class="py-lineno">2249</tt> <tt class="py-line"> <tt class="py-string">"host "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">mac</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2250"></a><tt class="py-lineno">2250</tt> <tt class="py-line"> <tt class="py-string">". Expected: 1 Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">port</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2251"></a><tt class="py-lineno">2251</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L2252"></a><tt class="py-lineno">2252</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">device</tt> <tt class="py-op">!=</tt> <tt class="py-name">mappings</tt><tt class="py-op">[</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">mac</tt> <tt class="py-op">)</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2253"></a><tt class="py-lineno">2253</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-797" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-797', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-798" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-798', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"The attachment device is incorrect for "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2254"></a><tt class="py-lineno">2254</tt> <tt class="py-line"> <tt class="py-string">"host "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">mac</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2255"></a><tt class="py-lineno">2255</tt> <tt class="py-line"> <tt class="py-string">". Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">mappings</tt><tt class="py-op">[</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">mac</tt> <tt class="py-op">)</tt> <tt class="py-op">]</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2256"></a><tt class="py-lineno">2256</tt> <tt class="py-line"> <tt class="py-string">" Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">device</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2257"></a><tt class="py-lineno">2257</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L2258"></a><tt class="py-lineno">2258</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2259"></a><tt class="py-lineno">2259</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L2260"></a><tt class="py-lineno">2260</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">AssertionError</tt><tt class="py-op">:</tt> </tt>
+<a name="L2261"></a><tt class="py-lineno">2261</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-799" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-799', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Json object not as expected"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2262"></a><tt class="py-lineno">2262</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-800" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-800', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-801" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-801', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">host</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2263"></a><tt class="py-lineno">2263</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
+<a name="L2264"></a><tt class="py-lineno">2264</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2265"></a><tt class="py-lineno">2265</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-802" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-802', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-803" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-803', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"No hosts json output or \"Error\""</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2266"></a><tt class="py-lineno">2266</tt> <tt class="py-line"> <tt class="py-string">" in output. hosts = "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2267"></a><tt class="py-lineno">2267</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-804" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-804', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-805" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-805', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2268"></a><tt class="py-lineno">2268</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">zeroHosts</tt> <tt class="py-keyword">is</tt> <tt class="py-name">False</tt><tt class="py-op">:</tt> </tt>
+<a name="L2269"></a><tt class="py-lineno">2269</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L2270"></a><tt class="py-lineno">2270</tt> <tt class="py-line"> </tt>
+<a name="L2271"></a><tt class="py-lineno">2271</tt> <tt class="py-line"> <tt class="py-comment"># END CHECKING HOST ATTACHMENT POINTS</tt> </tt>
+<a name="L2272"></a><tt class="py-lineno">2272</tt> <tt class="py-line"> <tt class="py-name">devicesResults</tt> <tt class="py-op">=</tt> <tt class="py-name">devicesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentDevicesResult</tt> </tt>
+<a name="L2273"></a><tt class="py-lineno">2273</tt> <tt class="py-line"> <tt class="py-name">linksResults</tt> <tt class="py-op">=</tt> <tt class="py-name">linksResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentLinksResult</tt> </tt>
+<a name="L2274"></a><tt class="py-lineno">2274</tt> <tt class="py-line"> <tt class="py-name">hostsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">hostsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentHostsResult</tt> </tt>
+<a name="L2275"></a><tt class="py-lineno">2275</tt> <tt class="py-line"> <tt class="py-name">hostAttachmentResults</tt> <tt class="py-op">=</tt> <tt class="py-name">hostAttachmentResults</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L2276"></a><tt class="py-lineno">2276</tt> <tt class="py-line"> <tt class="py-name">hostAttachment</tt> </tt>
+<a name="L2277"></a><tt class="py-lineno">2277</tt> <tt class="py-line"> <tt class="py-name">topoResult</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">devicesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">linksResults</tt> </tt>
+<a name="L2278"></a><tt class="py-lineno">2278</tt> <tt class="py-line"> <tt class="py-keyword">and</tt> <tt class="py-name">hostsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ipResult</tt> <tt class="py-keyword">and</tt> </tt>
+<a name="L2279"></a><tt class="py-lineno">2279</tt> <tt class="py-line"> <tt class="py-name">hostAttachmentResults</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2280"></a><tt class="py-lineno">2280</tt> <tt class="py-line"> </tt>
+<a name="L2281"></a><tt class="py-lineno">2281</tt> <tt class="py-line"> <tt class="py-comment"># Compare json objects for hosts and dataplane clusters</tt> </tt>
+<a name="L2282"></a><tt class="py-lineno">2282</tt> <tt class="py-line"> </tt>
+<a name="L2283"></a><tt class="py-lineno">2283</tt> <tt class="py-line"> <tt class="py-comment"># hosts</tt> </tt>
+<a name="L2284"></a><tt class="py-lineno">2284</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-806" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-806', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Hosts view is consistent across all ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2285"></a><tt class="py-lineno">2285</tt> <tt class="py-line"> <tt class="py-name">consistentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2286"></a><tt class="py-lineno">2286</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-807" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-807', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt id="link-808" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-808', 'hosts', 'link-159');">hosts</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2287"></a><tt class="py-lineno">2287</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-809" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-809', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2288"></a><tt class="py-lineno">2288</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-810" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-810', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-811" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-811', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2289"></a><tt class="py-lineno">2289</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-812" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-812', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-813" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-813', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt id="link-814" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-814', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2290"></a><tt class="py-lineno">2290</tt> <tt class="py-line"> <tt class="py-keyword">continue</tt> </tt>
+<a name="L2291"></a><tt class="py-lineno">2291</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-comment"># hosts not consistent</tt> </tt>
+<a name="L2292"></a><tt class="py-lineno">2292</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-815" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-815', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-816" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-816', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"hosts from ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2293"></a><tt class="py-lineno">2293</tt> <tt class="py-line"> <tt class="py-string">" is inconsistent with ONOS1"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2294"></a><tt class="py-lineno">2294</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-817" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-817', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-818" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-818', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-819" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-819', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2295"></a><tt class="py-lineno">2295</tt> <tt class="py-line"> <tt class="py-name">consistentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2296"></a><tt class="py-lineno">2296</tt> <tt class="py-line"> </tt>
+<a name="L2297"></a><tt class="py-lineno">2297</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2298"></a><tt class="py-lineno">2298</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-820" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-820', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-821" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-821', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting ONOS hosts from ONOS"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2299"></a><tt class="py-lineno">2299</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2300"></a><tt class="py-lineno">2300</tt> <tt class="py-line"> <tt class="py-name">consistentHostsResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2301"></a><tt class="py-lineno">2301</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-822" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-822', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2302"></a><tt class="py-lineno">2302</tt> <tt class="py-line"> <tt class="py-string">" hosts response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2303"></a><tt class="py-lineno">2303</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-823" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.hosts
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.hosts" class="py-name" href="#" onclick="return doclink('link-823', 'hosts', 'link-159');">hosts</a></tt><tt class="py-op">[</tt> <tt id="link-824" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-824', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2304"></a><tt class="py-lineno">2304</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2305"></a><tt class="py-lineno">2305</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2306"></a><tt class="py-lineno">2306</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentHostsResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2307"></a><tt class="py-lineno">2307</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Hosts view is consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2308"></a><tt class="py-lineno">2308</tt> <tt class="py-line"> <tt id="link-825" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-825', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of hosts"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2309"></a><tt class="py-lineno">2309</tt> <tt class="py-line"> </tt>
+<a name="L2310"></a><tt class="py-lineno">2310</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-826" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-826', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Hosts information is correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2311"></a><tt class="py-lineno">2311</tt> <tt class="py-line"> <tt class="py-name">hostsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">hostsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ipResult</tt> </tt>
+<a name="L2312"></a><tt class="py-lineno">2312</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2313"></a><tt class="py-lineno">2313</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2314"></a><tt class="py-lineno">2314</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">hostsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2315"></a><tt class="py-lineno">2315</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Host information is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2316"></a><tt class="py-lineno">2316</tt> <tt class="py-line"> <tt id="link-827" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-827', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Host information is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2317"></a><tt class="py-lineno">2317</tt> <tt class="py-line"> </tt>
+<a name="L2318"></a><tt class="py-lineno">2318</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-828" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-828', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Host attachment points to the network"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2319"></a><tt class="py-lineno">2319</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2320"></a><tt class="py-lineno">2320</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L2321"></a><tt class="py-lineno">2321</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">hostAttachmentResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2322"></a><tt class="py-lineno">2322</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Hosts are correctly attached to the network"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2323"></a><tt class="py-lineno">2323</tt> <tt class="py-line"> <tt id="link-829" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-829', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS did not correctly attach hosts to the network"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2324"></a><tt class="py-lineno">2324</tt> <tt class="py-line"> </tt>
+<a name="L2325"></a><tt class="py-lineno">2325</tt> <tt class="py-line"> <tt class="py-comment"># Strongly connected clusters of devices</tt> </tt>
+<a name="L2326"></a><tt class="py-lineno">2326</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-830" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-830', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Clusters view is consistent across all ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2327"></a><tt class="py-lineno">2327</tt> <tt class="py-line"> <tt class="py-name">consistentClustersResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2328"></a><tt class="py-lineno">2328</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-831" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-831', 'controller', 'link-523');">controller</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt id="link-832" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-832', 'clusters', 'link-518');">clusters</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2329"></a><tt class="py-lineno">2329</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-833" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-833', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2330"></a><tt class="py-lineno">2330</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"Error"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt id="link-834" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-834', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt id="link-835" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-835', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2331"></a><tt class="py-lineno">2331</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-836" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-836', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt id="link-837" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-837', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt id="link-838" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-838', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2332"></a><tt class="py-lineno">2332</tt> <tt class="py-line"> <tt class="py-keyword">continue</tt> </tt>
+<a name="L2333"></a><tt class="py-lineno">2333</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-comment"># clusters not consistent</tt> </tt>
+<a name="L2334"></a><tt class="py-lineno">2334</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-839" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-839', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-840" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-840', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"clusters from ONOS"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2335"></a><tt class="py-lineno">2335</tt> <tt class="py-line"> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2336"></a><tt class="py-lineno">2336</tt> <tt class="py-line"> <tt class="py-string">" is inconsistent with ONOS1"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2337"></a><tt class="py-lineno">2337</tt> <tt class="py-line"> <tt class="py-name">consistentClustersResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2338"></a><tt class="py-lineno">2338</tt> <tt class="py-line"> </tt>
+<a name="L2339"></a><tt class="py-lineno">2339</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2340"></a><tt class="py-lineno">2340</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-841" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-841', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-842" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-842', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in getting dataplane clusters "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2341"></a><tt class="py-lineno">2341</tt> <tt class="py-line"> <tt class="py-string">"from ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2342"></a><tt class="py-lineno">2342</tt> <tt class="py-line"> <tt class="py-name">consistentClustersResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2343"></a><tt class="py-lineno">2343</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-843" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-843', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">controllerStr</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2344"></a><tt class="py-lineno">2344</tt> <tt class="py-line"> <tt class="py-string">" clusters response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2345"></a><tt class="py-lineno">2345</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-844" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-844', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt id="link-845" class="py-name"><a title="TestON.drivers.common.api.controller" class="py-name" href="#" onclick="return doclink('link-845', 'controller', 'link-523');">controller</a></tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2346"></a><tt class="py-lineno">2346</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2347"></a><tt class="py-lineno">2347</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2348"></a><tt class="py-lineno">2348</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentClustersResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2349"></a><tt class="py-lineno">2349</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Clusters view is consistent across all ONOS nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2350"></a><tt class="py-lineno">2350</tt> <tt class="py-line"> <tt id="link-846" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-846', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS nodes have different views of clusters"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2351"></a><tt class="py-lineno">2351</tt> <tt class="py-line"> </tt>
+<a name="L2352"></a><tt class="py-lineno">2352</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-847" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-847', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"There is only one SCC"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2353"></a><tt class="py-lineno">2353</tt> <tt class="py-line"> <tt class="py-comment"># there should always only be one cluster</tt> </tt>
+<a name="L2354"></a><tt class="py-lineno">2354</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2355"></a><tt class="py-lineno">2355</tt> <tt class="py-line"> <tt class="py-name">numClusters</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt id="link-848" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-848', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2356"></a><tt class="py-lineno">2356</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2357"></a><tt class="py-lineno">2357</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-849" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-849', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing clusters[0]: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2358"></a><tt class="py-lineno">2358</tt> <tt class="py-line"> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt id="link-850" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.clusters" class="py-name" href="#" onclick="return doclink('link-850', 'clusters', 'link-518');">clusters</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2359"></a><tt class="py-lineno">2359</tt> <tt class="py-line"> <tt class="py-name">clusterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2360"></a><tt class="py-lineno">2360</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">numClusters</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L2361"></a><tt class="py-lineno">2361</tt> <tt class="py-line"> <tt class="py-name">clusterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2362"></a><tt class="py-lineno">2362</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2363"></a><tt class="py-lineno">2363</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-number">1</tt><tt class="py-op">,</tt> </tt>
+<a name="L2364"></a><tt class="py-lineno">2364</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">numClusters</tt><tt class="py-op">,</tt> </tt>
+<a name="L2365"></a><tt class="py-lineno">2365</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS shows 1 SCC"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2366"></a><tt class="py-lineno">2366</tt> <tt class="py-line"> <tt id="link-851" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-851', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS shows "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">numClusters</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" SCCs"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2367"></a><tt class="py-lineno">2367</tt> <tt class="py-line"> </tt>
+<a name="L2368"></a><tt class="py-lineno">2368</tt> <tt class="py-line"> <tt class="py-name">topoResult</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">devicesResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">linksResults</tt> </tt>
+<a name="L2369"></a><tt class="py-lineno">2369</tt> <tt class="py-line"> <tt class="py-keyword">and</tt> <tt class="py-name">hostsResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentHostsResult</tt> </tt>
+<a name="L2370"></a><tt class="py-lineno">2370</tt> <tt class="py-line"> <tt class="py-keyword">and</tt> <tt class="py-name">consistentClustersResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">clusterResults</tt> </tt>
+<a name="L2371"></a><tt class="py-lineno">2371</tt> <tt class="py-line"> <tt class="py-keyword">and</tt> <tt class="py-name">ipResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">hostAttachmentResults</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2372"></a><tt class="py-lineno">2372</tt> <tt class="py-line"> </tt>
+<a name="L2373"></a><tt class="py-lineno">2373</tt> <tt class="py-line"> <tt class="py-name">topoResult</tt> <tt class="py-op">=</tt> <tt class="py-name">topoResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">count</tt> <tt class="py-op"><=</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2374"></a><tt class="py-lineno">2374</tt> <tt class="py-line"> <tt class="py-name">note</tt> <tt class="py-op">=</tt> <tt class="py-string">"note it takes about "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">cliTime</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> \ </tt>
+<a name="L2375"></a><tt class="py-lineno">2375</tt> <tt class="py-line"> <tt class="py-string">" seconds for the test to make all the cli calls to fetch "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L2376"></a><tt class="py-lineno">2376</tt> <tt class="py-line"> <tt class="py-string">"the topology from each ONOS instance"</tt> </tt>
+<a name="L2377"></a><tt class="py-lineno">2377</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-852" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-852', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt>
+<a name="L2378"></a><tt class="py-lineno">2378</tt> <tt class="py-line"> <tt class="py-string">"Very crass estimate for topology discovery/convergence( "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2379"></a><tt class="py-lineno">2379</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">note</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" ): "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">elapsed</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" seconds, "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2380"></a><tt class="py-lineno">2380</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">count</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" tries"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2381"></a><tt class="py-lineno">2381</tt> <tt class="py-line"> </tt>
+<a name="L2382"></a><tt class="py-lineno">2382</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-853" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-853', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Device information is correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2383"></a><tt class="py-lineno">2383</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2384"></a><tt class="py-lineno">2384</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2385"></a><tt class="py-lineno">2385</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">devicesResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2386"></a><tt class="py-lineno">2386</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Device information is correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2387"></a><tt class="py-lineno">2387</tt> <tt class="py-line"> <tt id="link-854" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-854', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Device information is incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2388"></a><tt class="py-lineno">2388</tt> <tt class="py-line"> </tt>
+<a name="L2389"></a><tt class="py-lineno">2389</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-855" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-855', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Links are correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2390"></a><tt class="py-lineno">2390</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2391"></a><tt class="py-lineno">2391</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2392"></a><tt class="py-lineno">2392</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linksResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2393"></a><tt class="py-lineno">2393</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2394"></a><tt class="py-lineno">2394</tt> <tt class="py-line"> <tt id="link-856" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-856', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Links are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2395"></a><tt class="py-lineno">2395</tt> <tt class="py-line"> </tt>
+<a name="L2396"></a><tt class="py-lineno">2396</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-857" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-857', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Hosts are correct"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2397"></a><tt class="py-lineno">2397</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2398"></a><tt class="py-lineno">2398</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2399"></a><tt class="py-lineno">2399</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">hostsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2400"></a><tt class="py-lineno">2400</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Hosts are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2401"></a><tt class="py-lineno">2401</tt> <tt class="py-line"> <tt id="link-858" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-858', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Hosts are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2402"></a><tt class="py-lineno">2402</tt> <tt class="py-line"> </tt>
+<a name="L2403"></a><tt class="py-lineno">2403</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: move this to an ONOS state case</tt> </tt>
+<a name="L2404"></a><tt class="py-lineno">2404</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-859" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-859', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Checking ONOS nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2405"></a><tt class="py-lineno">2405</tt> <tt class="py-line"> <tt class="py-name">nodesOutput</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2406"></a><tt class="py-lineno">2406</tt> <tt class="py-line"> <tt class="py-name">nodeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2407"></a><tt class="py-lineno">2407</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2408"></a><tt class="py-lineno">2408</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2409"></a><tt class="py-lineno">2409</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-860" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-860', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-861" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-861', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2410"></a><tt class="py-lineno">2410</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"nodes-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2411"></a><tt class="py-lineno">2411</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2412"></a><tt class="py-lineno">2412</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2413"></a><tt class="py-lineno">2413</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2414"></a><tt class="py-lineno">2414</tt> <tt class="py-line"> </tt>
+<a name="L2415"></a><tt class="py-lineno">2415</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2416"></a><tt class="py-lineno">2416</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2417"></a><tt class="py-lineno">2417</tt> <tt class="py-line"> <tt class="py-name">nodesOutput</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2418"></a><tt class="py-lineno">2418</tt> <tt class="py-line"> <tt class="py-name">ips</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-862" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-862', 'nodes', 'link-9');">nodes</a></tt> <tt class="py-op">]</tt> </tt>
+<a name="L2419"></a><tt class="py-lineno">2419</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">nodesOutput</tt><tt class="py-op">:</tt> </tt>
+<a name="L2420"></a><tt class="py-lineno">2420</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2421"></a><tt class="py-lineno">2421</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2422"></a><tt class="py-lineno">2422</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L2423"></a><tt class="py-lineno">2423</tt> <tt class="py-line"> <tt class="py-name">currentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2424"></a><tt class="py-lineno">2424</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">node</tt><tt class="py-op">[</tt><tt class="py-string">'ip'</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ips</tt><tt class="py-op">:</tt> <tt class="py-comment"># node in nodes() output is in cell</tt> </tt>
+<a name="L2425"></a><tt class="py-lineno">2425</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">node</tt><tt class="py-op">[</tt><tt class="py-string">'state'</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'ACTIVE'</tt><tt class="py-op">:</tt> </tt>
+<a name="L2426"></a><tt class="py-lineno">2426</tt> <tt class="py-line"> <tt class="py-name">currentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2427"></a><tt class="py-lineno">2427</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2428"></a><tt class="py-lineno">2428</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-863" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-863', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-864" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-864', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error in ONOS node availability"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2429"></a><tt class="py-lineno">2429</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-865" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-865', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-866" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-866', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2430"></a><tt class="py-lineno">2430</tt> <tt class="py-line"> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt><tt class="py-op">,</tt> </tt>
+<a name="L2431"></a><tt class="py-lineno">2431</tt> <tt class="py-line"> <tt class="py-name">sort_keys</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L2432"></a><tt class="py-lineno">2432</tt> <tt class="py-line"> <tt class="py-name">indent</tt><tt class="py-op">=</tt><tt class="py-number">4</tt><tt class="py-op">,</tt> </tt>
+<a name="L2433"></a><tt class="py-lineno">2433</tt> <tt class="py-line"> <tt class="py-name">separators</tt><tt class="py-op">=</tt><tt class="py-op">(</tt> <tt class="py-string">','</tt><tt class="py-op">,</tt> <tt class="py-string">': '</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2434"></a><tt class="py-lineno">2434</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L2435"></a><tt class="py-lineno">2435</tt> <tt class="py-line"> <tt class="py-name">nodeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">nodeResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">currentResult</tt> </tt>
+<a name="L2436"></a><tt class="py-lineno">2436</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-op">(</tt> <tt class="py-name">ValueError</tt><tt class="py-op">,</tt> <tt class="py-name">TypeError</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2437"></a><tt class="py-lineno">2437</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-867" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-867', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-868" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-868', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error parsing nodes output"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2438"></a><tt class="py-lineno">2438</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-869" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-869', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2439"></a><tt class="py-lineno">2439</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">nodeResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2440"></a><tt class="py-lineno">2440</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Nodes check successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2441"></a><tt class="py-lineno">2441</tt> <tt class="py-line"> <tt id="link-870" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-870', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Nodes check NOT successful"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2442"></a><tt class="py-lineno">2442</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE9"></a><div id="HAsanity.CASE9-def"><a name="L2443"></a><tt class="py-lineno">2443</tt> <a class="py-toggle" href="#" id="HAsanity.CASE9-toggle" onclick="return toggle('HAsanity.CASE9');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE9">CASE9</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE9-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE9-expanded"><a name="L2444"></a><tt class="py-lineno">2444</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2445"></a><tt class="py-lineno">2445</tt> <tt class="py-line"><tt class="py-docstring"> Link s3-s28 down</tt> </tt>
+<a name="L2446"></a><tt class="py-lineno">2446</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2447"></a><tt class="py-lineno">2447</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2448"></a><tt class="py-lineno">2448</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2449"></a><tt class="py-lineno">2449</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2450"></a><tt class="py-lineno">2450</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2451"></a><tt class="py-lineno">2451</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2452"></a><tt class="py-lineno">2452</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-871" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-871', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2453"></a><tt class="py-lineno">2453</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: You should probably run a topology check after this</tt> </tt>
+<a name="L2454"></a><tt class="py-lineno">2454</tt> <tt class="py-line"> </tt>
+<a name="L2455"></a><tt class="py-lineno">2455</tt> <tt class="py-line"> <tt class="py-name">linkSleep</tt> <tt class="py-op">=</tt> <tt class="py-name">float</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'timers'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'LinkDiscovery'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2456"></a><tt class="py-lineno">2456</tt> <tt class="py-line"> </tt>
+<a name="L2457"></a><tt class="py-lineno">2457</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Turn off a link to ensure that Link Discovery "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L2458"></a><tt class="py-lineno">2458</tt> <tt class="py-line"> <tt class="py-string">"is working properly"</tt> </tt>
+<a name="L2459"></a><tt class="py-lineno">2459</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-872" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-872', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2460"></a><tt class="py-lineno">2460</tt> <tt class="py-line"> </tt>
+<a name="L2461"></a><tt class="py-lineno">2461</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-873" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-873', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Kill Link between s3 and s28"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2462"></a><tt class="py-lineno">2462</tt> <tt class="py-line"> <tt class="py-name">LinkDown</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-874" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#link"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-874', 'link', 'link-874');">link</a></tt><tt class="py-op">(</tt> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-string">"s3"</tt><tt class="py-op">,</tt> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-string">"s28"</tt><tt class="py-op">,</tt> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2463"></a><tt class="py-lineno">2463</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-875" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-875', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Waiting "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">linkSleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2464"></a><tt class="py-lineno">2464</tt> <tt class="py-line"> <tt class="py-string">" seconds for link down to be discovered"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2465"></a><tt class="py-lineno">2465</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-name">linkSleep</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2466"></a><tt class="py-lineno">2466</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">LinkDown</tt><tt class="py-op">,</tt> </tt>
+<a name="L2467"></a><tt class="py-lineno">2467</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link down successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2468"></a><tt class="py-lineno">2468</tt> <tt class="py-line"> <tt id="link-876" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-876', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Failed to bring link down"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2469"></a><tt class="py-lineno">2469</tt> <tt class="py-line"> <tt class="py-comment"># TODO do some sort of check here</tt> </tt>
+<a name="L2470"></a><tt class="py-lineno">2470</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE10"></a><div id="HAsanity.CASE10-def"><a name="L2471"></a><tt class="py-lineno">2471</tt> <a class="py-toggle" href="#" id="HAsanity.CASE10-toggle" onclick="return toggle('HAsanity.CASE10');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE10">CASE10</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE10-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE10-expanded"><a name="L2472"></a><tt class="py-lineno">2472</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2473"></a><tt class="py-lineno">2473</tt> <tt class="py-line"><tt class="py-docstring"> Link s3-s28 up</tt> </tt>
+<a name="L2474"></a><tt class="py-lineno">2474</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2475"></a><tt class="py-lineno">2475</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2476"></a><tt class="py-lineno">2476</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2477"></a><tt class="py-lineno">2477</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2478"></a><tt class="py-lineno">2478</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2479"></a><tt class="py-lineno">2479</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2480"></a><tt class="py-lineno">2480</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-877" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-877', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2481"></a><tt class="py-lineno">2481</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: You should probably run a topology check after this</tt> </tt>
+<a name="L2482"></a><tt class="py-lineno">2482</tt> <tt class="py-line"> </tt>
+<a name="L2483"></a><tt class="py-lineno">2483</tt> <tt class="py-line"> <tt class="py-name">linkSleep</tt> <tt class="py-op">=</tt> <tt class="py-name">float</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'timers'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'LinkDiscovery'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2484"></a><tt class="py-lineno">2484</tt> <tt class="py-line"> </tt>
+<a name="L2485"></a><tt class="py-lineno">2485</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Restore a link to ensure that Link Discovery is "</tt> <tt class="py-op">+</tt> \ </tt>
+<a name="L2486"></a><tt class="py-lineno">2486</tt> <tt class="py-line"> <tt class="py-string">"working properly"</tt> </tt>
+<a name="L2487"></a><tt class="py-lineno">2487</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-878" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-878', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2488"></a><tt class="py-lineno">2488</tt> <tt class="py-line"> </tt>
+<a name="L2489"></a><tt class="py-lineno">2489</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-879" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-879', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Bring link between s3 and s28 back up"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2490"></a><tt class="py-lineno">2490</tt> <tt class="py-line"> <tt class="py-name">LinkUp</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-880" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-880', 'link', 'link-874');">link</a></tt><tt class="py-op">(</tt> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-string">"s3"</tt><tt class="py-op">,</tt> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-string">"s28"</tt><tt class="py-op">,</tt> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2491"></a><tt class="py-lineno">2491</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-881" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-881', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Waiting "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">linkSleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2492"></a><tt class="py-lineno">2492</tt> <tt class="py-line"> <tt class="py-string">" seconds for link up to be discovered"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2493"></a><tt class="py-lineno">2493</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-name">linkSleep</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2494"></a><tt class="py-lineno">2494</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">LinkUp</tt><tt class="py-op">,</tt> </tt>
+<a name="L2495"></a><tt class="py-lineno">2495</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link up successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2496"></a><tt class="py-lineno">2496</tt> <tt class="py-line"> <tt id="link-882" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-882', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Failed to bring link up"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2497"></a><tt class="py-lineno">2497</tt> <tt class="py-line"> <tt class="py-comment"># TODO do some sort of check here</tt> </tt>
+<a name="L2498"></a><tt class="py-lineno">2498</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE11"></a><div id="HAsanity.CASE11-def"><a name="L2499"></a><tt class="py-lineno">2499</tt> <a class="py-toggle" href="#" id="HAsanity.CASE11-toggle" onclick="return toggle('HAsanity.CASE11');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE11">CASE11</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE11-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE11-expanded"><a name="L2500"></a><tt class="py-lineno">2500</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2501"></a><tt class="py-lineno">2501</tt> <tt class="py-line"><tt class="py-docstring"> Switch Down</tt> </tt>
+<a name="L2502"></a><tt class="py-lineno">2502</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2503"></a><tt class="py-lineno">2503</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: You should probably run a topology check after this</tt> </tt>
+<a name="L2504"></a><tt class="py-lineno">2504</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2505"></a><tt class="py-lineno">2505</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2506"></a><tt class="py-lineno">2506</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2507"></a><tt class="py-lineno">2507</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2508"></a><tt class="py-lineno">2508</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2509"></a><tt class="py-lineno">2509</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-883" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-883', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2510"></a><tt class="py-lineno">2510</tt> <tt class="py-line"> </tt>
+<a name="L2511"></a><tt class="py-lineno">2511</tt> <tt class="py-line"> <tt class="py-name">switchSleep</tt> <tt class="py-op">=</tt> <tt class="py-name">float</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'timers'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'SwitchDiscovery'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2512"></a><tt class="py-lineno">2512</tt> <tt class="py-line"> </tt>
+<a name="L2513"></a><tt class="py-lineno">2513</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Killing a switch to ensure it is discovered correctly"</tt> </tt>
+<a name="L2514"></a><tt class="py-lineno">2514</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-884" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-884', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2515"></a><tt class="py-lineno">2515</tt> <tt class="py-line"> <tt class="py-name">switch</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'kill'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'switch'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2516"></a><tt class="py-lineno">2516</tt> <tt class="py-line"> <tt class="py-name">switchDPID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'kill'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'dpid'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2517"></a><tt class="py-lineno">2517</tt> <tt class="py-line"> </tt>
+<a name="L2518"></a><tt class="py-lineno">2518</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Make this switch parameterizable</tt> </tt>
+<a name="L2519"></a><tt class="py-lineno">2519</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-885" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-885', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Kill "</tt> <tt class="py-op">+</tt> <tt class="py-name">switch</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2520"></a><tt class="py-lineno">2520</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-886" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-886', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Deleting "</tt> <tt class="py-op">+</tt> <tt class="py-name">switch</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2521"></a><tt class="py-lineno">2521</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-887" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.delSwitch()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#delSwitch"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.delSwitch" class="py-name" href="#" onclick="return doclink('link-887', 'delSwitch', 'link-887');">delSwitch</a></tt><tt class="py-op">(</tt> <tt class="py-name">switch</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2522"></a><tt class="py-lineno">2522</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-888" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-888', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Waiting "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">switchSleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2523"></a><tt class="py-lineno">2523</tt> <tt class="py-line"> <tt class="py-string">" seconds for switch down to be discovered"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2524"></a><tt class="py-lineno">2524</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-name">switchSleep</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2525"></a><tt class="py-lineno">2525</tt> <tt class="py-line"> <tt class="py-name">device</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-889" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-889', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-name">dpid</tt><tt class="py-op">=</tt><tt class="py-name">switchDPID</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2526"></a><tt class="py-lineno">2526</tt> <tt class="py-line"> <tt class="py-comment"># Peek at the deleted switch</tt> </tt>
+<a name="L2527"></a><tt class="py-lineno">2527</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-890" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-890', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">device</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2528"></a><tt class="py-lineno">2528</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2529"></a><tt class="py-lineno">2529</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">device</tt> <tt class="py-keyword">and</tt> <tt class="py-name">device</tt><tt class="py-op">[</tt> <tt class="py-string">'available'</tt> <tt class="py-op">]</tt> <tt class="py-keyword">is</tt> <tt class="py-name">False</tt><tt class="py-op">:</tt> </tt>
+<a name="L2530"></a><tt class="py-lineno">2530</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2531"></a><tt class="py-lineno">2531</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">result</tt><tt class="py-op">,</tt> </tt>
+<a name="L2532"></a><tt class="py-lineno">2532</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Kill switch successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2533"></a><tt class="py-lineno">2533</tt> <tt class="py-line"> <tt id="link-891" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-891', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Failed to kill switch?"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2534"></a><tt class="py-lineno">2534</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE12"></a><div id="HAsanity.CASE12-def"><a name="L2535"></a><tt class="py-lineno">2535</tt> <a class="py-toggle" href="#" id="HAsanity.CASE12-toggle" onclick="return toggle('HAsanity.CASE12');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE12">CASE12</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE12-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE12-expanded"><a name="L2536"></a><tt class="py-lineno">2536</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2537"></a><tt class="py-lineno">2537</tt> <tt class="py-line"><tt class="py-docstring"> Switch Up</tt> </tt>
+<a name="L2538"></a><tt class="py-lineno">2538</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2539"></a><tt class="py-lineno">2539</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: You should probably run a topology check after this</tt> </tt>
+<a name="L2540"></a><tt class="py-lineno">2540</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2541"></a><tt class="py-lineno">2541</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2542"></a><tt class="py-lineno">2542</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2543"></a><tt class="py-lineno">2543</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2544"></a><tt class="py-lineno">2544</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2545"></a><tt class="py-lineno">2545</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-892" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-892', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2546"></a><tt class="py-lineno">2546</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS1Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS1Port not defined"</tt> </tt>
+<a name="L2547"></a><tt class="py-lineno">2547</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS2Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS2Port not defined"</tt> </tt>
+<a name="L2548"></a><tt class="py-lineno">2548</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS3Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS3Port not defined"</tt> </tt>
+<a name="L2549"></a><tt class="py-lineno">2549</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS4Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS4Port not defined"</tt> </tt>
+<a name="L2550"></a><tt class="py-lineno">2550</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS5Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS5Port not defined"</tt> </tt>
+<a name="L2551"></a><tt class="py-lineno">2551</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS6Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS6Port not defined"</tt> </tt>
+<a name="L2552"></a><tt class="py-lineno">2552</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">ONOS7Port</tt><tt class="py-op">,</tt> <tt class="py-string">"ONOS7Port not defined"</tt> </tt>
+<a name="L2553"></a><tt class="py-lineno">2553</tt> <tt class="py-line"> </tt>
+<a name="L2554"></a><tt class="py-lineno">2554</tt> <tt class="py-line"> <tt class="py-name">switchSleep</tt> <tt class="py-op">=</tt> <tt class="py-name">float</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'timers'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'SwitchDiscovery'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2555"></a><tt class="py-lineno">2555</tt> <tt class="py-line"> <tt class="py-name">switch</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'kill'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'switch'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2556"></a><tt class="py-lineno">2556</tt> <tt class="py-line"> <tt class="py-name">switchDPID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'kill'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'dpid'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2557"></a><tt class="py-lineno">2557</tt> <tt class="py-line"> <tt id="link-893" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-893', 'links', 'link-514');">links</a></tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'kill'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'links'</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2558"></a><tt class="py-lineno">2558</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Adding a switch to ensure it is discovered correctly"</tt> </tt>
+<a name="L2559"></a><tt class="py-lineno">2559</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-894" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-894', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2560"></a><tt class="py-lineno">2560</tt> <tt class="py-line"> </tt>
+<a name="L2561"></a><tt class="py-lineno">2561</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-895" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-895', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add back "</tt> <tt class="py-op">+</tt> <tt class="py-name">switch</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2562"></a><tt class="py-lineno">2562</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-896" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.addSwitch()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#addSwitch"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.addSwitch" class="py-name" href="#" onclick="return doclink('link-896', 'addSwitch', 'link-896');">addSwitch</a></tt><tt class="py-op">(</tt> <tt class="py-name">switch</tt><tt class="py-op">,</tt> <tt class="py-name">dpid</tt><tt class="py-op">=</tt><tt class="py-name">switchDPID</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2563"></a><tt class="py-lineno">2563</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">peer</tt> <tt class="py-keyword">in</tt> <tt id="link-897" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-897', 'links', 'link-514');">links</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L2564"></a><tt class="py-lineno">2564</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-898" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.addLink()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#addLink"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.addLink" class="py-name" href="#" onclick="return doclink('link-898', 'addLink', 'link-898');">addLink</a></tt><tt class="py-op">(</tt> <tt class="py-name">switch</tt><tt class="py-op">,</tt> <tt class="py-name">peer</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2565"></a><tt class="py-lineno">2565</tt> <tt class="py-line"> <tt class="py-name">ipList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2566"></a><tt class="py-lineno">2566</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2567"></a><tt class="py-lineno">2567</tt> <tt class="py-line"> <tt class="py-name">ipList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-899" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-899', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2568"></a><tt class="py-lineno">2568</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-900" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.assignSwController" class="py-name" href="#" onclick="return doclink('link-900', 'assignSwController', 'link-78');">assignSwController</a></tt><tt class="py-op">(</tt> <tt class="py-name">sw</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">,</tt> <tt class="py-name">ip</tt><tt class="py-op">=</tt><tt class="py-name">ipList</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2569"></a><tt class="py-lineno">2569</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-901" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-901', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Waiting "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">switchSleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2570"></a><tt class="py-lineno">2570</tt> <tt class="py-line"> <tt class="py-string">" seconds for switch up to be discovered"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2571"></a><tt class="py-lineno">2571</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-name">switchSleep</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2572"></a><tt class="py-lineno">2572</tt> <tt class="py-line"> <tt class="py-name">device</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-902" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevice" class="py-name" href="#" onclick="return doclink('link-902', 'getDevice', 'link-90');">getDevice</a></tt><tt class="py-op">(</tt> <tt class="py-name">dpid</tt><tt class="py-op">=</tt><tt class="py-name">switchDPID</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2573"></a><tt class="py-lineno">2573</tt> <tt class="py-line"> <tt class="py-comment"># Peek at the deleted switch</tt> </tt>
+<a name="L2574"></a><tt class="py-lineno">2574</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-903" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-903', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">device</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2575"></a><tt class="py-lineno">2575</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2576"></a><tt class="py-lineno">2576</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">device</tt> <tt class="py-keyword">and</tt> <tt class="py-name">device</tt><tt class="py-op">[</tt> <tt class="py-string">'available'</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2577"></a><tt class="py-lineno">2577</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2578"></a><tt class="py-lineno">2578</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">result</tt><tt class="py-op">,</tt> </tt>
+<a name="L2579"></a><tt class="py-lineno">2579</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"add switch successful"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2580"></a><tt class="py-lineno">2580</tt> <tt class="py-line"> <tt id="link-904" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-904', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Failed to add switch?"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2581"></a><tt class="py-lineno">2581</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE13"></a><div id="HAsanity.CASE13-def"><a name="L2582"></a><tt class="py-lineno">2582</tt> <a class="py-toggle" href="#" id="HAsanity.CASE13-toggle" onclick="return toggle('HAsanity.CASE13');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE13">CASE13</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE13-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE13-expanded"><a name="L2583"></a><tt class="py-lineno">2583</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2584"></a><tt class="py-lineno">2584</tt> <tt class="py-line"><tt class="py-docstring"> Clean up</tt> </tt>
+<a name="L2585"></a><tt class="py-lineno">2585</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2586"></a><tt class="py-lineno">2586</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">os</tt> </tt>
+<a name="L2587"></a><tt class="py-lineno">2587</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2588"></a><tt class="py-lineno">2588</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2589"></a><tt class="py-lineno">2589</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2590"></a><tt class="py-lineno">2590</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2591"></a><tt class="py-lineno">2591</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2592"></a><tt class="py-lineno">2592</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-905" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-905', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2593"></a><tt class="py-lineno">2593</tt> <tt class="py-line"> </tt>
+<a name="L2594"></a><tt class="py-lineno">2594</tt> <tt class="py-line"> <tt class="py-comment"># printing colors to terminal</tt> </tt>
+<a name="L2595"></a><tt class="py-lineno">2595</tt> <tt class="py-line"> <tt class="py-name">colors</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> <tt class="py-string">'cyan'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[96m'</tt><tt class="py-op">,</tt> <tt class="py-string">'purple'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[95m'</tt><tt class="py-op">,</tt> </tt>
+<a name="L2596"></a><tt class="py-lineno">2596</tt> <tt class="py-line"> <tt class="py-string">'blue'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[94m'</tt><tt class="py-op">,</tt> <tt class="py-string">'green'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[92m'</tt><tt class="py-op">,</tt> </tt>
+<a name="L2597"></a><tt class="py-lineno">2597</tt> <tt class="py-line"> <tt class="py-string">'yellow'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[93m'</tt><tt class="py-op">,</tt> <tt class="py-string">'red'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[91m'</tt><tt class="py-op">,</tt> <tt class="py-string">'end'</tt><tt class="py-op">:</tt> <tt class="py-string">'\033[0m'</tt> <tt class="py-op">}</tt> </tt>
+<a name="L2598"></a><tt class="py-lineno">2598</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-906" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-906', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Test Cleanup"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2599"></a><tt class="py-lineno">2599</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-907" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-907', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Killing tcpdumps"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2600"></a><tt class="py-lineno">2600</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet2</tt><tt class="py-op">.</tt><tt id="link-908" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.stopTcpdump()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#stopTcpdump,Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.stopTcpdump()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#stopTcpdump"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.stopTcpdump
+TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.stopTcpdump" class="py-name" href="#" onclick="return doclink('link-908', 'stopTcpdump', 'link-908');">stopTcpdump</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2601"></a><tt class="py-lineno">2601</tt> <tt class="py-line"> </tt>
+<a name="L2602"></a><tt class="py-lineno">2602</tt> <tt class="py-line"> <tt class="py-name">testname</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TEST</tt> </tt>
+<a name="L2603"></a><tt class="py-lineno">2603</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'BACKUP'</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">"True"</tt><tt class="py-op">:</tt> </tt>
+<a name="L2604"></a><tt class="py-lineno">2604</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-909" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-909', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Copying MN pcap and ONOS log files to test station"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2605"></a><tt class="py-lineno">2605</tt> <tt class="py-line"> <tt class="py-name">teststationUser</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'BACKUP'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'TESTONUSER'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2606"></a><tt class="py-lineno">2606</tt> <tt class="py-line"> <tt class="py-name">teststationIP</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">params</tt><tt class="py-op">[</tt> <tt class="py-string">'BACKUP'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'TESTONIP'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2607"></a><tt class="py-lineno">2607</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: MN Pcap file is being saved to ~/packet_captures</tt> </tt>
+<a name="L2608"></a><tt class="py-lineno">2608</tt> <tt class="py-line"> <tt class="py-comment"># scp this file as MN and TestON aren't necessarily the same vm</tt> </tt>
+<a name="L2609"></a><tt class="py-lineno">2609</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: scp</tt> </tt>
+<a name="L2610"></a><tt class="py-lineno">2610</tt> <tt class="py-line"> <tt class="py-comment"># mn files</tt> </tt>
+<a name="L2611"></a><tt class="py-lineno">2611</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Load these from params</tt> </tt>
+<a name="L2612"></a><tt class="py-lineno">2612</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: must end in /</tt> </tt>
+<a name="L2613"></a><tt class="py-lineno">2613</tt> <tt class="py-line"> <tt class="py-name">logFolder</tt> <tt class="py-op">=</tt> <tt class="py-string">"/opt/onos/log/"</tt> </tt>
+<a name="L2614"></a><tt class="py-lineno">2614</tt> <tt class="py-line"> <tt class="py-name">logFiles</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-string">"karaf.log"</tt><tt class="py-op">,</tt> <tt class="py-string">"karaf.log.1"</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2615"></a><tt class="py-lineno">2615</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: must end in /</tt> </tt>
+<a name="L2616"></a><tt class="py-lineno">2616</tt> <tt class="py-line"> <tt class="py-name">dstDir</tt> <tt class="py-op">=</tt> <tt class="py-string">"~/packet_captures/"</tt> </tt>
+<a name="L2617"></a><tt class="py-lineno">2617</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">logFiles</tt><tt class="py-op">:</tt> </tt>
+<a name="L2618"></a><tt class="py-lineno">2618</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-910" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-910', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L2619"></a><tt class="py-lineno">2619</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-911" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#sendline"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-911', 'sendline', 'link-911');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"scp sdn@"</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2620"></a><tt class="py-lineno">2620</tt> <tt class="py-line"> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">logFolder</tt> <tt class="py-op">+</tt> <tt class="py-name">f</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2621"></a><tt class="py-lineno">2621</tt> <tt class="py-line"> <tt class="py-name">teststationUser</tt> <tt class="py-op">+</tt> <tt class="py-string">"@"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2622"></a><tt class="py-lineno">2622</tt> <tt class="py-line"> <tt class="py-name">teststationIP</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2623"></a><tt class="py-lineno">2623</tt> <tt class="py-line"> <tt class="py-name">dstDir</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">testname</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2624"></a><tt class="py-lineno">2624</tt> <tt class="py-line"> <tt class="py-string">"-"</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">"-"</tt> <tt class="py-op">+</tt> <tt class="py-name">f</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2625"></a><tt class="py-lineno">2625</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2626"></a><tt class="py-lineno">2626</tt> <tt class="py-line"> </tt>
+<a name="L2627"></a><tt class="py-lineno">2627</tt> <tt class="py-line"> <tt class="py-comment"># std*.log's</tt> </tt>
+<a name="L2628"></a><tt class="py-lineno">2628</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: must end in /</tt> </tt>
+<a name="L2629"></a><tt class="py-lineno">2629</tt> <tt class="py-line"> <tt class="py-name">logFolder</tt> <tt class="py-op">=</tt> <tt class="py-string">"/opt/onos/var/"</tt> </tt>
+<a name="L2630"></a><tt class="py-lineno">2630</tt> <tt class="py-line"> <tt class="py-name">logFiles</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-string">"stderr.log"</tt><tt class="py-op">,</tt> <tt class="py-string">"stdout.log"</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2631"></a><tt class="py-lineno">2631</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: must end in /</tt> </tt>
+<a name="L2632"></a><tt class="py-lineno">2632</tt> <tt class="py-line"> <tt class="py-name">dstDir</tt> <tt class="py-op">=</tt> <tt class="py-string">"~/packet_captures/"</tt> </tt>
+<a name="L2633"></a><tt class="py-lineno">2633</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">logFiles</tt><tt class="py-op">:</tt> </tt>
+<a name="L2634"></a><tt class="py-lineno">2634</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-912" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-912', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L2635"></a><tt class="py-lineno">2635</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-913" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-913', 'sendline', 'link-911');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"scp sdn@"</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2636"></a><tt class="py-lineno">2636</tt> <tt class="py-line"> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">logFolder</tt> <tt class="py-op">+</tt> <tt class="py-name">f</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2637"></a><tt class="py-lineno">2637</tt> <tt class="py-line"> <tt class="py-name">teststationUser</tt> <tt class="py-op">+</tt> <tt class="py-string">"@"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2638"></a><tt class="py-lineno">2638</tt> <tt class="py-line"> <tt class="py-name">teststationIP</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2639"></a><tt class="py-lineno">2639</tt> <tt class="py-line"> <tt class="py-name">dstDir</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">testname</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2640"></a><tt class="py-lineno">2640</tt> <tt class="py-line"> <tt class="py-string">"-"</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">"-"</tt> <tt class="py-op">+</tt> <tt class="py-name">f</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2641"></a><tt class="py-lineno">2641</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2642"></a><tt class="py-lineno">2642</tt> <tt class="py-line"> <tt class="py-comment"># sleep so scp can finish</tt> </tt>
+<a name="L2643"></a><tt class="py-lineno">2643</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">10</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2644"></a><tt class="py-lineno">2644</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-914" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-914', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Packing and rotating pcap archives"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2645"></a><tt class="py-lineno">2645</tt> <tt class="py-line"> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">system</tt><tt class="py-op">(</tt> <tt class="py-string">"~/TestON/dependencies/rotate.sh "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">testname</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2646"></a><tt class="py-lineno">2646</tt> <tt class="py-line"> </tt>
+<a name="L2647"></a><tt class="py-lineno">2647</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-915" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-915', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Stopping Mininet"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2648"></a><tt class="py-lineno">2648</tt> <tt class="py-line"> <tt class="py-name">mnResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-916" class="py-name" targets="Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.stopNet()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#stopNet"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.stopNet" class="py-name" href="#" onclick="return doclink('link-916', 'stopNet', 'link-916');">stopNet</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2649"></a><tt class="py-lineno">2649</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">mnResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2650"></a><tt class="py-lineno">2650</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Mininet stopped"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2651"></a><tt class="py-lineno">2651</tt> <tt class="py-line"> <tt id="link-917" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-917', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"MN cleanup NOT successful"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2652"></a><tt class="py-lineno">2652</tt> <tt class="py-line"> </tt>
+<a name="L2653"></a><tt class="py-lineno">2653</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-918" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-918', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Checking ONOS Logs for errors"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2654"></a><tt class="py-lineno">2654</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-919" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-919', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">:</tt> </tt>
+<a name="L2655"></a><tt class="py-lineno">2655</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">colors</tt><tt class="py-op">[</tt> <tt class="py-string">'purple'</tt> <tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">"Checking logs for errors on "</tt> <tt class="py-op">+</tt> \ </tt>
+<a name="L2656"></a><tt class="py-lineno">2656</tt> <tt class="py-line"> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">colors</tt><tt class="py-op">[</tt> <tt class="py-string">'end'</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2657"></a><tt class="py-lineno">2657</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-920" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.checkLogs()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#checkLogs"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.checkLogs" class="py-name" href="#" onclick="return doclink('link-920', 'checkLogs', 'link-920');">checkLogs</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2658"></a><tt class="py-lineno">2658</tt> <tt class="py-line"> </tt>
+<a name="L2659"></a><tt class="py-lineno">2659</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2660"></a><tt class="py-lineno">2660</tt> <tt class="py-line"> <tt class="py-name">timerLog</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">logdir</tt> <tt class="py-op">+</tt> <tt class="py-string">"/Timers.csv"</tt><tt class="py-op">,</tt> <tt class="py-string">'w'</tt><tt class="py-op">)</tt> </tt>
+<a name="L2661"></a><tt class="py-lineno">2661</tt> <tt class="py-line"> <tt class="py-comment"># Overwrite with empty line and close</tt> </tt>
+<a name="L2662"></a><tt class="py-lineno">2662</tt> <tt class="py-line"> <tt class="py-name">labels</tt> <tt class="py-op">=</tt> <tt class="py-string">"Gossip Intents"</tt> </tt>
+<a name="L2663"></a><tt class="py-lineno">2663</tt> <tt class="py-line"> <tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">gossipTime</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2664"></a><tt class="py-lineno">2664</tt> <tt class="py-line"> <tt class="py-name">timerLog</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt> <tt class="py-name">labels</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">+</tt> <tt class="py-name">data</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2665"></a><tt class="py-lineno">2665</tt> <tt class="py-line"> <tt class="py-name">timerLog</tt><tt class="py-op">.</tt><tt class="py-name">close</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2666"></a><tt class="py-lineno">2666</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">NameError</tt><tt class="py-op">,</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt>
+<a name="L2667"></a><tt class="py-lineno">2667</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-921" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-921', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt><tt class="py-name">e</tt><tt class="py-op">)</tt> </tt>
+</div><a name="L2668"></a><tt class="py-lineno">2668</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE14"></a><div id="HAsanity.CASE14-def"><a name="L2669"></a><tt class="py-lineno">2669</tt> <a class="py-toggle" href="#" id="HAsanity.CASE14-toggle" onclick="return toggle('HAsanity.CASE14');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE14">CASE14</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE14-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE14-expanded"><a name="L2670"></a><tt class="py-lineno">2670</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2671"></a><tt class="py-lineno">2671</tt> <tt class="py-line"><tt class="py-docstring"> start election app on all onos nodes</tt> </tt>
+<a name="L2672"></a><tt class="py-lineno">2672</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2673"></a><tt class="py-lineno">2673</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2674"></a><tt class="py-lineno">2674</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2675"></a><tt class="py-lineno">2675</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2676"></a><tt class="py-lineno">2676</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2677"></a><tt class="py-lineno">2677</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-922" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-922', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2678"></a><tt class="py-lineno">2678</tt> <tt class="py-line"> </tt>
+<a name="L2679"></a><tt class="py-lineno">2679</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-923" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-923', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt><tt class="py-string">"Start Leadership Election app"</tt><tt class="py-op">)</tt> </tt>
+<a name="L2680"></a><tt class="py-lineno">2680</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-924" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-924', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install leadership election app"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2681"></a><tt class="py-lineno">2681</tt> <tt class="py-line"> <tt class="py-name">appResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-925" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.activateApp
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp" class="py-name" href="#" onclick="return doclink('link-925', 'activateApp', 'link-124');">activateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2682"></a><tt class="py-lineno">2682</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2683"></a><tt class="py-lineno">2683</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2684"></a><tt class="py-lineno">2684</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">appResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2685"></a><tt class="py-lineno">2685</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Election app installed"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2686"></a><tt class="py-lineno">2686</tt> <tt class="py-line"> <tt id="link-926" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-926', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something went wrong with installing Leadership election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2687"></a><tt class="py-lineno">2687</tt> <tt class="py-line"> </tt>
+<a name="L2688"></a><tt class="py-lineno">2688</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-927" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-927', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Run for election on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2689"></a><tt class="py-lineno">2689</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2690"></a><tt class="py-lineno">2690</tt> <tt class="py-line"> <tt id="link-928" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-928', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2691"></a><tt class="py-lineno">2691</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-929" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-929', 'cli', 'link-223');">cli</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L2692"></a><tt class="py-lineno">2692</tt> <tt class="py-line"> <tt id="link-930" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-930', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-931" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestRun()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#electionTestRun"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestRun" class="py-name" href="#" onclick="return doclink('link-931', 'electionTestRun', 'link-931');">electionTestRun</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2693"></a><tt class="py-lineno">2693</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-932" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-932', 'cli', 'link-223');">cli</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L2694"></a><tt class="py-lineno">2694</tt> <tt class="py-line"> <tt class="py-name">leader</tt> <tt class="py-op">=</tt> <tt id="link-933" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-933', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-934" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-934', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2695"></a><tt class="py-lineno">2695</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">leader</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-name">leader</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L2696"></a><tt class="py-lineno">2696</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-935" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-935', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-936" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-936', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt id="link-937" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-937', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Leader for the election app "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2697"></a><tt class="py-lineno">2697</tt> <tt class="py-line"> <tt class="py-string">"should be an ONOS node, instead got '"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2698"></a><tt class="py-lineno">2698</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leader</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"'"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2699"></a><tt class="py-lineno">2699</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2700"></a><tt class="py-lineno">2700</tt> <tt class="py-line"> <tt id="link-938" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-938', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">leader</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2701"></a><tt class="py-lineno">2701</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2702"></a><tt class="py-lineno">2702</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2703"></a><tt class="py-lineno">2703</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">leaderResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2704"></a><tt class="py-lineno">2704</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Successfully ran for leadership"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2705"></a><tt class="py-lineno">2705</tt> <tt class="py-line"> <tt id="link-939" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-939', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Failed to run for leadership"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2706"></a><tt class="py-lineno">2706</tt> <tt class="py-line"> </tt>
+<a name="L2707"></a><tt class="py-lineno">2707</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-940" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-940', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check that each node shows the same leader"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2708"></a><tt class="py-lineno">2708</tt> <tt class="py-line"> <tt class="py-name">sameLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2709"></a><tt class="py-lineno">2709</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt id="link-941" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-941', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">!=</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L2710"></a><tt class="py-lineno">2710</tt> <tt class="py-line"> <tt class="py-name">sameLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2711"></a><tt class="py-lineno">2711</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-942" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-942', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-943" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-943', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Results of electionTestLeader is order of main.CLIs:"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2712"></a><tt class="py-lineno">2712</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-944" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-944', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2713"></a><tt class="py-lineno">2713</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2714"></a><tt class="py-lineno">2714</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2715"></a><tt class="py-lineno">2715</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">sameLeader</tt><tt class="py-op">,</tt> </tt>
+<a name="L2716"></a><tt class="py-lineno">2716</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Leadership is consistent for the election topic"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2717"></a><tt class="py-lineno">2717</tt> <tt class="py-line"> <tt id="link-945" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-945', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Nodes have different leaders"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2718"></a><tt class="py-lineno">2718</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE15"></a><div id="HAsanity.CASE15-def"><a name="L2719"></a><tt class="py-lineno">2719</tt> <a class="py-toggle" href="#" id="HAsanity.CASE15-toggle" onclick="return toggle('HAsanity.CASE15');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE15">CASE15</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE15-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE15-expanded"><a name="L2720"></a><tt class="py-lineno">2720</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2721"></a><tt class="py-lineno">2721</tt> <tt class="py-line"><tt class="py-docstring"> Check that Leadership Election is still functional</tt> </tt>
+<a name="L2722"></a><tt class="py-lineno">2722</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2723"></a><tt class="py-lineno">2723</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2724"></a><tt class="py-lineno">2724</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2725"></a><tt class="py-lineno">2725</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2726"></a><tt class="py-lineno">2726</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2727"></a><tt class="py-lineno">2727</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2728"></a><tt class="py-lineno">2728</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-946" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-946', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2729"></a><tt class="py-lineno">2729</tt> <tt class="py-line"> </tt>
+<a name="L2730"></a><tt class="py-lineno">2730</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2731"></a><tt class="py-lineno">2731</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Check that Leadership Election is still functional"</tt> </tt>
+<a name="L2732"></a><tt class="py-lineno">2732</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-947" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-947', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2733"></a><tt class="py-lineno">2733</tt> <tt class="py-line"> </tt>
+<a name="L2734"></a><tt class="py-lineno">2734</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-948" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-948', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check that each node shows the same leader"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2735"></a><tt class="py-lineno">2735</tt> <tt class="py-line"> <tt class="py-name">sameLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2736"></a><tt class="py-lineno">2736</tt> <tt class="py-line"> <tt id="link-949" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-949', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2737"></a><tt class="py-lineno">2737</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-950" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-950', 'cli', 'link-223');">cli</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L2738"></a><tt class="py-lineno">2738</tt> <tt class="py-line"> <tt class="py-name">leader</tt> <tt class="py-op">=</tt> <tt id="link-951" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-951', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-952" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-952', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2739"></a><tt class="py-lineno">2739</tt> <tt class="py-line"> <tt id="link-953" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-953', 'leaders', 'link-181');">leaders</a></tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">leader</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2740"></a><tt class="py-lineno">2740</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt id="link-954" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-954', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">!=</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L2741"></a><tt class="py-lineno">2741</tt> <tt class="py-line"> <tt class="py-name">sameLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2742"></a><tt class="py-lineno">2742</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-955" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-955', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-956" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-956', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Results of electionTestLeader is order of main.CLIs:"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2743"></a><tt class="py-lineno">2743</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt id="link-957" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.leaders" class="py-name" href="#" onclick="return doclink('link-957', 'leaders', 'link-181');">leaders</a></tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2744"></a><tt class="py-lineno">2744</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2745"></a><tt class="py-lineno">2745</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2746"></a><tt class="py-lineno">2746</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">sameLeader</tt><tt class="py-op">,</tt> </tt>
+<a name="L2747"></a><tt class="py-lineno">2747</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Leadership is consistent for the election topic"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2748"></a><tt class="py-lineno">2748</tt> <tt class="py-line"> <tt id="link-958" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-958', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Nodes have different leaders"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2749"></a><tt class="py-lineno">2749</tt> <tt class="py-line"> </tt>
+<a name="L2750"></a><tt class="py-lineno">2750</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-959" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-959', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Find current leader and withdraw"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2751"></a><tt class="py-lineno">2751</tt> <tt class="py-line"> <tt class="py-name">leader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-960" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-960', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2752"></a><tt class="py-lineno">2752</tt> <tt class="py-line"> <tt class="py-comment"># do some sanity checking on leader before using it</tt> </tt>
+<a name="L2753"></a><tt class="py-lineno">2753</tt> <tt class="py-line"> <tt class="py-name">withdrawResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2754"></a><tt class="py-lineno">2754</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">leader</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-name">leader</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L2755"></a><tt class="py-lineno">2755</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-961" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-961', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-962" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-962', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2756"></a><tt class="py-lineno">2756</tt> <tt class="py-line"> <tt class="py-string">"Leader for the election app should be an ONOS node,"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2757"></a><tt class="py-lineno">2757</tt> <tt class="py-line"> <tt class="py-string">"instead got '"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leader</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"'"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2758"></a><tt class="py-lineno">2758</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2759"></a><tt class="py-lineno">2759</tt> <tt class="py-line"> <tt class="py-name">oldLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
+<a name="L2760"></a><tt class="py-lineno">2760</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2761"></a><tt class="py-lineno">2761</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">leader</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-963" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-963', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt><tt class="py-op">:</tt> </tt>
+<a name="L2762"></a><tt class="py-lineno">2762</tt> <tt class="py-line"> <tt class="py-name">oldLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> </tt>
+<a name="L2763"></a><tt class="py-lineno">2763</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
+<a name="L2764"></a><tt class="py-lineno">2764</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-comment"># FOR/ELSE statement</tt> </tt>
+<a name="L2765"></a><tt class="py-lineno">2765</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-964" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-964', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-965" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-965', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Leader election, could not find current leader"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2766"></a><tt class="py-lineno">2766</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">oldLeader</tt><tt class="py-op">:</tt> </tt>
+<a name="L2767"></a><tt class="py-lineno">2767</tt> <tt class="py-line"> <tt class="py-name">withdrawResult</tt> <tt class="py-op">=</tt> <tt class="py-name">oldLeader</tt><tt class="py-op">.</tt><tt id="link-966" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestWithdraw()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#electionTestWithdraw"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestWithdraw" class="py-name" href="#" onclick="return doclink('link-966', 'electionTestWithdraw', 'link-966');">electionTestWithdraw</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2768"></a><tt class="py-lineno">2768</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2769"></a><tt class="py-lineno">2769</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2770"></a><tt class="py-lineno">2770</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">withdrawResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2771"></a><tt class="py-lineno">2771</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Node was withdrawn from election"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2772"></a><tt class="py-lineno">2772</tt> <tt class="py-line"> <tt id="link-967" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-967', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Node was not withdrawn from election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2773"></a><tt class="py-lineno">2773</tt> <tt class="py-line"> </tt>
+<a name="L2774"></a><tt class="py-lineno">2774</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-968" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-968', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Make sure new leader is elected"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2775"></a><tt class="py-lineno">2775</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: use threads</tt> </tt>
+<a name="L2776"></a><tt class="py-lineno">2776</tt> <tt class="py-line"> <tt class="py-name">leaderList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2777"></a><tt class="py-lineno">2777</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-969" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-969', 'cli', 'link-223');">cli</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">:</tt> </tt>
+<a name="L2778"></a><tt class="py-lineno">2778</tt> <tt class="py-line"> <tt class="py-name">leaderN</tt> <tt class="py-op">=</tt> <tt id="link-970" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-970', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-971" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-971', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2779"></a><tt class="py-lineno">2779</tt> <tt class="py-line"> <tt class="py-name">leaderList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2780"></a><tt class="py-lineno">2780</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">==</tt> <tt class="py-name">leader</tt><tt class="py-op">:</tt> </tt>
+<a name="L2781"></a><tt class="py-lineno">2781</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-972" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-972', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-973" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-973', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt id="link-974" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-974', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">" still sees "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leader</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2782"></a><tt class="py-lineno">2782</tt> <tt class="py-line"> <tt class="py-string">" as leader after they withdrew"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2783"></a><tt class="py-lineno">2783</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2784"></a><tt class="py-lineno">2784</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L2785"></a><tt class="py-lineno">2785</tt> <tt class="py-line"> <tt class="py-comment"># error in response</tt> </tt>
+<a name="L2786"></a><tt class="py-lineno">2786</tt> <tt class="py-line"> <tt class="py-comment"># TODO: add check for "Command not found:" in the driver, this</tt> </tt>
+<a name="L2787"></a><tt class="py-lineno">2787</tt> <tt class="py-line"> <tt class="py-comment"># means the app isn't loaded</tt> </tt>
+<a name="L2788"></a><tt class="py-lineno">2788</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-975" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-975', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-976" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-976', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Something is wrong with "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2789"></a><tt class="py-lineno">2789</tt> <tt class="py-line"> <tt class="py-string">"electionTestLeader function, "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2790"></a><tt class="py-lineno">2790</tt> <tt class="py-line"> <tt class="py-string">"check the error logs"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2791"></a><tt class="py-lineno">2791</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2792"></a><tt class="py-lineno">2792</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">leaderN</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
+<a name="L2793"></a><tt class="py-lineno">2793</tt> <tt class="py-line"> <tt class="py-comment"># node may not have recieved the event yet</tt> </tt>
+<a name="L2794"></a><tt class="py-lineno">2794</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt><tt class="py-number">7</tt><tt class="py-op">)</tt> </tt>
+<a name="L2795"></a><tt class="py-lineno">2795</tt> <tt class="py-line"> <tt class="py-name">leaderN</tt> <tt class="py-op">=</tt> <tt id="link-977" class="py-name"><a title="TestON.bin.cli
+TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-977', 'cli', 'link-223');">cli</a></tt><tt class="py-op">.</tt><tt id="link-978" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-978', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2796"></a><tt class="py-lineno">2796</tt> <tt class="py-line"> <tt class="py-name">leaderList</tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2797"></a><tt class="py-lineno">2797</tt> <tt class="py-line"> <tt class="py-name">leaderList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">leaderN</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2798"></a><tt class="py-lineno">2798</tt> <tt class="py-line"> <tt class="py-name">consistentLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2799"></a><tt class="py-lineno">2799</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">leaderList</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
+<a name="L2800"></a><tt class="py-lineno">2800</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-979" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-979', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Each Election-app sees '"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2801"></a><tt class="py-lineno">2801</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leaderList</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2802"></a><tt class="py-lineno">2802</tt> <tt class="py-line"> <tt class="py-string">"' as the leader"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2803"></a><tt class="py-lineno">2803</tt> <tt class="py-line"> <tt class="py-name">consistentLeader</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2804"></a><tt class="py-lineno">2804</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2805"></a><tt class="py-lineno">2805</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-980" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-980', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-981" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-981', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> </tt>
+<a name="L2806"></a><tt class="py-lineno">2806</tt> <tt class="py-line"> <tt class="py-string">"Inconsistent responses for leader of Election-app:"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2807"></a><tt class="py-lineno">2807</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">n</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">leaderList</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2808"></a><tt class="py-lineno">2808</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-982" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-982', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-983" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-983', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">n</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" response: "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2809"></a><tt class="py-lineno">2809</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">leaderList</tt><tt class="py-op">[</tt> <tt class="py-name">n</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2810"></a><tt class="py-lineno">2810</tt> <tt class="py-line"> <tt class="py-name">leaderResult</tt> <tt class="py-op">=</tt> <tt class="py-name">leaderResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">consistentLeader</tt> </tt>
+<a name="L2811"></a><tt class="py-lineno">2811</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2812"></a><tt class="py-lineno">2812</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2813"></a><tt class="py-lineno">2813</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">leaderResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2814"></a><tt class="py-lineno">2814</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Leadership election passed"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2815"></a><tt class="py-lineno">2815</tt> <tt class="py-line"> <tt id="link-984" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-984', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something went wrong with Leadership election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2816"></a><tt class="py-lineno">2816</tt> <tt class="py-line"> </tt>
+<a name="L2817"></a><tt class="py-lineno">2817</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-985" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-985', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Run for election on old leader( just so everyone "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2818"></a><tt class="py-lineno">2818</tt> <tt class="py-line"> <tt class="py-string">"is in the hat )"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2819"></a><tt class="py-lineno">2819</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">oldLeader</tt><tt class="py-op">:</tt> </tt>
+<a name="L2820"></a><tt class="py-lineno">2820</tt> <tt class="py-line"> <tt class="py-name">runResult</tt> <tt class="py-op">=</tt> <tt class="py-name">oldLeader</tt><tt class="py-op">.</tt><tt id="link-986" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestRun" class="py-name" href="#" onclick="return doclink('link-986', 'electionTestRun', 'link-931');">electionTestRun</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2821"></a><tt class="py-lineno">2821</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2822"></a><tt class="py-lineno">2822</tt> <tt class="py-line"> <tt class="py-name">runResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2823"></a><tt class="py-lineno">2823</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2824"></a><tt class="py-lineno">2824</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2825"></a><tt class="py-lineno">2825</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">runResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2826"></a><tt class="py-lineno">2826</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"App re-ran for election"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2827"></a><tt class="py-lineno">2827</tt> <tt class="py-line"> <tt id="link-987" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-987', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"App failed to run for election"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2828"></a><tt class="py-lineno">2828</tt> <tt class="py-line"> </tt>
+<a name="L2829"></a><tt class="py-lineno">2829</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-988" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-988', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Leader did not change when old leader re-ran"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2830"></a><tt class="py-lineno">2830</tt> <tt class="py-line"> <tt class="py-name">afterRun</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-989" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.electionTestLeader" class="py-name" href="#" onclick="return doclink('link-989', 'electionTestLeader', 'link-705');">electionTestLeader</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2831"></a><tt class="py-lineno">2831</tt> <tt class="py-line"> <tt class="py-comment"># verify leader didn't just change</tt> </tt>
+<a name="L2832"></a><tt class="py-lineno">2832</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">afterRun</tt> <tt class="py-op">==</tt> <tt class="py-name">leaderList</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L2833"></a><tt class="py-lineno">2833</tt> <tt class="py-line"> <tt class="py-name">afterResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L2834"></a><tt class="py-lineno">2834</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L2835"></a><tt class="py-lineno">2835</tt> <tt class="py-line"> <tt class="py-name">afterResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L2836"></a><tt class="py-lineno">2836</tt> <tt class="py-line"> </tt>
+<a name="L2837"></a><tt class="py-lineno">2837</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> </tt>
+<a name="L2838"></a><tt class="py-lineno">2838</tt> <tt class="py-line"> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2839"></a><tt class="py-lineno">2839</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">afterResult</tt><tt class="py-op">,</tt> </tt>
+<a name="L2840"></a><tt class="py-lineno">2840</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Old leader successfully re-ran for election"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2841"></a><tt class="py-lineno">2841</tt> <tt class="py-line"> <tt id="link-990" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-990', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Something went wrong with Leadership election after "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2842"></a><tt class="py-lineno">2842</tt> <tt class="py-line"> <tt class="py-string">"the old leader re-ran for election"</tt> <tt class="py-op">)</tt> </tt>
+</div><a name="L2843"></a><tt class="py-lineno">2843</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE16"></a><div id="HAsanity.CASE16-def"><a name="L2844"></a><tt class="py-lineno">2844</tt> <a class="py-toggle" href="#" id="HAsanity.CASE16-toggle" onclick="return toggle('HAsanity.CASE16');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE16">CASE16</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE16-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE16-expanded"><a name="L2845"></a><tt class="py-lineno">2845</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2846"></a><tt class="py-lineno">2846</tt> <tt class="py-line"><tt class="py-docstring"> Install Distributed Primitives app</tt> </tt>
+<a name="L2847"></a><tt class="py-lineno">2847</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2848"></a><tt class="py-lineno">2848</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
+<a name="L2849"></a><tt class="py-lineno">2849</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2850"></a><tt class="py-lineno">2850</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2851"></a><tt class="py-lineno">2851</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2852"></a><tt class="py-lineno">2852</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2853"></a><tt class="py-lineno">2853</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-991" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-991', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2854"></a><tt class="py-lineno">2854</tt> <tt class="py-line"> </tt>
+<a name="L2855"></a><tt class="py-lineno">2855</tt> <tt class="py-line"> <tt class="py-comment"># Variables for the distributed primitives tests</tt> </tt>
+<a name="L2856"></a><tt class="py-lineno">2856</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">pCounterName</tt> </tt>
+<a name="L2857"></a><tt class="py-lineno">2857</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">iCounterName</tt> </tt>
+<a name="L2858"></a><tt class="py-lineno">2858</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">pCounterValue</tt> </tt>
+<a name="L2859"></a><tt class="py-lineno">2859</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">iCounterValue</tt> </tt>
+<a name="L2860"></a><tt class="py-lineno">2860</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">onosSet</tt> </tt>
+<a name="L2861"></a><tt class="py-lineno">2861</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">onosSetName</tt> </tt>
+<a name="L2862"></a><tt class="py-lineno">2862</tt> <tt class="py-line"> <tt class="py-name">pCounterName</tt> <tt class="py-op">=</tt> <tt class="py-string">"TestON-Partitions"</tt> </tt>
+<a name="L2863"></a><tt class="py-lineno">2863</tt> <tt class="py-line"> <tt class="py-name">iCounterName</tt> <tt class="py-op">=</tt> <tt class="py-string">"TestON-inMemory"</tt> </tt>
+<a name="L2864"></a><tt class="py-lineno">2864</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L2865"></a><tt class="py-lineno">2865</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L2866"></a><tt class="py-lineno">2866</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
+<a name="L2867"></a><tt class="py-lineno">2867</tt> <tt class="py-line"> <tt class="py-name">onosSetName</tt> <tt class="py-op">=</tt> <tt class="py-string">"TestON-set"</tt> </tt>
+<a name="L2868"></a><tt class="py-lineno">2868</tt> <tt class="py-line"> </tt>
+<a name="L2869"></a><tt class="py-lineno">2869</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Install Primitives app"</tt> </tt>
+<a name="L2870"></a><tt class="py-lineno">2870</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-992" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-992', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2871"></a><tt class="py-lineno">2871</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-993" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-993', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install Primitives app"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2872"></a><tt class="py-lineno">2872</tt> <tt class="py-line"> <tt class="py-name">appName</tt> <tt class="py-op">=</tt> <tt class="py-string">"org.onosproject.distributedprimitives"</tt> </tt>
+<a name="L2873"></a><tt class="py-lineno">2873</tt> <tt class="py-line"> <tt class="py-name">appResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-994" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.activateApp
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp" class="py-name" href="#" onclick="return doclink('link-994', 'activateApp', 'link-124');">activateApp</a></tt><tt class="py-op">(</tt> <tt class="py-name">appName</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2874"></a><tt class="py-lineno">2874</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2875"></a><tt class="py-lineno">2875</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">appResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2876"></a><tt class="py-lineno">2876</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Primitives app activated"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2877"></a><tt class="py-lineno">2877</tt> <tt class="py-line"> <tt id="link-995" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-995', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Primitives app not activated"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2878"></a><tt class="py-lineno">2878</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt> <tt class="py-number">5</tt> <tt class="py-op">)</tt> <tt class="py-comment"># To allow all nodes to activate</tt> </tt>
+</div><a name="L2879"></a><tt class="py-lineno">2879</tt> <tt class="py-line"> </tt>
+<a name="HAsanity.CASE17"></a><div id="HAsanity.CASE17-def"><a name="L2880"></a><tt class="py-lineno">2880</tt> <a class="py-toggle" href="#" id="HAsanity.CASE17-toggle" onclick="return toggle('HAsanity.CASE17');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.HAsanity.HAsanity.HAsanity-class.html#CASE17">CASE17</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">main</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+</div><div id="HAsanity.CASE17-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="HAsanity.CASE17-expanded"><a name="L2881"></a><tt class="py-lineno">2881</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
+<a name="L2882"></a><tt class="py-lineno">2882</tt> <tt class="py-line"><tt class="py-docstring"> Check for basic functionality with distributed primitives</tt> </tt>
+<a name="L2883"></a><tt class="py-lineno">2883</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
+<a name="L2884"></a><tt class="py-lineno">2884</tt> <tt class="py-line"> <tt class="py-comment"># Make sure variables are defined/set</tt> </tt>
+<a name="L2885"></a><tt class="py-lineno">2885</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt><tt class="py-op">,</tt> <tt class="py-string">"main.numCtrls not defined"</tt> </tt>
+<a name="L2886"></a><tt class="py-lineno">2886</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">,</tt> <tt class="py-string">"main not defined"</tt> </tt>
+<a name="L2887"></a><tt class="py-lineno">2887</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">,</tt> <tt class="py-string">"utilities.assert_equals not defined"</tt> </tt>
+<a name="L2888"></a><tt class="py-lineno">2888</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">,</tt> <tt class="py-string">"main.CLIs not defined"</tt> </tt>
+<a name="L2889"></a><tt class="py-lineno">2889</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-996" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.nodes
+TestON.drivers.common.cli.onosclidriver.OnosCliDriver.nodes" class="py-name" href="#" onclick="return doclink('link-996', 'nodes', 'link-9');">nodes</a></tt><tt class="py-op">,</tt> <tt class="py-string">"main.nodes not defined"</tt> </tt>
+<a name="L2890"></a><tt class="py-lineno">2890</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">pCounterName</tt><tt class="py-op">,</tt> <tt class="py-string">"pCounterName not defined"</tt> </tt>
+<a name="L2891"></a><tt class="py-lineno">2891</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">iCounterName</tt><tt class="py-op">,</tt> <tt class="py-string">"iCounterName not defined"</tt> </tt>
+<a name="L2892"></a><tt class="py-lineno">2892</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-string">"onosSetName not defined"</tt> </tt>
+<a name="L2893"></a><tt class="py-lineno">2893</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: assert fails if value is 0/None/Empty/False</tt> </tt>
+<a name="L2894"></a><tt class="py-lineno">2894</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2895"></a><tt class="py-lineno">2895</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> </tt>
+<a name="L2896"></a><tt class="py-lineno">2896</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">NameError</tt><tt class="py-op">:</tt> </tt>
+<a name="L2897"></a><tt class="py-lineno">2897</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-997" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-997', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-998" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-998', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"pCounterValue not defined, setting to 0"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2898"></a><tt class="py-lineno">2898</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L2899"></a><tt class="py-lineno">2899</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2900"></a><tt class="py-lineno">2900</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> </tt>
+<a name="L2901"></a><tt class="py-lineno">2901</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">NameError</tt><tt class="py-op">:</tt> </tt>
+<a name="L2902"></a><tt class="py-lineno">2902</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-999" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-999', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1000" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1000', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"iCounterValue not defined, setting to 0"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2903"></a><tt class="py-lineno">2903</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
+<a name="L2904"></a><tt class="py-lineno">2904</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L2905"></a><tt class="py-lineno">2905</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt> </tt>
+<a name="L2906"></a><tt class="py-lineno">2906</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">NameError</tt><tt class="py-op">:</tt> </tt>
+<a name="L2907"></a><tt class="py-lineno">2907</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1001" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1001', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1002" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1002', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onosSet not defined, setting to empty Set"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2908"></a><tt class="py-lineno">2908</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
+<a name="L2909"></a><tt class="py-lineno">2909</tt> <tt class="py-line"> <tt class="py-comment"># Variables for the distributed primitives tests. These are local only</tt> </tt>
+<a name="L2910"></a><tt class="py-lineno">2910</tt> <tt class="py-line"> <tt class="py-name">addValue</tt> <tt class="py-op">=</tt> <tt class="py-string">"a"</tt> </tt>
+<a name="L2911"></a><tt class="py-lineno">2911</tt> <tt class="py-line"> <tt class="py-name">addAllValue</tt> <tt class="py-op">=</tt> <tt class="py-string">"a b c d e f"</tt> </tt>
+<a name="L2912"></a><tt class="py-lineno">2912</tt> <tt class="py-line"> <tt class="py-name">retainValue</tt> <tt class="py-op">=</tt> <tt class="py-string">"c d e f"</tt> </tt>
+<a name="L2913"></a><tt class="py-lineno">2913</tt> <tt class="py-line"> </tt>
+<a name="L2914"></a><tt class="py-lineno">2914</tt> <tt class="py-line"> <tt class="py-name">description</tt> <tt class="py-op">=</tt> <tt class="py-string">"Check for basic functionality with distributed "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L2915"></a><tt class="py-lineno">2915</tt> <tt class="py-line"> <tt class="py-string">"primitives"</tt> </tt>
+<a name="L2916"></a><tt class="py-lineno">2916</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1003" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-1003', 'case', 'link-2');">case</a></tt><tt class="py-op">(</tt> <tt class="py-name">description</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2917"></a><tt class="py-lineno">2917</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">caseExplanation</tt> <tt class="py-op">=</tt> <tt class="py-string">"Test the methods of the distributed "</tt> <tt class="py-op">+</tt>\ </tt>
+<a name="L2918"></a><tt class="py-lineno">2918</tt> <tt class="py-line"> <tt class="py-string">"primitives (counters and sets) throught the cli"</tt> </tt>
+<a name="L2919"></a><tt class="py-lineno">2919</tt> <tt class="py-line"> <tt class="py-comment"># DISTRIBUTED ATOMIC COUNTERS</tt> </tt>
+<a name="L2920"></a><tt class="py-lineno">2920</tt> <tt class="py-line"> <tt class="py-comment"># Partitioned counters</tt> </tt>
+<a name="L2921"></a><tt class="py-lineno">2921</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1004" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1004', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Increment then get a default counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2922"></a><tt class="py-lineno">2922</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2923"></a><tt class="py-lineno">2923</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2924"></a><tt class="py-lineno">2924</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2925"></a><tt class="py-lineno">2925</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2926"></a><tt class="py-lineno">2926</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1005" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1005', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1006" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#counterTestAddAndGet"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet" class="py-name" href="#" onclick="return doclink('link-1006', 'counterTestAddAndGet', 'link-1006');">counterTestAddAndGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2927"></a><tt class="py-lineno">2927</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterAddAndGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2928"></a><tt class="py-lineno">2928</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">pCounterName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2929"></a><tt class="py-lineno">2929</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L2930"></a><tt class="py-lineno">2930</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2931"></a><tt class="py-lineno">2931</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2932"></a><tt class="py-lineno">2932</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2933"></a><tt class="py-lineno">2933</tt> <tt class="py-line"> </tt>
+<a name="L2934"></a><tt class="py-lineno">2934</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2935"></a><tt class="py-lineno">2935</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2936"></a><tt class="py-lineno">2936</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2937"></a><tt class="py-lineno">2937</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L2938"></a><tt class="py-lineno">2938</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L2939"></a><tt class="py-lineno">2939</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedPValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L2940"></a><tt class="py-lineno">2940</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pCounters</tt> </tt>
+<a name="L2941"></a><tt class="py-lineno">2941</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">pCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L2942"></a><tt class="py-lineno">2942</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L2943"></a><tt class="py-lineno">2943</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1007" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1007', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1008" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1008', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in partitioned "</tt> </tt>
+<a name="L2944"></a><tt class="py-lineno">2944</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2945"></a><tt class="py-lineno">2945</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L2946"></a><tt class="py-lineno">2946</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2947"></a><tt class="py-lineno">2947</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Default counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2948"></a><tt class="py-lineno">2948</tt> <tt class="py-line"> <tt id="link-1009" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1009', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing default"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2949"></a><tt class="py-lineno">2949</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2950"></a><tt class="py-lineno">2950</tt> <tt class="py-line"> </tt>
+<a name="L2951"></a><tt class="py-lineno">2951</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1010" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1010', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get then Increment a default counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2952"></a><tt class="py-lineno">2952</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2953"></a><tt class="py-lineno">2953</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2954"></a><tt class="py-lineno">2954</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2955"></a><tt class="py-lineno">2955</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2956"></a><tt class="py-lineno">2956</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1011" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1011', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1012" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestGetAndAdd()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#counterTestGetAndAdd"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestGetAndAdd" class="py-name" href="#" onclick="return doclink('link-1012', 'counterTestGetAndAdd', 'link-1012');">counterTestGetAndAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2957"></a><tt class="py-lineno">2957</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterGetAndAdd-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2958"></a><tt class="py-lineno">2958</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">pCounterName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2959"></a><tt class="py-lineno">2959</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2960"></a><tt class="py-lineno">2960</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L2961"></a><tt class="py-lineno">2961</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2962"></a><tt class="py-lineno">2962</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2963"></a><tt class="py-lineno">2963</tt> <tt class="py-line"> </tt>
+<a name="L2964"></a><tt class="py-lineno">2964</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L2965"></a><tt class="py-lineno">2965</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L2966"></a><tt class="py-lineno">2966</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2967"></a><tt class="py-lineno">2967</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L2968"></a><tt class="py-lineno">2968</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L2969"></a><tt class="py-lineno">2969</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedPValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L2970"></a><tt class="py-lineno">2970</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pCounters</tt> </tt>
+<a name="L2971"></a><tt class="py-lineno">2971</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">pCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L2972"></a><tt class="py-lineno">2972</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L2973"></a><tt class="py-lineno">2973</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1013" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1013', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1014" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1014', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in partitioned "</tt> </tt>
+<a name="L2974"></a><tt class="py-lineno">2974</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2975"></a><tt class="py-lineno">2975</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L2976"></a><tt class="py-lineno">2976</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L2977"></a><tt class="py-lineno">2977</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Default counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2978"></a><tt class="py-lineno">2978</tt> <tt class="py-line"> <tt id="link-1015" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1015', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing default"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L2979"></a><tt class="py-lineno">2979</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2980"></a><tt class="py-lineno">2980</tt> <tt class="py-line"> </tt>
+<a name="L2981"></a><tt class="py-lineno">2981</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1016" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1016', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Counters we added have the correct values"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2982"></a><tt class="py-lineno">2982</tt> <tt class="py-line"> <tt class="py-name">incrementCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1017" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-1017', 'Counters', 'link-4');">Counters</a></tt><tt class="py-op">.</tt><tt id="link-1018" class="py-name" targets="Function TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck()=TestON.tests.HAclusterRestart.dependencies.Counters-module.html#counterCheck,Function TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck()=TestON.tests.HAminorityRestart.dependencies.Counters-module.html#counterCheck,Function TestON.tests.HAsanity.dependencies.Counters.counterCheck()=TestON.tests.HAsanity.dependencies.Counters-module.html#counterCheck,Function TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck()=TestON.tests.HAsingleInstanceRestart.dependencies.Counters-module.html#counterCheck"><a title="TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck
+TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck
+TestON.tests.HAsanity.dependencies.Counters.counterCheck
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck" class="py-name" href="#" onclick="return doclink('link-1018', 'counterCheck', 'link-1018');">counterCheck</a></tt><tt class="py-op">(</tt> <tt class="py-name">pCounterName</tt><tt class="py-op">,</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2983"></a><tt class="py-lineno">2983</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L2984"></a><tt class="py-lineno">2984</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">incrementCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L2985"></a><tt class="py-lineno">2985</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L2986"></a><tt class="py-lineno">2986</tt> <tt class="py-line"> <tt id="link-1019" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1019', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2987"></a><tt class="py-lineno">2987</tt> <tt class="py-line"> </tt>
+<a name="L2988"></a><tt class="py-lineno">2988</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1020" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1020', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add -8 to then get a default counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2989"></a><tt class="py-lineno">2989</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2990"></a><tt class="py-lineno">2990</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2991"></a><tt class="py-lineno">2991</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L2992"></a><tt class="py-lineno">2992</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L2993"></a><tt class="py-lineno">2993</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1021" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1021', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1022" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet" class="py-name" href="#" onclick="return doclink('link-1022', 'counterTestAddAndGet', 'link-1006');">counterTestAddAndGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L2994"></a><tt class="py-lineno">2994</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L2995"></a><tt class="py-lineno">2995</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">pCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L2996"></a><tt class="py-lineno">2996</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"delta"</tt><tt class="py-op">:</tt> <tt class="py-op">-</tt><tt class="py-number">8</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2997"></a><tt class="py-lineno">2997</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-op">-</tt><tt class="py-number">8</tt> </tt>
+<a name="L2998"></a><tt class="py-lineno">2998</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L2999"></a><tt class="py-lineno">2999</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3000"></a><tt class="py-lineno">3000</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3001"></a><tt class="py-lineno">3001</tt> <tt class="py-line"> </tt>
+<a name="L3002"></a><tt class="py-lineno">3002</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3003"></a><tt class="py-lineno">3003</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3004"></a><tt class="py-lineno">3004</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3005"></a><tt class="py-lineno">3005</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3006"></a><tt class="py-lineno">3006</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3007"></a><tt class="py-lineno">3007</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedPValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3008"></a><tt class="py-lineno">3008</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pCounters</tt> </tt>
+<a name="L3009"></a><tt class="py-lineno">3009</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">pCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3010"></a><tt class="py-lineno">3010</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3011"></a><tt class="py-lineno">3011</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1023" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1023', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1024" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1024', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in partitioned "</tt> </tt>
+<a name="L3012"></a><tt class="py-lineno">3012</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3013"></a><tt class="py-lineno">3013</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3014"></a><tt class="py-lineno">3014</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3015"></a><tt class="py-lineno">3015</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Default counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3016"></a><tt class="py-lineno">3016</tt> <tt class="py-line"> <tt id="link-1025" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1025', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing default"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3017"></a><tt class="py-lineno">3017</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3018"></a><tt class="py-lineno">3018</tt> <tt class="py-line"> </tt>
+<a name="L3019"></a><tt class="py-lineno">3019</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1026" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1026', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add 5 to then get a default counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3020"></a><tt class="py-lineno">3020</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3021"></a><tt class="py-lineno">3021</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3022"></a><tt class="py-lineno">3022</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3023"></a><tt class="py-lineno">3023</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3024"></a><tt class="py-lineno">3024</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1027" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1027', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1028" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet" class="py-name" href="#" onclick="return doclink('link-1028', 'counterTestAddAndGet', 'link-1006');">counterTestAddAndGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3025"></a><tt class="py-lineno">3025</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3026"></a><tt class="py-lineno">3026</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">pCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3027"></a><tt class="py-lineno">3027</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"delta"</tt><tt class="py-op">:</tt> <tt class="py-number">5</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3028"></a><tt class="py-lineno">3028</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">5</tt> </tt>
+<a name="L3029"></a><tt class="py-lineno">3029</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3030"></a><tt class="py-lineno">3030</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3031"></a><tt class="py-lineno">3031</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3032"></a><tt class="py-lineno">3032</tt> <tt class="py-line"> </tt>
+<a name="L3033"></a><tt class="py-lineno">3033</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3034"></a><tt class="py-lineno">3034</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3035"></a><tt class="py-lineno">3035</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3036"></a><tt class="py-lineno">3036</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3037"></a><tt class="py-lineno">3037</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3038"></a><tt class="py-lineno">3038</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedPValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3039"></a><tt class="py-lineno">3039</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pCounters</tt> </tt>
+<a name="L3040"></a><tt class="py-lineno">3040</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">pCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3041"></a><tt class="py-lineno">3041</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3042"></a><tt class="py-lineno">3042</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1029" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1029', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1030" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1030', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in partitioned "</tt> </tt>
+<a name="L3043"></a><tt class="py-lineno">3043</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3044"></a><tt class="py-lineno">3044</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3045"></a><tt class="py-lineno">3045</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3046"></a><tt class="py-lineno">3046</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Default counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3047"></a><tt class="py-lineno">3047</tt> <tt class="py-line"> <tt id="link-1031" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1031', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing default"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3048"></a><tt class="py-lineno">3048</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3049"></a><tt class="py-lineno">3049</tt> <tt class="py-line"> </tt>
+<a name="L3050"></a><tt class="py-lineno">3050</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1032" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1032', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get then add 5 to a default counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3051"></a><tt class="py-lineno">3051</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3052"></a><tt class="py-lineno">3052</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3053"></a><tt class="py-lineno">3053</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3054"></a><tt class="py-lineno">3054</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3055"></a><tt class="py-lineno">3055</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1033" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1033', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1034" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestGetAndAdd" class="py-name" href="#" onclick="return doclink('link-1034', 'counterTestGetAndAdd', 'link-1012');">counterTestGetAndAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3056"></a><tt class="py-lineno">3056</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3057"></a><tt class="py-lineno">3057</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">pCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3058"></a><tt class="py-lineno">3058</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"delta"</tt><tt class="py-op">:</tt> <tt class="py-number">5</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3059"></a><tt class="py-lineno">3059</tt> <tt class="py-line"> <tt class="py-name">addedPValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3060"></a><tt class="py-lineno">3060</tt> <tt class="py-line"> <tt class="py-name">pCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">5</tt> </tt>
+<a name="L3061"></a><tt class="py-lineno">3061</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3062"></a><tt class="py-lineno">3062</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3063"></a><tt class="py-lineno">3063</tt> <tt class="py-line"> </tt>
+<a name="L3064"></a><tt class="py-lineno">3064</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3065"></a><tt class="py-lineno">3065</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3066"></a><tt class="py-lineno">3066</tt> <tt class="py-line"> <tt class="py-name">pCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3067"></a><tt class="py-lineno">3067</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3068"></a><tt class="py-lineno">3068</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3069"></a><tt class="py-lineno">3069</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedPValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3070"></a><tt class="py-lineno">3070</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pCounters</tt> </tt>
+<a name="L3071"></a><tt class="py-lineno">3071</tt> <tt class="py-line"> <tt class="py-name">pCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">pCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3072"></a><tt class="py-lineno">3072</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3073"></a><tt class="py-lineno">3073</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1035" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1035', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1036" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1036', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in partitioned "</tt> </tt>
+<a name="L3074"></a><tt class="py-lineno">3074</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3075"></a><tt class="py-lineno">3075</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3076"></a><tt class="py-lineno">3076</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3077"></a><tt class="py-lineno">3077</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Default counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3078"></a><tt class="py-lineno">3078</tt> <tt class="py-line"> <tt id="link-1037" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1037', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing default"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3079"></a><tt class="py-lineno">3079</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3080"></a><tt class="py-lineno">3080</tt> <tt class="py-line"> </tt>
+<a name="L3081"></a><tt class="py-lineno">3081</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1038" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1038', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Counters we added have the correct values"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3082"></a><tt class="py-lineno">3082</tt> <tt class="py-line"> <tt class="py-name">incrementCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1039" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-1039', 'Counters', 'link-4');">Counters</a></tt><tt class="py-op">.</tt><tt id="link-1040" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck
+TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck
+TestON.tests.HAsanity.dependencies.Counters.counterCheck
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck" class="py-name" href="#" onclick="return doclink('link-1040', 'counterCheck', 'link-1018');">counterCheck</a></tt><tt class="py-op">(</tt> <tt class="py-name">pCounterName</tt><tt class="py-op">,</tt> <tt class="py-name">pCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3083"></a><tt class="py-lineno">3083</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3084"></a><tt class="py-lineno">3084</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">incrementCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L3085"></a><tt class="py-lineno">3085</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3086"></a><tt class="py-lineno">3086</tt> <tt class="py-line"> <tt id="link-1041" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1041', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3087"></a><tt class="py-lineno">3087</tt> <tt class="py-line"> </tt>
+<a name="L3088"></a><tt class="py-lineno">3088</tt> <tt class="py-line"> <tt class="py-comment"># In-Memory counters</tt> </tt>
+<a name="L3089"></a><tt class="py-lineno">3089</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1042" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1042', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Increment and get an in-memory counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3090"></a><tt class="py-lineno">3090</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3091"></a><tt class="py-lineno">3091</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3092"></a><tt class="py-lineno">3092</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3093"></a><tt class="py-lineno">3093</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3094"></a><tt class="py-lineno">3094</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1043" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1043', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1044" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet" class="py-name" href="#" onclick="return doclink('link-1044', 'counterTestAddAndGet', 'link-1006');">counterTestAddAndGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3095"></a><tt class="py-lineno">3095</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"icounterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3096"></a><tt class="py-lineno">3096</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">iCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3097"></a><tt class="py-lineno">3097</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"inMemory"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3098"></a><tt class="py-lineno">3098</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L3099"></a><tt class="py-lineno">3099</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3100"></a><tt class="py-lineno">3100</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3101"></a><tt class="py-lineno">3101</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3102"></a><tt class="py-lineno">3102</tt> <tt class="py-line"> </tt>
+<a name="L3103"></a><tt class="py-lineno">3103</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3104"></a><tt class="py-lineno">3104</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3105"></a><tt class="py-lineno">3105</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3106"></a><tt class="py-lineno">3106</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3107"></a><tt class="py-lineno">3107</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3108"></a><tt class="py-lineno">3108</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedIValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3109"></a><tt class="py-lineno">3109</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iCounters</tt> </tt>
+<a name="L3110"></a><tt class="py-lineno">3110</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">iCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3111"></a><tt class="py-lineno">3111</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3112"></a><tt class="py-lineno">3112</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1045" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1045', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1046" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1046', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in the in-memory "</tt> </tt>
+<a name="L3113"></a><tt class="py-lineno">3113</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3114"></a><tt class="py-lineno">3114</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3115"></a><tt class="py-lineno">3115</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">iCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3116"></a><tt class="py-lineno">3116</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"In-memory counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3117"></a><tt class="py-lineno">3117</tt> <tt class="py-line"> <tt id="link-1047" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1047', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing in-memory"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3118"></a><tt class="py-lineno">3118</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3119"></a><tt class="py-lineno">3119</tt> <tt class="py-line"> </tt>
+<a name="L3120"></a><tt class="py-lineno">3120</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1048" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1048', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get then Increment a in-memory counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3121"></a><tt class="py-lineno">3121</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3122"></a><tt class="py-lineno">3122</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3123"></a><tt class="py-lineno">3123</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3124"></a><tt class="py-lineno">3124</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3125"></a><tt class="py-lineno">3125</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1049" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1049', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1050" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestGetAndAdd" class="py-name" href="#" onclick="return doclink('link-1050', 'counterTestGetAndAdd', 'link-1012');">counterTestGetAndAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3126"></a><tt class="py-lineno">3126</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterGetAndAdd-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3127"></a><tt class="py-lineno">3127</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">iCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3128"></a><tt class="py-lineno">3128</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"inMemory"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3129"></a><tt class="py-lineno">3129</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3130"></a><tt class="py-lineno">3130</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
+<a name="L3131"></a><tt class="py-lineno">3131</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3132"></a><tt class="py-lineno">3132</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3133"></a><tt class="py-lineno">3133</tt> <tt class="py-line"> </tt>
+<a name="L3134"></a><tt class="py-lineno">3134</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3135"></a><tt class="py-lineno">3135</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3136"></a><tt class="py-lineno">3136</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3137"></a><tt class="py-lineno">3137</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3138"></a><tt class="py-lineno">3138</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3139"></a><tt class="py-lineno">3139</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedIValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3140"></a><tt class="py-lineno">3140</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iCounters</tt> </tt>
+<a name="L3141"></a><tt class="py-lineno">3141</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">iCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3142"></a><tt class="py-lineno">3142</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3143"></a><tt class="py-lineno">3143</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1051" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1051', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1052" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1052', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in in-memory "</tt> </tt>
+<a name="L3144"></a><tt class="py-lineno">3144</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3145"></a><tt class="py-lineno">3145</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3146"></a><tt class="py-lineno">3146</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">iCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3147"></a><tt class="py-lineno">3147</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"In-memory counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3148"></a><tt class="py-lineno">3148</tt> <tt class="py-line"> <tt id="link-1053" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1053', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing in-memory"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3149"></a><tt class="py-lineno">3149</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3150"></a><tt class="py-lineno">3150</tt> <tt class="py-line"> </tt>
+<a name="L3151"></a><tt class="py-lineno">3151</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1054" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1054', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Counters we added have the correct values"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3152"></a><tt class="py-lineno">3152</tt> <tt class="py-line"> <tt class="py-name">incrementCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1055" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-1055', 'Counters', 'link-4');">Counters</a></tt><tt class="py-op">.</tt><tt id="link-1056" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck
+TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck
+TestON.tests.HAsanity.dependencies.Counters.counterCheck
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck" class="py-name" href="#" onclick="return doclink('link-1056', 'counterCheck', 'link-1018');">counterCheck</a></tt><tt class="py-op">(</tt> <tt class="py-name">iCounterName</tt><tt class="py-op">,</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3153"></a><tt class="py-lineno">3153</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3154"></a><tt class="py-lineno">3154</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">incrementCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L3155"></a><tt class="py-lineno">3155</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3156"></a><tt class="py-lineno">3156</tt> <tt class="py-line"> <tt id="link-1057" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1057', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3157"></a><tt class="py-lineno">3157</tt> <tt class="py-line"> </tt>
+<a name="L3158"></a><tt class="py-lineno">3158</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1058" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1058', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add -8 to then get a in-memory counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3159"></a><tt class="py-lineno">3159</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3160"></a><tt class="py-lineno">3160</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3161"></a><tt class="py-lineno">3161</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3162"></a><tt class="py-lineno">3162</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3163"></a><tt class="py-lineno">3163</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1059" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1059', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1060" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet" class="py-name" href="#" onclick="return doclink('link-1060', 'counterTestAddAndGet', 'link-1006');">counterTestAddAndGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3164"></a><tt class="py-lineno">3164</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3165"></a><tt class="py-lineno">3165</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">iCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3166"></a><tt class="py-lineno">3166</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"delta"</tt><tt class="py-op">:</tt> <tt class="py-op">-</tt><tt class="py-number">8</tt><tt class="py-op">,</tt> <tt class="py-string">"inMemory"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3167"></a><tt class="py-lineno">3167</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-op">-</tt><tt class="py-number">8</tt> </tt>
+<a name="L3168"></a><tt class="py-lineno">3168</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3169"></a><tt class="py-lineno">3169</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3170"></a><tt class="py-lineno">3170</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3171"></a><tt class="py-lineno">3171</tt> <tt class="py-line"> </tt>
+<a name="L3172"></a><tt class="py-lineno">3172</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3173"></a><tt class="py-lineno">3173</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3174"></a><tt class="py-lineno">3174</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3175"></a><tt class="py-lineno">3175</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3176"></a><tt class="py-lineno">3176</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3177"></a><tt class="py-lineno">3177</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedIValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3178"></a><tt class="py-lineno">3178</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iCounters</tt> </tt>
+<a name="L3179"></a><tt class="py-lineno">3179</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">iCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3180"></a><tt class="py-lineno">3180</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3181"></a><tt class="py-lineno">3181</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1061" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1061', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1062" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1062', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in in-memory "</tt> </tt>
+<a name="L3182"></a><tt class="py-lineno">3182</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3183"></a><tt class="py-lineno">3183</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3184"></a><tt class="py-lineno">3184</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3185"></a><tt class="py-lineno">3185</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"In-memory counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3186"></a><tt class="py-lineno">3186</tt> <tt class="py-line"> <tt id="link-1063" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1063', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing in-memory"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3187"></a><tt class="py-lineno">3187</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3188"></a><tt class="py-lineno">3188</tt> <tt class="py-line"> </tt>
+<a name="L3189"></a><tt class="py-lineno">3189</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1064" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1064', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add 5 to then get a in-memory counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3190"></a><tt class="py-lineno">3190</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3191"></a><tt class="py-lineno">3191</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3192"></a><tt class="py-lineno">3192</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3193"></a><tt class="py-lineno">3193</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3194"></a><tt class="py-lineno">3194</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1065" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1065', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1066" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestAddAndGet" class="py-name" href="#" onclick="return doclink('link-1066', 'counterTestAddAndGet', 'link-1006');">counterTestAddAndGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3195"></a><tt class="py-lineno">3195</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3196"></a><tt class="py-lineno">3196</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">iCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3197"></a><tt class="py-lineno">3197</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"delta"</tt><tt class="py-op">:</tt> <tt class="py-number">5</tt><tt class="py-op">,</tt> <tt class="py-string">"inMemory"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3198"></a><tt class="py-lineno">3198</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">5</tt> </tt>
+<a name="L3199"></a><tt class="py-lineno">3199</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3200"></a><tt class="py-lineno">3200</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3201"></a><tt class="py-lineno">3201</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3202"></a><tt class="py-lineno">3202</tt> <tt class="py-line"> </tt>
+<a name="L3203"></a><tt class="py-lineno">3203</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3204"></a><tt class="py-lineno">3204</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3205"></a><tt class="py-lineno">3205</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3206"></a><tt class="py-lineno">3206</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3207"></a><tt class="py-lineno">3207</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3208"></a><tt class="py-lineno">3208</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedIValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3209"></a><tt class="py-lineno">3209</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iCounters</tt> </tt>
+<a name="L3210"></a><tt class="py-lineno">3210</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">iCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3211"></a><tt class="py-lineno">3211</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3212"></a><tt class="py-lineno">3212</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1067" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1067', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1068" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1068', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in in-memory "</tt> </tt>
+<a name="L3213"></a><tt class="py-lineno">3213</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3214"></a><tt class="py-lineno">3214</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3215"></a><tt class="py-lineno">3215</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">pCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3216"></a><tt class="py-lineno">3216</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"In-memory counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3217"></a><tt class="py-lineno">3217</tt> <tt class="py-line"> <tt id="link-1069" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1069', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing in-memory"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3218"></a><tt class="py-lineno">3218</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3219"></a><tt class="py-lineno">3219</tt> <tt class="py-line"> </tt>
+<a name="L3220"></a><tt class="py-lineno">3220</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1070" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1070', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Get then add 5 to a in-memory counter on each node"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3221"></a><tt class="py-lineno">3221</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3222"></a><tt class="py-lineno">3222</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3223"></a><tt class="py-lineno">3223</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3224"></a><tt class="py-lineno">3224</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3225"></a><tt class="py-lineno">3225</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1071" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1071', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1072" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counterTestGetAndAdd" class="py-name" href="#" onclick="return doclink('link-1072', 'counterTestGetAndAdd', 'link-1012');">counterTestGetAndAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3226"></a><tt class="py-lineno">3226</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counterIncrement-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3227"></a><tt class="py-lineno">3227</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">iCounterName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3228"></a><tt class="py-lineno">3228</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"delta"</tt><tt class="py-op">:</tt> <tt class="py-number">5</tt><tt class="py-op">,</tt> <tt class="py-string">"inMemory"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3229"></a><tt class="py-lineno">3229</tt> <tt class="py-line"> <tt class="py-name">addedIValues</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3230"></a><tt class="py-lineno">3230</tt> <tt class="py-line"> <tt class="py-name">iCounterValue</tt> <tt class="py-op">+=</tt> <tt class="py-number">5</tt> </tt>
+<a name="L3231"></a><tt class="py-lineno">3231</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3232"></a><tt class="py-lineno">3232</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3233"></a><tt class="py-lineno">3233</tt> <tt class="py-line"> </tt>
+<a name="L3234"></a><tt class="py-lineno">3234</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3235"></a><tt class="py-lineno">3235</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3236"></a><tt class="py-lineno">3236</tt> <tt class="py-line"> <tt class="py-name">iCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3237"></a><tt class="py-lineno">3237</tt> <tt class="py-line"> <tt class="py-comment"># Check that counter incremented numController times</tt> </tt>
+<a name="L3238"></a><tt class="py-lineno">3238</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
+<a name="L3239"></a><tt class="py-lineno">3239</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">addedIValues</tt><tt class="py-op">:</tt> </tt>
+<a name="L3240"></a><tt class="py-lineno">3240</tt> <tt class="py-line"> <tt class="py-name">tmpResult</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iCounters</tt> </tt>
+<a name="L3241"></a><tt class="py-lineno">3241</tt> <tt class="py-line"> <tt class="py-name">iCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">iCounterResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tmpResult</tt> </tt>
+<a name="L3242"></a><tt class="py-lineno">3242</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tmpResult</tt><tt class="py-op">:</tt> </tt>
+<a name="L3243"></a><tt class="py-lineno">3243</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1073" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1073', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1074" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1074', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" is not in in-memory "</tt> </tt>
+<a name="L3244"></a><tt class="py-lineno">3244</tt> <tt class="py-line"> <tt class="py-string">"counter incremented results"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3245"></a><tt class="py-lineno">3245</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
+<a name="L3246"></a><tt class="py-lineno">3246</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">iCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3247"></a><tt class="py-lineno">3247</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"In-memory counter incremented"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3248"></a><tt class="py-lineno">3248</tt> <tt class="py-line"> <tt id="link-1075" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1075', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Error incrementing in-memory"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3249"></a><tt class="py-lineno">3249</tt> <tt class="py-line"> <tt class="py-string">" counter"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3250"></a><tt class="py-lineno">3250</tt> <tt class="py-line"> </tt>
+<a name="L3251"></a><tt class="py-lineno">3251</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1076" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1076', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Counters we added have the correct values"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3252"></a><tt class="py-lineno">3252</tt> <tt class="py-line"> <tt class="py-name">incrementCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1077" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-1077', 'Counters', 'link-4');">Counters</a></tt><tt class="py-op">.</tt><tt id="link-1078" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck
+TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck
+TestON.tests.HAsanity.dependencies.Counters.counterCheck
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck" class="py-name" href="#" onclick="return doclink('link-1078', 'counterCheck', 'link-1018');">counterCheck</a></tt><tt class="py-op">(</tt> <tt class="py-name">iCounterName</tt><tt class="py-op">,</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3253"></a><tt class="py-lineno">3253</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3254"></a><tt class="py-lineno">3254</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">incrementCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L3255"></a><tt class="py-lineno">3255</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3256"></a><tt class="py-lineno">3256</tt> <tt class="py-line"> <tt id="link-1079" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1079', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3257"></a><tt class="py-lineno">3257</tt> <tt class="py-line"> </tt>
+<a name="L3258"></a><tt class="py-lineno">3258</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1080" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1080', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Check counters are consistant across nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3259"></a><tt class="py-lineno">3259</tt> <tt class="py-line"> <tt class="py-name">onosCounters</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3260"></a><tt class="py-lineno">3260</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3261"></a><tt class="py-lineno">3261</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3262"></a><tt class="py-lineno">3262</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1081" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1081', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1082" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counters()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#counters"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.counters" class="py-name" href="#" onclick="return doclink('link-1082', 'counters', 'link-1082');">counters</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3263"></a><tt class="py-lineno">3263</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"counters-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3264"></a><tt class="py-lineno">3264</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3265"></a><tt class="py-lineno">3265</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3266"></a><tt class="py-lineno">3266</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3267"></a><tt class="py-lineno">3267</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3268"></a><tt class="py-lineno">3268</tt> <tt class="py-line"> <tt class="py-name">onosCounters</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3269"></a><tt class="py-lineno">3269</tt> <tt class="py-line"> <tt class="py-name">tmp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-name">onosCounters</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">onosCounters</tt> <tt class="py-op">]</tt> </tt>
+<a name="L3270"></a><tt class="py-lineno">3270</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt> <tt class="py-name">tmp</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3271"></a><tt class="py-lineno">3271</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1083" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1083', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Counters are consistent across all nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3272"></a><tt class="py-lineno">3272</tt> <tt class="py-line"> <tt class="py-name">consistentCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3273"></a><tt class="py-lineno">3273</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3274"></a><tt class="py-lineno">3274</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1084" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1084', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1085" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1085', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Counters are not consistent across all nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3275"></a><tt class="py-lineno">3275</tt> <tt class="py-line"> <tt class="py-name">consistentCounterResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3276"></a><tt class="py-lineno">3276</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3277"></a><tt class="py-lineno">3277</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">consistentCounterResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3278"></a><tt class="py-lineno">3278</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"ONOS counters are consistent "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3279"></a><tt class="py-lineno">3279</tt> <tt class="py-line"> <tt class="py-string">"across nodes"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3280"></a><tt class="py-lineno">3280</tt> <tt class="py-line"> <tt id="link-1086" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1086', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"ONOS Counters are inconsistent "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3281"></a><tt class="py-lineno">3281</tt> <tt class="py-line"> <tt class="py-string">"across nodes"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3282"></a><tt class="py-lineno">3282</tt> <tt class="py-line"> </tt>
+<a name="L3283"></a><tt class="py-lineno">3283</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1087" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1087', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Counters we added have the correct values"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3284"></a><tt class="py-lineno">3284</tt> <tt class="py-line"> <tt class="py-name">incrementCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1088" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-1088', 'Counters', 'link-4');">Counters</a></tt><tt class="py-op">.</tt><tt id="link-1089" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck
+TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck
+TestON.tests.HAsanity.dependencies.Counters.counterCheck
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck" class="py-name" href="#" onclick="return doclink('link-1089', 'counterCheck', 'link-1018');">counterCheck</a></tt><tt class="py-op">(</tt> <tt class="py-name">iCounterName</tt><tt class="py-op">,</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3285"></a><tt class="py-lineno">3285</tt> <tt class="py-line"> <tt class="py-name">incrementCheck</tt> <tt class="py-op">=</tt> <tt class="py-name">incrementCheck</tt> <tt class="py-keyword">and</tt> \ </tt>
+<a name="L3286"></a><tt class="py-lineno">3286</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1090" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters
+TestON.tests.HAminorityRestart.dependencies.Counters
+TestON.tests.HAsanity.dependencies.Counters
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters" class="py-name" href="#" onclick="return doclink('link-1090', 'Counters', 'link-4');">Counters</a></tt><tt class="py-op">.</tt><tt id="link-1091" class="py-name"><a title="TestON.tests.HAclusterRestart.dependencies.Counters.counterCheck
+TestON.tests.HAminorityRestart.dependencies.Counters.counterCheck
+TestON.tests.HAsanity.dependencies.Counters.counterCheck
+TestON.tests.HAsingleInstanceRestart.dependencies.Counters.counterCheck" class="py-name" href="#" onclick="return doclink('link-1091', 'counterCheck', 'link-1018');">counterCheck</a></tt><tt class="py-op">(</tt> <tt class="py-name">iCounterName</tt><tt class="py-op">,</tt> <tt class="py-name">iCounterValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3287"></a><tt class="py-lineno">3287</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3288"></a><tt class="py-lineno">3288</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">incrementCheck</tt><tt class="py-op">,</tt> </tt>
+<a name="L3289"></a><tt class="py-lineno">3289</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3290"></a><tt class="py-lineno">3290</tt> <tt class="py-line"> <tt id="link-1092" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1092', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Added counters are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3291"></a><tt class="py-lineno">3291</tt> <tt class="py-line"> </tt>
+<a name="L3292"></a><tt class="py-lineno">3292</tt> <tt class="py-line"> <tt class="py-comment"># DISTRIBUTED SETS</tt> </tt>
+<a name="L3293"></a><tt class="py-lineno">3293</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1093" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1093', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set get"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3294"></a><tt class="py-lineno">3294</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3295"></a><tt class="py-lineno">3295</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3296"></a><tt class="py-lineno">3296</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3297"></a><tt class="py-lineno">3297</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3298"></a><tt class="py-lineno">3298</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1094" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1094', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1095" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#setTestGet"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1095', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3299"></a><tt class="py-lineno">3299</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3300"></a><tt class="py-lineno">3300</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3301"></a><tt class="py-lineno">3301</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3302"></a><tt class="py-lineno">3302</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3303"></a><tt class="py-lineno">3303</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3304"></a><tt class="py-lineno">3304</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3305"></a><tt class="py-lineno">3305</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3306"></a><tt class="py-lineno">3306</tt> <tt class="py-line"> </tt>
+<a name="L3307"></a><tt class="py-lineno">3307</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3308"></a><tt class="py-lineno">3308</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3309"></a><tt class="py-lineno">3309</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3310"></a><tt class="py-lineno">3310</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3311"></a><tt class="py-lineno">3311</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3312"></a><tt class="py-lineno">3312</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3313"></a><tt class="py-lineno">3313</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3314"></a><tt class="py-lineno">3314</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1096" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1096', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1097" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1097', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3315"></a><tt class="py-lineno">3315</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3316"></a><tt class="py-lineno">3316</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3317"></a><tt class="py-lineno">3317</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3318"></a><tt class="py-lineno">3318</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1098" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1098', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3319"></a><tt class="py-lineno">3319</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1099" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1099', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3320"></a><tt class="py-lineno">3320</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3321"></a><tt class="py-lineno">3321</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3322"></a><tt class="py-lineno">3322</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3323"></a><tt class="py-lineno">3323</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1100" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1100', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1101" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1101', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3324"></a><tt class="py-lineno">3324</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3325"></a><tt class="py-lineno">3325</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3326"></a><tt class="py-lineno">3326</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3327"></a><tt class="py-lineno">3327</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3328"></a><tt class="py-lineno">3328</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3329"></a><tt class="py-lineno">3329</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3330"></a><tt class="py-lineno">3330</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3331"></a><tt class="py-lineno">3331</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">getResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3332"></a><tt class="py-lineno">3332</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set elements are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3333"></a><tt class="py-lineno">3333</tt> <tt class="py-line"> <tt id="link-1102" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1102', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set elements are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3334"></a><tt class="py-lineno">3334</tt> <tt class="py-line"> </tt>
+<a name="L3335"></a><tt class="py-lineno">3335</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1103" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1103', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set size"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3336"></a><tt class="py-lineno">3336</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3337"></a><tt class="py-lineno">3337</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3338"></a><tt class="py-lineno">3338</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3339"></a><tt class="py-lineno">3339</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1104" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1104', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1105" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#setTestSize"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1105', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3340"></a><tt class="py-lineno">3340</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3341"></a><tt class="py-lineno">3341</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3342"></a><tt class="py-lineno">3342</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3343"></a><tt class="py-lineno">3343</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3344"></a><tt class="py-lineno">3344</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3345"></a><tt class="py-lineno">3345</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3346"></a><tt class="py-lineno">3346</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3347"></a><tt class="py-lineno">3347</tt> <tt class="py-line"> </tt>
+<a name="L3348"></a><tt class="py-lineno">3348</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3349"></a><tt class="py-lineno">3349</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3350"></a><tt class="py-lineno">3350</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3351"></a><tt class="py-lineno">3351</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3352"></a><tt class="py-lineno">3352</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1106" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1106', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1107" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1107', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3353"></a><tt class="py-lineno">3353</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3354"></a><tt class="py-lineno">3354</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3355"></a><tt class="py-lineno">3355</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3356"></a><tt class="py-lineno">3356</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3357"></a><tt class="py-lineno">3357</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">sizeResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3358"></a><tt class="py-lineno">3358</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set sizes are correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3359"></a><tt class="py-lineno">3359</tt> <tt class="py-line"> <tt id="link-1108" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1108', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set sizes are incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3360"></a><tt class="py-lineno">3360</tt> <tt class="py-line"> </tt>
+<a name="L3361"></a><tt class="py-lineno">3361</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1109" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1109', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set add()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3362"></a><tt class="py-lineno">3362</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt class="py-name">add</tt><tt class="py-op">(</tt> <tt class="py-name">addValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3363"></a><tt class="py-lineno">3363</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3364"></a><tt class="py-lineno">3364</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3365"></a><tt class="py-lineno">3365</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3366"></a><tt class="py-lineno">3366</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1110" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1110', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1111" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestAdd()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#setTestAdd"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestAdd" class="py-name" href="#" onclick="return doclink('link-1111', 'setTestAdd', 'link-1111');">setTestAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3367"></a><tt class="py-lineno">3367</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestAdd-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3368"></a><tt class="py-lineno">3368</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">addValue</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3369"></a><tt class="py-lineno">3369</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3370"></a><tt class="py-lineno">3370</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3371"></a><tt class="py-lineno">3371</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3372"></a><tt class="py-lineno">3372</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3373"></a><tt class="py-lineno">3373</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3374"></a><tt class="py-lineno">3374</tt> <tt class="py-line"> </tt>
+<a name="L3375"></a><tt class="py-lineno">3375</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L3376"></a><tt class="py-lineno">3376</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L3377"></a><tt class="py-lineno">3377</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L3378"></a><tt class="py-lineno">3378</tt> <tt class="py-line"> <tt class="py-name">addResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3379"></a><tt class="py-lineno">3379</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3380"></a><tt class="py-lineno">3380</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3381"></a><tt class="py-lineno">3381</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L3382"></a><tt class="py-lineno">3382</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3383"></a><tt class="py-lineno">3383</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3384"></a><tt class="py-lineno">3384</tt> <tt class="py-line"> <tt class="py-comment"># Already in set, probably fine</tt> </tt>
+<a name="L3385"></a><tt class="py-lineno">3385</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3386"></a><tt class="py-lineno">3386</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3387"></a><tt class="py-lineno">3387</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L3388"></a><tt class="py-lineno">3388</tt> <tt class="py-line"> <tt class="py-name">addResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3389"></a><tt class="py-lineno">3389</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3390"></a><tt class="py-lineno">3390</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L3391"></a><tt class="py-lineno">3391</tt> <tt class="py-line"> <tt class="py-name">addResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3392"></a><tt class="py-lineno">3392</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3393"></a><tt class="py-lineno">3393</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1112" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1112', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1113" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1113', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set add"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3394"></a><tt class="py-lineno">3394</tt> <tt class="py-line"> </tt>
+<a name="L3395"></a><tt class="py-lineno">3395</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L3396"></a><tt class="py-lineno">3396</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3397"></a><tt class="py-lineno">3397</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3398"></a><tt class="py-lineno">3398</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3399"></a><tt class="py-lineno">3399</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3400"></a><tt class="py-lineno">3400</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1114" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1114', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1115" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1115', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3401"></a><tt class="py-lineno">3401</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3402"></a><tt class="py-lineno">3402</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3403"></a><tt class="py-lineno">3403</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3404"></a><tt class="py-lineno">3404</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3405"></a><tt class="py-lineno">3405</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3406"></a><tt class="py-lineno">3406</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3407"></a><tt class="py-lineno">3407</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3408"></a><tt class="py-lineno">3408</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3409"></a><tt class="py-lineno">3409</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3410"></a><tt class="py-lineno">3410</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3411"></a><tt class="py-lineno">3411</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3412"></a><tt class="py-lineno">3412</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3413"></a><tt class="py-lineno">3413</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3414"></a><tt class="py-lineno">3414</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3415"></a><tt class="py-lineno">3415</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1116" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1116', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1117" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1117', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3416"></a><tt class="py-lineno">3416</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3417"></a><tt class="py-lineno">3417</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3418"></a><tt class="py-lineno">3418</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3419"></a><tt class="py-lineno">3419</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1118" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1118', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3420"></a><tt class="py-lineno">3420</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1119" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1119', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3421"></a><tt class="py-lineno">3421</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3422"></a><tt class="py-lineno">3422</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3423"></a><tt class="py-lineno">3423</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3424"></a><tt class="py-lineno">3424</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1120" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1120', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1121" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1121', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3425"></a><tt class="py-lineno">3425</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3426"></a><tt class="py-lineno">3426</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3427"></a><tt class="py-lineno">3427</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3428"></a><tt class="py-lineno">3428</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3429"></a><tt class="py-lineno">3429</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3430"></a><tt class="py-lineno">3430</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3431"></a><tt class="py-lineno">3431</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3432"></a><tt class="py-lineno">3432</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3433"></a><tt class="py-lineno">3433</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3434"></a><tt class="py-lineno">3434</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1122" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1122', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1123" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1123', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3435"></a><tt class="py-lineno">3435</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3436"></a><tt class="py-lineno">3436</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3437"></a><tt class="py-lineno">3437</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3438"></a><tt class="py-lineno">3438</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3439"></a><tt class="py-lineno">3439</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3440"></a><tt class="py-lineno">3440</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3441"></a><tt class="py-lineno">3441</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3442"></a><tt class="py-lineno">3442</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3443"></a><tt class="py-lineno">3443</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3444"></a><tt class="py-lineno">3444</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3445"></a><tt class="py-lineno">3445</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3446"></a><tt class="py-lineno">3446</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1124" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1124', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1125" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1125', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3447"></a><tt class="py-lineno">3447</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3448"></a><tt class="py-lineno">3448</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3449"></a><tt class="py-lineno">3449</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3450"></a><tt class="py-lineno">3450</tt> <tt class="py-line"> <tt class="py-name">addResults</tt> <tt class="py-op">=</tt> <tt class="py-name">addResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L3451"></a><tt class="py-lineno">3451</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3452"></a><tt class="py-lineno">3452</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">addResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3453"></a><tt class="py-lineno">3453</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set add correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3454"></a><tt class="py-lineno">3454</tt> <tt class="py-line"> <tt id="link-1126" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1126', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set add was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3455"></a><tt class="py-lineno">3455</tt> <tt class="py-line"> </tt>
+<a name="L3456"></a><tt class="py-lineno">3456</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1127" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1127', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set addAll()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3457"></a><tt class="py-lineno">3457</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt id="link-1128" class="py-name" targets="Method TestON.core.dicttoobject.DictToObject.update()=TestON.core.dicttoobject.DictToObject-class.html#update,Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.update()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#update"><a title="TestON.core.dicttoobject.DictToObject.update
+TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.update" class="py-name" href="#" onclick="return doclink('link-1128', 'update', 'link-1128');">update</a></tt><tt class="py-op">(</tt> <tt class="py-name">addAllValue</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3458"></a><tt class="py-lineno">3458</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3459"></a><tt class="py-lineno">3459</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3460"></a><tt class="py-lineno">3460</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3461"></a><tt class="py-lineno">3461</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1129" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1129', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1130" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestAdd" class="py-name" href="#" onclick="return doclink('link-1130', 'setTestAdd', 'link-1111');">setTestAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3462"></a><tt class="py-lineno">3462</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestAddAll-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3463"></a><tt class="py-lineno">3463</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">addAllValue</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3464"></a><tt class="py-lineno">3464</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3465"></a><tt class="py-lineno">3465</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3466"></a><tt class="py-lineno">3466</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3467"></a><tt class="py-lineno">3467</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3468"></a><tt class="py-lineno">3468</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3469"></a><tt class="py-lineno">3469</tt> <tt class="py-line"> </tt>
+<a name="L3470"></a><tt class="py-lineno">3470</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L3471"></a><tt class="py-lineno">3471</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L3472"></a><tt class="py-lineno">3472</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L3473"></a><tt class="py-lineno">3473</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3474"></a><tt class="py-lineno">3474</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3475"></a><tt class="py-lineno">3475</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3476"></a><tt class="py-lineno">3476</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L3477"></a><tt class="py-lineno">3477</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3478"></a><tt class="py-lineno">3478</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3479"></a><tt class="py-lineno">3479</tt> <tt class="py-line"> <tt class="py-comment"># Already in set, probably fine</tt> </tt>
+<a name="L3480"></a><tt class="py-lineno">3480</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3481"></a><tt class="py-lineno">3481</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3482"></a><tt class="py-lineno">3482</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L3483"></a><tt class="py-lineno">3483</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3484"></a><tt class="py-lineno">3484</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3485"></a><tt class="py-lineno">3485</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L3486"></a><tt class="py-lineno">3486</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3487"></a><tt class="py-lineno">3487</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addAllResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3488"></a><tt class="py-lineno">3488</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1131" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1131', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1132" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1132', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set addAll"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3489"></a><tt class="py-lineno">3489</tt> <tt class="py-line"> </tt>
+<a name="L3490"></a><tt class="py-lineno">3490</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L3491"></a><tt class="py-lineno">3491</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3492"></a><tt class="py-lineno">3492</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3493"></a><tt class="py-lineno">3493</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3494"></a><tt class="py-lineno">3494</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3495"></a><tt class="py-lineno">3495</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1133" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1133', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1134" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1134', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3496"></a><tt class="py-lineno">3496</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3497"></a><tt class="py-lineno">3497</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3498"></a><tt class="py-lineno">3498</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3499"></a><tt class="py-lineno">3499</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3500"></a><tt class="py-lineno">3500</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3501"></a><tt class="py-lineno">3501</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3502"></a><tt class="py-lineno">3502</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3503"></a><tt class="py-lineno">3503</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3504"></a><tt class="py-lineno">3504</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3505"></a><tt class="py-lineno">3505</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3506"></a><tt class="py-lineno">3506</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3507"></a><tt class="py-lineno">3507</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3508"></a><tt class="py-lineno">3508</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3509"></a><tt class="py-lineno">3509</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3510"></a><tt class="py-lineno">3510</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1135" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1135', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1136" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1136', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3511"></a><tt class="py-lineno">3511</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3512"></a><tt class="py-lineno">3512</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3513"></a><tt class="py-lineno">3513</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3514"></a><tt class="py-lineno">3514</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1137" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1137', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3515"></a><tt class="py-lineno">3515</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1138" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1138', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3516"></a><tt class="py-lineno">3516</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3517"></a><tt class="py-lineno">3517</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3518"></a><tt class="py-lineno">3518</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3519"></a><tt class="py-lineno">3519</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1139" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1139', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1140" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1140', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3520"></a><tt class="py-lineno">3520</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3521"></a><tt class="py-lineno">3521</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3522"></a><tt class="py-lineno">3522</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3523"></a><tt class="py-lineno">3523</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3524"></a><tt class="py-lineno">3524</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3525"></a><tt class="py-lineno">3525</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3526"></a><tt class="py-lineno">3526</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3527"></a><tt class="py-lineno">3527</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3528"></a><tt class="py-lineno">3528</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3529"></a><tt class="py-lineno">3529</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1141" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1141', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1142" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1142', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3530"></a><tt class="py-lineno">3530</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3531"></a><tt class="py-lineno">3531</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3532"></a><tt class="py-lineno">3532</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3533"></a><tt class="py-lineno">3533</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3534"></a><tt class="py-lineno">3534</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3535"></a><tt class="py-lineno">3535</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3536"></a><tt class="py-lineno">3536</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3537"></a><tt class="py-lineno">3537</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3538"></a><tt class="py-lineno">3538</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3539"></a><tt class="py-lineno">3539</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3540"></a><tt class="py-lineno">3540</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3541"></a><tt class="py-lineno">3541</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1143" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1143', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1144" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1144', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3542"></a><tt class="py-lineno">3542</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3543"></a><tt class="py-lineno">3543</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3544"></a><tt class="py-lineno">3544</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3545"></a><tt class="py-lineno">3545</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">addAllResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L3546"></a><tt class="py-lineno">3546</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3547"></a><tt class="py-lineno">3547</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">addAllResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3548"></a><tt class="py-lineno">3548</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set addAll correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3549"></a><tt class="py-lineno">3549</tt> <tt class="py-line"> <tt id="link-1145" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1145', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set addAll was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3550"></a><tt class="py-lineno">3550</tt> <tt class="py-line"> </tt>
+<a name="L3551"></a><tt class="py-lineno">3551</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1146" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1146', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set contains()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3552"></a><tt class="py-lineno">3552</tt> <tt class="py-line"> <tt class="py-name">containsResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3553"></a><tt class="py-lineno">3553</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3554"></a><tt class="py-lineno">3554</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3555"></a><tt class="py-lineno">3555</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1147" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1147', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1148" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1148', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3556"></a><tt class="py-lineno">3556</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setContains-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3557"></a><tt class="py-lineno">3557</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3558"></a><tt class="py-lineno">3558</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"values"</tt><tt class="py-op">:</tt> <tt class="py-name">addValue</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3559"></a><tt class="py-lineno">3559</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3560"></a><tt class="py-lineno">3560</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3561"></a><tt class="py-lineno">3561</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3562"></a><tt class="py-lineno">3562</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3563"></a><tt class="py-lineno">3563</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: This is the tuple</tt> </tt>
+<a name="L3564"></a><tt class="py-lineno">3564</tt> <tt class="py-line"> <tt class="py-name">containsResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3565"></a><tt class="py-lineno">3565</tt> <tt class="py-line"> </tt>
+<a name="L3566"></a><tt class="py-lineno">3566</tt> <tt class="py-line"> <tt class="py-name">containsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3567"></a><tt class="py-lineno">3567</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3568"></a><tt class="py-lineno">3568</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">containsResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3569"></a><tt class="py-lineno">3569</tt> <tt class="py-line"> <tt class="py-name">containsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3570"></a><tt class="py-lineno">3570</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3571"></a><tt class="py-lineno">3571</tt> <tt class="py-line"> <tt class="py-name">containsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">containsResults</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L3572"></a><tt class="py-lineno">3572</tt> <tt class="py-line"> <tt class="py-name">containsResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-number">1</tt> <tt class="py-op">]</tt> </tt>
+<a name="L3573"></a><tt class="py-lineno">3573</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3574"></a><tt class="py-lineno">3574</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">containsResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3575"></a><tt class="py-lineno">3575</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set contains is functional"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3576"></a><tt class="py-lineno">3576</tt> <tt class="py-line"> <tt id="link-1149" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1149', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set contains failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3577"></a><tt class="py-lineno">3577</tt> <tt class="py-line"> </tt>
+<a name="L3578"></a><tt class="py-lineno">3578</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1150" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1150', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set containsAll()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3579"></a><tt class="py-lineno">3579</tt> <tt class="py-line"> <tt class="py-name">containsAllResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3580"></a><tt class="py-lineno">3580</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3581"></a><tt class="py-lineno">3581</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3582"></a><tt class="py-lineno">3582</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1151" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1151', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1152" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1152', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3583"></a><tt class="py-lineno">3583</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setContainsAll-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3584"></a><tt class="py-lineno">3584</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L3585"></a><tt class="py-lineno">3585</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"values"</tt><tt class="py-op">:</tt> <tt class="py-name">addAllValue</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3586"></a><tt class="py-lineno">3586</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3587"></a><tt class="py-lineno">3587</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3588"></a><tt class="py-lineno">3588</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3589"></a><tt class="py-lineno">3589</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3590"></a><tt class="py-lineno">3590</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: This is the tuple</tt> </tt>
+<a name="L3591"></a><tt class="py-lineno">3591</tt> <tt class="py-line"> <tt class="py-name">containsAllResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3592"></a><tt class="py-lineno">3592</tt> <tt class="py-line"> </tt>
+<a name="L3593"></a><tt class="py-lineno">3593</tt> <tt class="py-line"> <tt class="py-name">containsAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3594"></a><tt class="py-lineno">3594</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3595"></a><tt class="py-lineno">3595</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">containsResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3596"></a><tt class="py-lineno">3596</tt> <tt class="py-line"> <tt class="py-name">containsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3597"></a><tt class="py-lineno">3597</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3598"></a><tt class="py-lineno">3598</tt> <tt class="py-line"> <tt class="py-name">containsResults</tt> <tt class="py-op">=</tt> <tt class="py-name">containsResults</tt> <tt class="py-keyword">and</tt>\ </tt>
+<a name="L3599"></a><tt class="py-lineno">3599</tt> <tt class="py-line"> <tt class="py-name">containsResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-number">1</tt> <tt class="py-op">]</tt> </tt>
+<a name="L3600"></a><tt class="py-lineno">3600</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3601"></a><tt class="py-lineno">3601</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">containsAllResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3602"></a><tt class="py-lineno">3602</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set containsAll is functional"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3603"></a><tt class="py-lineno">3603</tt> <tt class="py-line"> <tt id="link-1153" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1153', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set containsAll failed"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3604"></a><tt class="py-lineno">3604</tt> <tt class="py-line"> </tt>
+<a name="L3605"></a><tt class="py-lineno">3605</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1154" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1154', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set remove()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3606"></a><tt class="py-lineno">3606</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt> <tt class="py-name">addValue</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3607"></a><tt class="py-lineno">3607</tt> <tt class="py-line"> <tt class="py-name">removeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3608"></a><tt class="py-lineno">3608</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3609"></a><tt class="py-lineno">3609</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3610"></a><tt class="py-lineno">3610</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1155" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1155', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1156" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestRemove()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#setTestRemove"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestRemove" class="py-name" href="#" onclick="return doclink('link-1156', 'setTestRemove', 'link-1156');">setTestRemove</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3611"></a><tt class="py-lineno">3611</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestRemove-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3612"></a><tt class="py-lineno">3612</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">addValue</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3613"></a><tt class="py-lineno">3613</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3614"></a><tt class="py-lineno">3614</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3615"></a><tt class="py-lineno">3615</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3616"></a><tt class="py-lineno">3616</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3617"></a><tt class="py-lineno">3617</tt> <tt class="py-line"> <tt class="py-name">removeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3618"></a><tt class="py-lineno">3618</tt> <tt class="py-line"> </tt>
+<a name="L3619"></a><tt class="py-lineno">3619</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L3620"></a><tt class="py-lineno">3620</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L3621"></a><tt class="py-lineno">3621</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L3622"></a><tt class="py-lineno">3622</tt> <tt class="py-line"> <tt class="py-name">removeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3623"></a><tt class="py-lineno">3623</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3624"></a><tt class="py-lineno">3624</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">removeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3625"></a><tt class="py-lineno">3625</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L3626"></a><tt class="py-lineno">3626</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3627"></a><tt class="py-lineno">3627</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">removeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3628"></a><tt class="py-lineno">3628</tt> <tt class="py-line"> <tt class="py-comment"># not in set, probably fine</tt> </tt>
+<a name="L3629"></a><tt class="py-lineno">3629</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3630"></a><tt class="py-lineno">3630</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">removeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3631"></a><tt class="py-lineno">3631</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L3632"></a><tt class="py-lineno">3632</tt> <tt class="py-line"> <tt class="py-name">removeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3633"></a><tt class="py-lineno">3633</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3634"></a><tt class="py-lineno">3634</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L3635"></a><tt class="py-lineno">3635</tt> <tt class="py-line"> <tt class="py-name">removeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3636"></a><tt class="py-lineno">3636</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">removeResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3637"></a><tt class="py-lineno">3637</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1157" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1157', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1158" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1158', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set remove"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3638"></a><tt class="py-lineno">3638</tt> <tt class="py-line"> </tt>
+<a name="L3639"></a><tt class="py-lineno">3639</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L3640"></a><tt class="py-lineno">3640</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3641"></a><tt class="py-lineno">3641</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3642"></a><tt class="py-lineno">3642</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3643"></a><tt class="py-lineno">3643</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3644"></a><tt class="py-lineno">3644</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1159" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1159', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1160" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1160', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3645"></a><tt class="py-lineno">3645</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3646"></a><tt class="py-lineno">3646</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3647"></a><tt class="py-lineno">3647</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3648"></a><tt class="py-lineno">3648</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3649"></a><tt class="py-lineno">3649</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3650"></a><tt class="py-lineno">3650</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3651"></a><tt class="py-lineno">3651</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3652"></a><tt class="py-lineno">3652</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3653"></a><tt class="py-lineno">3653</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3654"></a><tt class="py-lineno">3654</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3655"></a><tt class="py-lineno">3655</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3656"></a><tt class="py-lineno">3656</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3657"></a><tt class="py-lineno">3657</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3658"></a><tt class="py-lineno">3658</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3659"></a><tt class="py-lineno">3659</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1161" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1161', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1162" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1162', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3660"></a><tt class="py-lineno">3660</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3661"></a><tt class="py-lineno">3661</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3662"></a><tt class="py-lineno">3662</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3663"></a><tt class="py-lineno">3663</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1163" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1163', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3664"></a><tt class="py-lineno">3664</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1164" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1164', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3665"></a><tt class="py-lineno">3665</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3666"></a><tt class="py-lineno">3666</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3667"></a><tt class="py-lineno">3667</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3668"></a><tt class="py-lineno">3668</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1165" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1165', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1166" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1166', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3669"></a><tt class="py-lineno">3669</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3670"></a><tt class="py-lineno">3670</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3671"></a><tt class="py-lineno">3671</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3672"></a><tt class="py-lineno">3672</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3673"></a><tt class="py-lineno">3673</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3674"></a><tt class="py-lineno">3674</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3675"></a><tt class="py-lineno">3675</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3676"></a><tt class="py-lineno">3676</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3677"></a><tt class="py-lineno">3677</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3678"></a><tt class="py-lineno">3678</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1167" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1167', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1168" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1168', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3679"></a><tt class="py-lineno">3679</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3680"></a><tt class="py-lineno">3680</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3681"></a><tt class="py-lineno">3681</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3682"></a><tt class="py-lineno">3682</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3683"></a><tt class="py-lineno">3683</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3684"></a><tt class="py-lineno">3684</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3685"></a><tt class="py-lineno">3685</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3686"></a><tt class="py-lineno">3686</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3687"></a><tt class="py-lineno">3687</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3688"></a><tt class="py-lineno">3688</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3689"></a><tt class="py-lineno">3689</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3690"></a><tt class="py-lineno">3690</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1169" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1169', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1170" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1170', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3691"></a><tt class="py-lineno">3691</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3692"></a><tt class="py-lineno">3692</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3693"></a><tt class="py-lineno">3693</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3694"></a><tt class="py-lineno">3694</tt> <tt class="py-line"> <tt class="py-name">removeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">removeResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L3695"></a><tt class="py-lineno">3695</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3696"></a><tt class="py-lineno">3696</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">removeResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3697"></a><tt class="py-lineno">3697</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set remove correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3698"></a><tt class="py-lineno">3698</tt> <tt class="py-line"> <tt id="link-1171" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1171', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set remove was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3699"></a><tt class="py-lineno">3699</tt> <tt class="py-line"> </tt>
+<a name="L3700"></a><tt class="py-lineno">3700</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1172" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1172', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set removeAll()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3701"></a><tt class="py-lineno">3701</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt class="py-name">difference_update</tt><tt class="py-op">(</tt> <tt class="py-name">addAllValue</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3702"></a><tt class="py-lineno">3702</tt> <tt class="py-line"> <tt class="py-name">removeAllResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3703"></a><tt class="py-lineno">3703</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3704"></a><tt class="py-lineno">3704</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
+<a name="L3705"></a><tt class="py-lineno">3705</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3706"></a><tt class="py-lineno">3706</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1173" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1173', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1174" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestRemove" class="py-name" href="#" onclick="return doclink('link-1174', 'setTestRemove', 'link-1156');">setTestRemove</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3707"></a><tt class="py-lineno">3707</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestRemoveAll-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3708"></a><tt class="py-lineno">3708</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">addAllValue</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3709"></a><tt class="py-lineno">3709</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3710"></a><tt class="py-lineno">3710</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3711"></a><tt class="py-lineno">3711</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3712"></a><tt class="py-lineno">3712</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3713"></a><tt class="py-lineno">3713</tt> <tt class="py-line"> <tt class="py-name">removeAllResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3714"></a><tt class="py-lineno">3714</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">,</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt>
+<a name="L3715"></a><tt class="py-lineno">3715</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1175" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1175', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt><tt class="py-name">e</tt><tt class="py-op">)</tt> </tt>
+<a name="L3716"></a><tt class="py-lineno">3716</tt> <tt class="py-line"> </tt>
+<a name="L3717"></a><tt class="py-lineno">3717</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L3718"></a><tt class="py-lineno">3718</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L3719"></a><tt class="py-lineno">3719</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L3720"></a><tt class="py-lineno">3720</tt> <tt class="py-line"> <tt class="py-name">removeAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3721"></a><tt class="py-lineno">3721</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3722"></a><tt class="py-lineno">3722</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">removeAllResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3723"></a><tt class="py-lineno">3723</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L3724"></a><tt class="py-lineno">3724</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3725"></a><tt class="py-lineno">3725</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">removeAllResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3726"></a><tt class="py-lineno">3726</tt> <tt class="py-line"> <tt class="py-comment"># not in set, probably fine</tt> </tt>
+<a name="L3727"></a><tt class="py-lineno">3727</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3728"></a><tt class="py-lineno">3728</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">removeAllResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3729"></a><tt class="py-lineno">3729</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L3730"></a><tt class="py-lineno">3730</tt> <tt class="py-line"> <tt class="py-name">removeAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3731"></a><tt class="py-lineno">3731</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3732"></a><tt class="py-lineno">3732</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L3733"></a><tt class="py-lineno">3733</tt> <tt class="py-line"> <tt class="py-name">removeAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3734"></a><tt class="py-lineno">3734</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">removeAllResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3735"></a><tt class="py-lineno">3735</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1176" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1176', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1177" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1177', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set removeAll"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3736"></a><tt class="py-lineno">3736</tt> <tt class="py-line"> </tt>
+<a name="L3737"></a><tt class="py-lineno">3737</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L3738"></a><tt class="py-lineno">3738</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3739"></a><tt class="py-lineno">3739</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3740"></a><tt class="py-lineno">3740</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3741"></a><tt class="py-lineno">3741</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3742"></a><tt class="py-lineno">3742</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1178" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1178', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1179" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1179', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3743"></a><tt class="py-lineno">3743</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3744"></a><tt class="py-lineno">3744</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3745"></a><tt class="py-lineno">3745</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3746"></a><tt class="py-lineno">3746</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3747"></a><tt class="py-lineno">3747</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3748"></a><tt class="py-lineno">3748</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3749"></a><tt class="py-lineno">3749</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3750"></a><tt class="py-lineno">3750</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3751"></a><tt class="py-lineno">3751</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3752"></a><tt class="py-lineno">3752</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3753"></a><tt class="py-lineno">3753</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3754"></a><tt class="py-lineno">3754</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3755"></a><tt class="py-lineno">3755</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3756"></a><tt class="py-lineno">3756</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3757"></a><tt class="py-lineno">3757</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1180" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1180', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1181" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1181', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3758"></a><tt class="py-lineno">3758</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3759"></a><tt class="py-lineno">3759</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3760"></a><tt class="py-lineno">3760</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3761"></a><tt class="py-lineno">3761</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1182" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1182', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3762"></a><tt class="py-lineno">3762</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1183" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1183', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3763"></a><tt class="py-lineno">3763</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3764"></a><tt class="py-lineno">3764</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3765"></a><tt class="py-lineno">3765</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3766"></a><tt class="py-lineno">3766</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1184" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1184', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1185" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1185', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3767"></a><tt class="py-lineno">3767</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3768"></a><tt class="py-lineno">3768</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3769"></a><tt class="py-lineno">3769</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3770"></a><tt class="py-lineno">3770</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3771"></a><tt class="py-lineno">3771</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3772"></a><tt class="py-lineno">3772</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3773"></a><tt class="py-lineno">3773</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3774"></a><tt class="py-lineno">3774</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3775"></a><tt class="py-lineno">3775</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3776"></a><tt class="py-lineno">3776</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1186" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1186', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1187" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1187', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3777"></a><tt class="py-lineno">3777</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3778"></a><tt class="py-lineno">3778</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3779"></a><tt class="py-lineno">3779</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3780"></a><tt class="py-lineno">3780</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3781"></a><tt class="py-lineno">3781</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3782"></a><tt class="py-lineno">3782</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3783"></a><tt class="py-lineno">3783</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3784"></a><tt class="py-lineno">3784</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3785"></a><tt class="py-lineno">3785</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3786"></a><tt class="py-lineno">3786</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3787"></a><tt class="py-lineno">3787</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3788"></a><tt class="py-lineno">3788</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1188" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1188', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1189" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1189', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3789"></a><tt class="py-lineno">3789</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3790"></a><tt class="py-lineno">3790</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3791"></a><tt class="py-lineno">3791</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3792"></a><tt class="py-lineno">3792</tt> <tt class="py-line"> <tt class="py-name">removeAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">removeAllResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L3793"></a><tt class="py-lineno">3793</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3794"></a><tt class="py-lineno">3794</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">removeAllResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3795"></a><tt class="py-lineno">3795</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set removeAll correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3796"></a><tt class="py-lineno">3796</tt> <tt class="py-line"> <tt id="link-1190" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1190', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set removeAll was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3797"></a><tt class="py-lineno">3797</tt> <tt class="py-line"> </tt>
+<a name="L3798"></a><tt class="py-lineno">3798</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1191" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1191', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set addAll()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3799"></a><tt class="py-lineno">3799</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt id="link-1192" class="py-name"><a title="TestON.core.dicttoobject.DictToObject.update
+TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.update" class="py-name" href="#" onclick="return doclink('link-1192', 'update', 'link-1128');">update</a></tt><tt class="py-op">(</tt> <tt class="py-name">addAllValue</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3800"></a><tt class="py-lineno">3800</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3801"></a><tt class="py-lineno">3801</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3802"></a><tt class="py-lineno">3802</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3803"></a><tt class="py-lineno">3803</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1193" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1193', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1194" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestAdd" class="py-name" href="#" onclick="return doclink('link-1194', 'setTestAdd', 'link-1111');">setTestAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3804"></a><tt class="py-lineno">3804</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestAddAll-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3805"></a><tt class="py-lineno">3805</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">addAllValue</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3806"></a><tt class="py-lineno">3806</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3807"></a><tt class="py-lineno">3807</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3808"></a><tt class="py-lineno">3808</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3809"></a><tt class="py-lineno">3809</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3810"></a><tt class="py-lineno">3810</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3811"></a><tt class="py-lineno">3811</tt> <tt class="py-line"> </tt>
+<a name="L3812"></a><tt class="py-lineno">3812</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L3813"></a><tt class="py-lineno">3813</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L3814"></a><tt class="py-lineno">3814</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L3815"></a><tt class="py-lineno">3815</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3816"></a><tt class="py-lineno">3816</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3817"></a><tt class="py-lineno">3817</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3818"></a><tt class="py-lineno">3818</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L3819"></a><tt class="py-lineno">3819</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3820"></a><tt class="py-lineno">3820</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3821"></a><tt class="py-lineno">3821</tt> <tt class="py-line"> <tt class="py-comment"># Already in set, probably fine</tt> </tt>
+<a name="L3822"></a><tt class="py-lineno">3822</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3823"></a><tt class="py-lineno">3823</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3824"></a><tt class="py-lineno">3824</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L3825"></a><tt class="py-lineno">3825</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3826"></a><tt class="py-lineno">3826</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3827"></a><tt class="py-lineno">3827</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L3828"></a><tt class="py-lineno">3828</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3829"></a><tt class="py-lineno">3829</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addAllResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3830"></a><tt class="py-lineno">3830</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1195" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1195', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1196" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1196', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set addAll"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3831"></a><tt class="py-lineno">3831</tt> <tt class="py-line"> </tt>
+<a name="L3832"></a><tt class="py-lineno">3832</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L3833"></a><tt class="py-lineno">3833</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3834"></a><tt class="py-lineno">3834</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3835"></a><tt class="py-lineno">3835</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3836"></a><tt class="py-lineno">3836</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3837"></a><tt class="py-lineno">3837</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1197" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1197', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1198" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1198', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3838"></a><tt class="py-lineno">3838</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3839"></a><tt class="py-lineno">3839</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3840"></a><tt class="py-lineno">3840</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3841"></a><tt class="py-lineno">3841</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3842"></a><tt class="py-lineno">3842</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3843"></a><tt class="py-lineno">3843</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3844"></a><tt class="py-lineno">3844</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3845"></a><tt class="py-lineno">3845</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3846"></a><tt class="py-lineno">3846</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3847"></a><tt class="py-lineno">3847</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3848"></a><tt class="py-lineno">3848</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3849"></a><tt class="py-lineno">3849</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3850"></a><tt class="py-lineno">3850</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3851"></a><tt class="py-lineno">3851</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3852"></a><tt class="py-lineno">3852</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1199" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1199', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1200" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1200', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3853"></a><tt class="py-lineno">3853</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3854"></a><tt class="py-lineno">3854</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3855"></a><tt class="py-lineno">3855</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3856"></a><tt class="py-lineno">3856</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1201" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1201', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3857"></a><tt class="py-lineno">3857</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1202" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1202', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3858"></a><tt class="py-lineno">3858</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3859"></a><tt class="py-lineno">3859</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3860"></a><tt class="py-lineno">3860</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3861"></a><tt class="py-lineno">3861</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1203" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1203', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1204" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1204', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3862"></a><tt class="py-lineno">3862</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3863"></a><tt class="py-lineno">3863</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3864"></a><tt class="py-lineno">3864</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3865"></a><tt class="py-lineno">3865</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3866"></a><tt class="py-lineno">3866</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3867"></a><tt class="py-lineno">3867</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3868"></a><tt class="py-lineno">3868</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3869"></a><tt class="py-lineno">3869</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3870"></a><tt class="py-lineno">3870</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3871"></a><tt class="py-lineno">3871</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1205" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1205', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1206" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1206', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3872"></a><tt class="py-lineno">3872</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3873"></a><tt class="py-lineno">3873</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3874"></a><tt class="py-lineno">3874</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3875"></a><tt class="py-lineno">3875</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3876"></a><tt class="py-lineno">3876</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3877"></a><tt class="py-lineno">3877</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3878"></a><tt class="py-lineno">3878</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3879"></a><tt class="py-lineno">3879</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3880"></a><tt class="py-lineno">3880</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3881"></a><tt class="py-lineno">3881</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3882"></a><tt class="py-lineno">3882</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3883"></a><tt class="py-lineno">3883</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1207" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1207', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1208" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1208', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3884"></a><tt class="py-lineno">3884</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3885"></a><tt class="py-lineno">3885</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3886"></a><tt class="py-lineno">3886</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3887"></a><tt class="py-lineno">3887</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">addAllResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L3888"></a><tt class="py-lineno">3888</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3889"></a><tt class="py-lineno">3889</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">addAllResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3890"></a><tt class="py-lineno">3890</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set addAll correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3891"></a><tt class="py-lineno">3891</tt> <tt class="py-line"> <tt id="link-1209" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1209', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set addAll was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3892"></a><tt class="py-lineno">3892</tt> <tt class="py-line"> </tt>
+<a name="L3893"></a><tt class="py-lineno">3893</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1210" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1210', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set clear()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3894"></a><tt class="py-lineno">3894</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt class="py-name">clear</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3895"></a><tt class="py-lineno">3895</tt> <tt class="py-line"> <tt class="py-name">clearResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3896"></a><tt class="py-lineno">3896</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3897"></a><tt class="py-lineno">3897</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3898"></a><tt class="py-lineno">3898</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1211" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1211', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1212" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestRemove" class="py-name" href="#" onclick="return doclink('link-1212', 'setTestRemove', 'link-1156');">setTestRemove</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3899"></a><tt class="py-lineno">3899</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestClear-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3900"></a><tt class="py-lineno">3900</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-string">" "</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-comment"># Values doesn't matter</tt> </tt>
+<a name="L3901"></a><tt class="py-lineno">3901</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"clear"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3902"></a><tt class="py-lineno">3902</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3903"></a><tt class="py-lineno">3903</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3904"></a><tt class="py-lineno">3904</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3905"></a><tt class="py-lineno">3905</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3906"></a><tt class="py-lineno">3906</tt> <tt class="py-line"> <tt class="py-name">clearResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3907"></a><tt class="py-lineno">3907</tt> <tt class="py-line"> </tt>
+<a name="L3908"></a><tt class="py-lineno">3908</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L3909"></a><tt class="py-lineno">3909</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L3910"></a><tt class="py-lineno">3910</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L3911"></a><tt class="py-lineno">3911</tt> <tt class="py-line"> <tt class="py-name">clearResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3912"></a><tt class="py-lineno">3912</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3913"></a><tt class="py-lineno">3913</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">clearResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3914"></a><tt class="py-lineno">3914</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L3915"></a><tt class="py-lineno">3915</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3916"></a><tt class="py-lineno">3916</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">clearResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3917"></a><tt class="py-lineno">3917</tt> <tt class="py-line"> <tt class="py-comment"># Nothing set, probably fine</tt> </tt>
+<a name="L3918"></a><tt class="py-lineno">3918</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L3919"></a><tt class="py-lineno">3919</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">clearResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3920"></a><tt class="py-lineno">3920</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L3921"></a><tt class="py-lineno">3921</tt> <tt class="py-line"> <tt class="py-name">clearResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3922"></a><tt class="py-lineno">3922</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3923"></a><tt class="py-lineno">3923</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L3924"></a><tt class="py-lineno">3924</tt> <tt class="py-line"> <tt class="py-name">clearResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3925"></a><tt class="py-lineno">3925</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">clearResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L3926"></a><tt class="py-lineno">3926</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1213" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1213', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1214" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1214', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set clear"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3927"></a><tt class="py-lineno">3927</tt> <tt class="py-line"> </tt>
+<a name="L3928"></a><tt class="py-lineno">3928</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L3929"></a><tt class="py-lineno">3929</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3930"></a><tt class="py-lineno">3930</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3931"></a><tt class="py-lineno">3931</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3932"></a><tt class="py-lineno">3932</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3933"></a><tt class="py-lineno">3933</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1215" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1215', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1216" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1216', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3934"></a><tt class="py-lineno">3934</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3935"></a><tt class="py-lineno">3935</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3936"></a><tt class="py-lineno">3936</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3937"></a><tt class="py-lineno">3937</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3938"></a><tt class="py-lineno">3938</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3939"></a><tt class="py-lineno">3939</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3940"></a><tt class="py-lineno">3940</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3941"></a><tt class="py-lineno">3941</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3942"></a><tt class="py-lineno">3942</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3943"></a><tt class="py-lineno">3943</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3944"></a><tt class="py-lineno">3944</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3945"></a><tt class="py-lineno">3945</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3946"></a><tt class="py-lineno">3946</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L3947"></a><tt class="py-lineno">3947</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L3948"></a><tt class="py-lineno">3948</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1217" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1217', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1218" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1218', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3949"></a><tt class="py-lineno">3949</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3950"></a><tt class="py-lineno">3950</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3951"></a><tt class="py-lineno">3951</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3952"></a><tt class="py-lineno">3952</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1219" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1219', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3953"></a><tt class="py-lineno">3953</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1220" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1220', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3954"></a><tt class="py-lineno">3954</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3955"></a><tt class="py-lineno">3955</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L3956"></a><tt class="py-lineno">3956</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L3957"></a><tt class="py-lineno">3957</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1221" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1221', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1222" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1222', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3958"></a><tt class="py-lineno">3958</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3959"></a><tt class="py-lineno">3959</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3960"></a><tt class="py-lineno">3960</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3961"></a><tt class="py-lineno">3961</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3962"></a><tt class="py-lineno">3962</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L3963"></a><tt class="py-lineno">3963</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3964"></a><tt class="py-lineno">3964</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3965"></a><tt class="py-lineno">3965</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3966"></a><tt class="py-lineno">3966</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3967"></a><tt class="py-lineno">3967</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1223" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1223', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1224" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1224', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3968"></a><tt class="py-lineno">3968</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3969"></a><tt class="py-lineno">3969</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3970"></a><tt class="py-lineno">3970</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3971"></a><tt class="py-lineno">3971</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3972"></a><tt class="py-lineno">3972</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L3973"></a><tt class="py-lineno">3973</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3974"></a><tt class="py-lineno">3974</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3975"></a><tt class="py-lineno">3975</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L3976"></a><tt class="py-lineno">3976</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3977"></a><tt class="py-lineno">3977</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L3978"></a><tt class="py-lineno">3978</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L3979"></a><tt class="py-lineno">3979</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1225" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1225', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1226" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1226', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3980"></a><tt class="py-lineno">3980</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3981"></a><tt class="py-lineno">3981</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L3982"></a><tt class="py-lineno">3982</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3983"></a><tt class="py-lineno">3983</tt> <tt class="py-line"> <tt class="py-name">clearResults</tt> <tt class="py-op">=</tt> <tt class="py-name">clearResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L3984"></a><tt class="py-lineno">3984</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L3985"></a><tt class="py-lineno">3985</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">clearResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L3986"></a><tt class="py-lineno">3986</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set clear correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L3987"></a><tt class="py-lineno">3987</tt> <tt class="py-line"> <tt id="link-1227" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1227', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set clear was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3988"></a><tt class="py-lineno">3988</tt> <tt class="py-line"> </tt>
+<a name="L3989"></a><tt class="py-lineno">3989</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1228" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1228', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set addAll()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3990"></a><tt class="py-lineno">3990</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt id="link-1229" class="py-name"><a title="TestON.core.dicttoobject.DictToObject.update
+TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.update" class="py-name" href="#" onclick="return doclink('link-1229', 'update', 'link-1128');">update</a></tt><tt class="py-op">(</tt> <tt class="py-name">addAllValue</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3991"></a><tt class="py-lineno">3991</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3992"></a><tt class="py-lineno">3992</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L3993"></a><tt class="py-lineno">3993</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L3994"></a><tt class="py-lineno">3994</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1230" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1230', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1231" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestAdd" class="py-name" href="#" onclick="return doclink('link-1231', 'setTestAdd', 'link-1111');">setTestAdd</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L3995"></a><tt class="py-lineno">3995</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestAddAll-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L3996"></a><tt class="py-lineno">3996</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">addAllValue</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3997"></a><tt class="py-lineno">3997</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L3998"></a><tt class="py-lineno">3998</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L3999"></a><tt class="py-lineno">3999</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L4000"></a><tt class="py-lineno">4000</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4001"></a><tt class="py-lineno">4001</tt> <tt class="py-line"> <tt class="py-name">addResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4002"></a><tt class="py-lineno">4002</tt> <tt class="py-line"> </tt>
+<a name="L4003"></a><tt class="py-lineno">4003</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L4004"></a><tt class="py-lineno">4004</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L4005"></a><tt class="py-lineno">4005</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L4006"></a><tt class="py-lineno">4006</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L4007"></a><tt class="py-lineno">4007</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4008"></a><tt class="py-lineno">4008</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L4009"></a><tt class="py-lineno">4009</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L4010"></a><tt class="py-lineno">4010</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L4011"></a><tt class="py-lineno">4011</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L4012"></a><tt class="py-lineno">4012</tt> <tt class="py-line"> <tt class="py-comment"># Already in set, probably fine</tt> </tt>
+<a name="L4013"></a><tt class="py-lineno">4013</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L4014"></a><tt class="py-lineno">4014</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">addResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L4015"></a><tt class="py-lineno">4015</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L4016"></a><tt class="py-lineno">4016</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4017"></a><tt class="py-lineno">4017</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L4018"></a><tt class="py-lineno">4018</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L4019"></a><tt class="py-lineno">4019</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4020"></a><tt class="py-lineno">4020</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">addAllResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L4021"></a><tt class="py-lineno">4021</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1232" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1232', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1233" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1233', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set addAll"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4022"></a><tt class="py-lineno">4022</tt> <tt class="py-line"> </tt>
+<a name="L4023"></a><tt class="py-lineno">4023</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L4024"></a><tt class="py-lineno">4024</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4025"></a><tt class="py-lineno">4025</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4026"></a><tt class="py-lineno">4026</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4027"></a><tt class="py-lineno">4027</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4028"></a><tt class="py-lineno">4028</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1234" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1234', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1235" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1235', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L4029"></a><tt class="py-lineno">4029</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L4030"></a><tt class="py-lineno">4030</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4031"></a><tt class="py-lineno">4031</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4032"></a><tt class="py-lineno">4032</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4033"></a><tt class="py-lineno">4033</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L4034"></a><tt class="py-lineno">4034</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4035"></a><tt class="py-lineno">4035</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4036"></a><tt class="py-lineno">4036</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L4037"></a><tt class="py-lineno">4037</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4038"></a><tt class="py-lineno">4038</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4039"></a><tt class="py-lineno">4039</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4040"></a><tt class="py-lineno">4040</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4041"></a><tt class="py-lineno">4041</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L4042"></a><tt class="py-lineno">4042</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L4043"></a><tt class="py-lineno">4043</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1236" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1236', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1237" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1237', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4044"></a><tt class="py-lineno">4044</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4045"></a><tt class="py-lineno">4045</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4046"></a><tt class="py-lineno">4046</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4047"></a><tt class="py-lineno">4047</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1238" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1238', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4048"></a><tt class="py-lineno">4048</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1239" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1239', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4049"></a><tt class="py-lineno">4049</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4050"></a><tt class="py-lineno">4050</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L4051"></a><tt class="py-lineno">4051</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L4052"></a><tt class="py-lineno">4052</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1240" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1240', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1241" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1241', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4053"></a><tt class="py-lineno">4053</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4054"></a><tt class="py-lineno">4054</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4055"></a><tt class="py-lineno">4055</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4056"></a><tt class="py-lineno">4056</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4057"></a><tt class="py-lineno">4057</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L4058"></a><tt class="py-lineno">4058</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4059"></a><tt class="py-lineno">4059</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4060"></a><tt class="py-lineno">4060</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4061"></a><tt class="py-lineno">4061</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4062"></a><tt class="py-lineno">4062</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1242" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1242', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1243" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1243', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L4063"></a><tt class="py-lineno">4063</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L4064"></a><tt class="py-lineno">4064</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4065"></a><tt class="py-lineno">4065</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4066"></a><tt class="py-lineno">4066</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4067"></a><tt class="py-lineno">4067</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L4068"></a><tt class="py-lineno">4068</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4069"></a><tt class="py-lineno">4069</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4070"></a><tt class="py-lineno">4070</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L4071"></a><tt class="py-lineno">4071</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4072"></a><tt class="py-lineno">4072</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L4073"></a><tt class="py-lineno">4073</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4074"></a><tt class="py-lineno">4074</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1244" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1244', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1245" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1245', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4075"></a><tt class="py-lineno">4075</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4076"></a><tt class="py-lineno">4076</tt> <tt class="py-line"> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4077"></a><tt class="py-lineno">4077</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4078"></a><tt class="py-lineno">4078</tt> <tt class="py-line"> <tt class="py-name">addAllResults</tt> <tt class="py-op">=</tt> <tt class="py-name">addAllResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L4079"></a><tt class="py-lineno">4079</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L4080"></a><tt class="py-lineno">4080</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">addAllResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L4081"></a><tt class="py-lineno">4081</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set addAll correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L4082"></a><tt class="py-lineno">4082</tt> <tt class="py-line"> <tt id="link-1246" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1246', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set addAll was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4083"></a><tt class="py-lineno">4083</tt> <tt class="py-line"> </tt>
+<a name="L4084"></a><tt class="py-lineno">4084</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1247" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-1247', 'step', 'link-12');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Distributed Set retain()"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4085"></a><tt class="py-lineno">4085</tt> <tt class="py-line"> <tt class="py-name">onosSet</tt><tt class="py-op">.</tt><tt class="py-name">intersection_update</tt><tt class="py-op">(</tt> <tt class="py-name">retainValue</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4086"></a><tt class="py-lineno">4086</tt> <tt class="py-line"> <tt class="py-name">retainResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4087"></a><tt class="py-lineno">4087</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4088"></a><tt class="py-lineno">4088</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4089"></a><tt class="py-lineno">4089</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1248" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1248', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1249" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestRemove" class="py-name" href="#" onclick="return doclink('link-1249', 'setTestRemove', 'link-1156');">setTestRemove</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L4090"></a><tt class="py-lineno">4090</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestRetain-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L4091"></a><tt class="py-lineno">4091</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt><tt class="py-op">,</tt> <tt class="py-name">retainValue</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
+<a name="L4092"></a><tt class="py-lineno">4092</tt> <tt class="py-line"> <tt class="py-name">kwargs</tt><tt class="py-op">=</tt><tt class="py-op">{</tt> <tt class="py-string">"retain"</tt><tt class="py-op">:</tt> <tt class="py-name">True</tt> <tt class="py-op">}</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4093"></a><tt class="py-lineno">4093</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4094"></a><tt class="py-lineno">4094</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4095"></a><tt class="py-lineno">4095</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L4096"></a><tt class="py-lineno">4096</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4097"></a><tt class="py-lineno">4097</tt> <tt class="py-line"> <tt class="py-name">retainResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4098"></a><tt class="py-lineno">4098</tt> <tt class="py-line"> </tt>
+<a name="L4099"></a><tt class="py-lineno">4099</tt> <tt class="py-line"> <tt class="py-comment"># main.TRUE = successfully changed the set</tt> </tt>
+<a name="L4100"></a><tt class="py-lineno">4100</tt> <tt class="py-line"> <tt class="py-comment"># main.FALSE = action resulted in no change in set</tt> </tt>
+<a name="L4101"></a><tt class="py-lineno">4101</tt> <tt class="py-line"> <tt class="py-comment"># main.ERROR - Some error in executing the function</tt> </tt>
+<a name="L4102"></a><tt class="py-lineno">4102</tt> <tt class="py-line"> <tt class="py-name">retainResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L4103"></a><tt class="py-lineno">4103</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4104"></a><tt class="py-lineno">4104</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">retainResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L4105"></a><tt class="py-lineno">4105</tt> <tt class="py-line"> <tt class="py-comment"># All is well</tt> </tt>
+<a name="L4106"></a><tt class="py-lineno">4106</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L4107"></a><tt class="py-lineno">4107</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">retainResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt><tt class="py-op">:</tt> </tt>
+<a name="L4108"></a><tt class="py-lineno">4108</tt> <tt class="py-line"> <tt class="py-comment"># Already in set, probably fine</tt> </tt>
+<a name="L4109"></a><tt class="py-lineno">4109</tt> <tt class="py-line"> <tt class="py-keyword">pass</tt> </tt>
+<a name="L4110"></a><tt class="py-lineno">4110</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">retainResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L4111"></a><tt class="py-lineno">4111</tt> <tt class="py-line"> <tt class="py-comment"># Error in execution</tt> </tt>
+<a name="L4112"></a><tt class="py-lineno">4112</tt> <tt class="py-line"> <tt class="py-name">retainResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4113"></a><tt class="py-lineno">4113</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L4114"></a><tt class="py-lineno">4114</tt> <tt class="py-line"> <tt class="py-comment"># unexpected result</tt> </tt>
+<a name="L4115"></a><tt class="py-lineno">4115</tt> <tt class="py-line"> <tt class="py-name">retainResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4116"></a><tt class="py-lineno">4116</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">retainResults</tt> <tt class="py-op">!=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">:</tt> </tt>
+<a name="L4117"></a><tt class="py-lineno">4117</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1250" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1250', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1251" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1251', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Error executing set retain"</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4118"></a><tt class="py-lineno">4118</tt> <tt class="py-line"> </tt>
+<a name="L4119"></a><tt class="py-lineno">4119</tt> <tt class="py-line"> <tt class="py-comment"># Check if set is still correct</tt> </tt>
+<a name="L4120"></a><tt class="py-lineno">4120</tt> <tt class="py-line"> <tt class="py-name">size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4121"></a><tt class="py-lineno">4121</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4122"></a><tt class="py-lineno">4122</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4123"></a><tt class="py-lineno">4123</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4124"></a><tt class="py-lineno">4124</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1252" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1252', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1253" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestGet" class="py-name" href="#" onclick="return doclink('link-1253', 'setTestGet', 'link-1095');">setTestGet</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L4125"></a><tt class="py-lineno">4125</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestGet-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L4126"></a><tt class="py-lineno">4126</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4127"></a><tt class="py-lineno">4127</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4128"></a><tt class="py-lineno">4128</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4129"></a><tt class="py-lineno">4129</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L4130"></a><tt class="py-lineno">4130</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4131"></a><tt class="py-lineno">4131</tt> <tt class="py-line"> <tt class="py-name">getResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4132"></a><tt class="py-lineno">4132</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L4133"></a><tt class="py-lineno">4133</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4134"></a><tt class="py-lineno">4134</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4135"></a><tt class="py-lineno">4135</tt> <tt class="py-line"> <tt class="py-name">current</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4136"></a><tt class="py-lineno">4136</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4137"></a><tt class="py-lineno">4137</tt> <tt class="py-line"> <tt class="py-comment"># no repeats</tt> </tt>
+<a name="L4138"></a><tt class="py-lineno">4138</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">!=</tt> <tt class="py-name">current</tt><tt class="py-op">:</tt> </tt>
+<a name="L4139"></a><tt class="py-lineno">4139</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1254" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1254', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1255" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1255', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4140"></a><tt class="py-lineno">4140</tt> <tt class="py-line"> <tt class="py-string">" has incorrect view"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4141"></a><tt class="py-lineno">4141</tt> <tt class="py-line"> <tt class="py-string">" of set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4142"></a><tt class="py-lineno">4142</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4143"></a><tt class="py-lineno">4143</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1256" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1256', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Expected: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosSet</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4144"></a><tt class="py-lineno">4144</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1257" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1257', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">debug</tt><tt class="py-op">(</tt> <tt class="py-string">"Actual: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">current</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4145"></a><tt class="py-lineno">4145</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4146"></a><tt class="py-lineno">4146</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
+<a name="L4147"></a><tt class="py-lineno">4147</tt> <tt class="py-line"> <tt class="py-comment"># error, set is not a set</tt> </tt>
+<a name="L4148"></a><tt class="py-lineno">4148</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1258" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1258', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1259" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1259', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4149"></a><tt class="py-lineno">4149</tt> <tt class="py-line"> <tt class="py-string">" has repeat elements in"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4150"></a><tt class="py-lineno">4150</tt> <tt class="py-line"> <tt class="py-string">" set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> <tt class="py-string">":\n"</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4151"></a><tt class="py-lineno">4151</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4152"></a><tt class="py-lineno">4152</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4153"></a><tt class="py-lineno">4153</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">getResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt><tt class="py-op">:</tt> </tt>
+<a name="L4154"></a><tt class="py-lineno">4154</tt> <tt class="py-line"> <tt class="py-name">getResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4155"></a><tt class="py-lineno">4155</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4156"></a><tt class="py-lineno">4156</tt> <tt class="py-line"> <tt class="py-name">threads</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
+<a name="L4157"></a><tt class="py-lineno">4157</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4158"></a><tt class="py-lineno">4158</tt> <tt class="py-line"> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1260" class="py-name"><a title="TestON.core.Thread
+TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-1260', 'Thread', 'link-56');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">CLIs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1261" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.setTestSize" class="py-name" href="#" onclick="return doclink('link-1261', 'setTestSize', 'link-1105');">setTestSize</a></tt><tt class="py-op">,</tt> </tt>
+<a name="L4159"></a><tt class="py-lineno">4159</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"setTestSize-"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
+<a name="L4160"></a><tt class="py-lineno">4160</tt> <tt class="py-line"> <tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4161"></a><tt class="py-lineno">4161</tt> <tt class="py-line"> <tt class="py-name">threads</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4162"></a><tt class="py-lineno">4162</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">start</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4163"></a><tt class="py-lineno">4163</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">threads</tt><tt class="py-op">:</tt> </tt>
+<a name="L4164"></a><tt class="py-lineno">4164</tt> <tt class="py-line"> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
+<a name="L4165"></a><tt class="py-lineno">4165</tt> <tt class="py-line"> <tt class="py-name">sizeResponses</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4166"></a><tt class="py-lineno">4166</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
+<a name="L4167"></a><tt class="py-lineno">4167</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numCtrls</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
+<a name="L4168"></a><tt class="py-lineno">4168</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">size</tt> <tt class="py-op">!=</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
+<a name="L4169"></a><tt class="py-lineno">4169</tt> <tt class="py-line"> <tt class="py-name">sizeResults</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
+<a name="L4170"></a><tt class="py-lineno">4170</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-1262" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-1262', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-1263" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-1263', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4171"></a><tt class="py-lineno">4171</tt> <tt class="py-line"> <tt class="py-string">" expected a size of "</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4172"></a><tt class="py-lineno">4172</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">size</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" for set "</tt> <tt class="py-op">+</tt> <tt class="py-name">onosSetName</tt> <tt class="py-op">+</tt> </tt>
+<a name="L4173"></a><tt class="py-lineno">4173</tt> <tt class="py-line"> <tt class="py-string">" but got "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">sizeResponses</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
+<a name="L4174"></a><tt class="py-lineno">4174</tt> <tt class="py-line"> <tt class="py-name">retainResults</tt> <tt class="py-op">=</tt> <tt class="py-name">retainResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">getResults</tt> <tt class="py-keyword">and</tt> <tt class="py-name">sizeResults</tt> </tt>
+<a name="L4175"></a><tt class="py-lineno">4175</tt> <tt class="py-line"> <tt class="py-name">utilities</tt><tt class="py-op">.</tt><tt class="py-name">assert_equals</tt><tt class="py-op">(</tt> <tt class="py-name">expect</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
+<a name="L4176"></a><tt class="py-lineno">4176</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">retainResults</tt><tt class="py-op">,</tt> </tt>
+<a name="L4177"></a><tt class="py-lineno">4177</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set retain correct"</tt><tt class="py-op">,</tt> </tt>
+<a name="L4178"></a><tt class="py-lineno">4178</tt> <tt class="py-line"> <tt id="link-1264" class="py-name"><a title="TestON.core.teston.TestON.onfail
+TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-1264', 'onfail', 'link-28');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set retain was incorrect"</tt> <tt class="py-op">)</tt> </tt>
+</div></div><a name="L4179"></a><tt class="py-lineno">4179</tt> <tt class="py-line"> </tt><script type="text/javascript">
+<!--
+expandto(location.href);
+// -->
+</script>
+</pre>
+<br />
+<!-- ==================== NAVIGATION BAR ==================== -->
+<table class="navbar" border="0" width="100%" cellpadding="0"
+ bgcolor="#a0c0ff" cellspacing="0">
+ <tr valign="middle">
+ <!-- Home link -->
+ <th> <a
+ href="TestON-module.html">Home</a> </th>
+
+ <!-- Tree link -->
+ <th> <a
+ href="module-tree.html">Trees</a> </th>
+
+ <!-- Index link -->
+ <th> <a
+ href="identifier-index.html">Indices</a> </th>
+
+ <!-- Help link -->
+ <th> <a
+ href="help.html">Help</a> </th>
+
+ <!-- Project homepage -->
+ <th class="navbar" align="right" width="100%">
+ <table border="0" cellpadding="0" cellspacing="0">
+ <tr><th class="navbar" align="center"
+ >TestON</th>
+ </tr></table></th>
+ </tr>
+</table>
+<table border="0" cellpadding="0" cellspacing="0" width="100%%">
+ <tr>
+ <td align="left" class="footer">
+ Generated by Epydoc 3.0.1 on Mon Aug 10 11:12:37 2015
+ </td>
+ <td align="right" class="footer">
+ <a target="mainFrame" href="http://epydoc.sourceforge.net"
+ >http://epydoc.sourceforge.net</a>
+ </td>
+ </tr>
+</table>
+
+<script type="text/javascript">
+ <!--
+ // Private objects are initially displayed (because if
+ // javascript is turned off then we want them to be
+ // visible); but by default, we want to hide them. So hide
+ // them unless we have a cookie that says to show them.
+ checkCookie();
+ // -->
+</script>
+</body>
+</html>