blob: 0128d5c7aef6155944bb75f951a6fc3db51a5bf0 [file] [log] [blame]
Jon Halla1cdd892015-08-10 13:36:28 -07001<?xml version="1.0" encoding="ascii"?>
2<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
3 "DTD/xhtml1-transitional.dtd">
4<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
5<head>
6 <title>TestON.tests.CHOtest.CHOtest</title>
7 <link rel="stylesheet" href="epydoc.css" type="text/css" />
8 <script type="text/javascript" src="epydoc.js"></script>
9</head>
10
11<body bgcolor="white" text="black" link="blue" vlink="#204080"
12 alink="#204080">
13<!-- ==================== NAVIGATION BAR ==================== -->
14<table class="navbar" border="0" width="100%" cellpadding="0"
15 bgcolor="#a0c0ff" cellspacing="0">
16 <tr valign="middle">
17 <!-- Home link -->
18 <th>&nbsp;&nbsp;&nbsp;<a
19 href="TestON-module.html">Home</a>&nbsp;&nbsp;&nbsp;</th>
20
21 <!-- Tree link -->
22 <th>&nbsp;&nbsp;&nbsp;<a
23 href="module-tree.html">Trees</a>&nbsp;&nbsp;&nbsp;</th>
24
25 <!-- Index link -->
26 <th>&nbsp;&nbsp;&nbsp;<a
27 href="identifier-index.html">Indices</a>&nbsp;&nbsp;&nbsp;</th>
28
29 <!-- Help link -->
30 <th>&nbsp;&nbsp;&nbsp;<a
31 href="help.html">Help</a>&nbsp;&nbsp;&nbsp;</th>
32
33 <!-- Project homepage -->
34 <th class="navbar" align="right" width="100%">
35 <table border="0" cellpadding="0" cellspacing="0">
36 <tr><th class="navbar" align="center"
37 >TestON</th>
38 </tr></table></th>
39 </tr>
40</table>
41<table width="100%" cellpadding="0" cellspacing="0">
42 <tr valign="top">
43 <td width="100%">
44 <span class="breadcrumbs">
45 <a href="TestON-module.html">Package&nbsp;TestON</a> ::
46 <a href="TestON.tests-module.html">Package&nbsp;tests</a> ::
47 <a href="TestON.tests.CHOtest-module.html">Package&nbsp;CHOtest</a> ::
48 Module&nbsp;CHOtest
49 </span>
50 </td>
51 <td>
52 <table cellpadding="0" cellspacing="0">
53 <!-- hide/show private -->
54 <tr><td align="right"><span class="options">[<a href="javascript:void(0);" class="privatelink"
55 onclick="toggle_private();">hide&nbsp;private</a>]</span></td></tr>
56 <tr><td align="right"><span class="options"
57 >[<a href="frames.html" target="_top">frames</a
58 >]&nbsp;|&nbsp;<a href="TestON.tests.CHOtest.CHOtest-pysrc.html"
59 target="_top">no&nbsp;frames</a>]</span></td></tr>
60 </table>
61 </td>
62 </tr>
63</table>
64<h1 class="epydoc">Source Code for <a href="TestON.tests.CHOtest.CHOtest-module.html">Module TestON.tests.CHOtest.CHOtest</a></h1>
65<pre class="py-src">
66<a name="L1"></a><tt class="py-lineno"> 1</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">sys</tt> </tt>
67<a name="L2"></a><tt class="py-lineno"> 2</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">os</tt> </tt>
68<a name="L3"></a><tt class="py-lineno"> 3</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
69<a name="L4"></a><tt class="py-lineno"> 4</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
70<a name="L5"></a><tt class="py-lineno"> 5</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt>
71<a name="L6"></a><tt class="py-lineno"> 6</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
72<a name="L7"></a><tt class="py-lineno"> 7</tt> <tt class="py-line"> </tt>
73<a name="L8"></a><tt class="py-lineno"> 8</tt> <tt class="py-line"> </tt>
74<a name="CHOtest"></a><div id="CHOtest-def"><a name="L9"></a><tt class="py-lineno"> 9</tt> <a class="py-toggle" href="#" id="CHOtest-toggle" onclick="return toggle('CHOtest');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html">CHOtest</a><tt class="py-op">:</tt> </tt>
75</div><div id="CHOtest-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="CHOtest-expanded"><a name="L10"></a><tt class="py-lineno"> 10</tt> <tt class="py-line"> </tt>
76<a name="CHOtest.__init__"></a><div id="CHOtest.__init__-def"><a name="L11"></a><tt class="py-lineno"> 11</tt> <a class="py-toggle" href="#" id="CHOtest.__init__-toggle" onclick="return toggle('CHOtest.__init__');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-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>
77</div><div id="CHOtest.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.__init__-expanded"><a name="L12"></a><tt class="py-lineno"> 12</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>
78</div><a name="L13"></a><tt class="py-lineno"> 13</tt> <tt class="py-line"> </tt>
79<a name="CHOtest.CASE1"></a><div id="CHOtest.CASE1-def"><a name="L14"></a><tt class="py-lineno"> 14</tt> <a class="py-toggle" href="#" id="CHOtest.CASE1-toggle" onclick="return toggle('CHOtest.CASE1');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-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>
80</div><div id="CHOtest.CASE1-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE1-expanded"><a name="L15"></a><tt class="py-lineno"> 15</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
81<a name="L16"></a><tt class="py-lineno"> 16</tt> <tt class="py-line"><tt class="py-docstring"> Startup sequence:</tt> </tt>
82<a name="L17"></a><tt class="py-lineno"> 17</tt> <tt class="py-line"><tt class="py-docstring"> apply cell &lt;name&gt;</tt> </tt>
83<a name="L18"></a><tt class="py-lineno"> 18</tt> <tt class="py-line"><tt class="py-docstring"> git pull</tt> </tt>
84<a name="L19"></a><tt class="py-lineno"> 19</tt> <tt class="py-line"><tt class="py-docstring"> mvn clean install</tt> </tt>
85<a name="L20"></a><tt class="py-lineno"> 20</tt> <tt class="py-line"><tt class="py-docstring"> onos-package</tt> </tt>
86<a name="L21"></a><tt class="py-lineno"> 21</tt> <tt class="py-line"><tt class="py-docstring"> onos-verify-cell</tt> </tt>
87<a name="L22"></a><tt class="py-lineno"> 22</tt> <tt class="py-line"><tt class="py-docstring"> onos-uninstall</tt> </tt>
88<a name="L23"></a><tt class="py-lineno"> 23</tt> <tt class="py-line"><tt class="py-docstring"> onos-install</tt> </tt>
89<a name="L24"></a><tt class="py-lineno"> 24</tt> <tt class="py-line"><tt class="py-docstring"> onos-start-cli</tt> </tt>
90<a name="L25"></a><tt class="py-lineno"> 25</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
91<a name="L26"></a><tt class="py-lineno"> 26</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
92<a name="L27"></a><tt class="py-lineno"> 27</tt> <tt class="py-line"> </tt>
93<a name="L28"></a><tt class="py-lineno"> 28</tt> <tt class="py-line"> <tt class="py-keyword">global</tt> <tt class="py-name">intentState</tt> </tt>
94<a name="L29"></a><tt class="py-lineno"> 29</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
95<a name="L30"></a><tt class="py-lineno"> 30</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">300</tt> </tt>
96<a name="L31"></a><tt class="py-lineno"> 31</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">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">'numCtrl'</tt> <tt class="py-op">]</tt> </tt>
97<a name="L32"></a><tt class="py-lineno"> 32</tt> <tt class="py-line"> <tt class="py-name">git_pull</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">'GIT'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'autoPull'</tt> <tt class="py-op">]</tt> </tt>
98<a name="L33"></a><tt class="py-lineno"> 33</tt> <tt class="py-line"> <tt class="py-name">git_branch</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">'GIT'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'branch'</tt> <tt class="py-op">]</tt> </tt>
99<a name="L34"></a><tt class="py-lineno"> 34</tt> <tt class="py-line"> <tt class="py-name">karafTimeout</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">'karafCliTimeout'</tt><tt class="py-op">]</tt> </tt>
100<a name="L35"></a><tt class="py-lineno"> 35</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt> </tt>
101<a name="L36"></a><tt class="py-lineno"> 36</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>
102<a name="L37"></a><tt class="py-lineno"> 37</tt> <tt class="py-line"> </tt>
103<a name="L38"></a><tt class="py-lineno"> 38</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">int</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 class="py-number">1</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
104<a name="L39"></a><tt class="py-lineno"> 39</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>
105<a name="L40"></a><tt class="py-lineno"> 40</tt> <tt class="py-line"> </tt>
106<a name="L41"></a><tt class="py-lineno"> 41</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.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-1', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Set up test environment"</tt> <tt class="py-op">)</tt> </tt>
107<a name="L42"></a><tt class="py-lineno"> 42</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.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-2', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Set up test environment"</tt> <tt class="py-op">)</tt> </tt>
108<a name="L43"></a><tt class="py-lineno"> 43</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-3" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-3', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________"</tt> <tt class="py-op">)</tt> </tt>
109<a name="L44"></a><tt class="py-lineno"> 44</tt> <tt class="py-line"> </tt>
110<a name="L45"></a><tt class="py-lineno"> 45</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-4" 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-4', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Apply Cell environment for ONOS"</tt> <tt class="py-op">)</tt> </tt>
111<a name="L46"></a><tt class="py-lineno"> 46</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onoscell</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
112<a name="L47"></a><tt class="py-lineno"> 47</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">onoscell</tt> </tt>
113<a name="L48"></a><tt class="py-lineno"> 48</tt> <tt class="py-line"> <tt class="py-name">cell_result</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-5" 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
114TestON.drivers.common.cli.onosdriver.OnosDriver.setCell" class="py-name" href="#" onclick="return doclink('link-5', 'setCell', 'link-5');">setCell</a></tt><tt class="py-op">(</tt> <tt class="py-name">cellName</tt> <tt class="py-op">)</tt> </tt>
115<a name="L49"></a><tt class="py-lineno"> 49</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">cell_result</tt><tt class="py-op">,</tt> </tt>
116<a name="L50"></a><tt class="py-lineno"> 50</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
117<a name="L51"></a><tt class="py-lineno"> 51</tt> <tt class="py-line"> <tt id="link-6" 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
118TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-6', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
119<a name="L52"></a><tt class="py-lineno"> 52</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
120<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-7" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-7', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt id="link-8" 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-8', 'error', 'link-8');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Please provide onoscell option at TestON CLI to run CHO tests"</tt> <tt class="py-op">)</tt> </tt>
121<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 id="link-9" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-9', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt id="link-10" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-10', 'error', 'link-8');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Example: ~/TestON/bin/cli.py run OnosCHO onoscell &lt;cellName&gt;"</tt> <tt class="py-op">)</tt> </tt>
122<a name="L55"></a><tt class="py-lineno"> 55</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">clean</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
123<a name="L56"></a><tt class="py-lineno"> 56</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-11" 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-11', 'exit', 'link-11');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
124<a name="L57"></a><tt class="py-lineno"> 57</tt> <tt class="py-line"> </tt>
125<a name="L58"></a><tt class="py-lineno"> 58</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-12" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-12', 'step', 'link-4');">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">git_branch</tt> <tt class="py-op">)</tt> </tt>
126<a name="L59"></a><tt class="py-lineno"> 59</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">git_pull</tt> <tt class="py-op">==</tt> <tt class="py-string">'on'</tt><tt class="py-op">:</tt> </tt>
127<a name="L60"></a><tt class="py-lineno"> 60</tt> <tt class="py-line"> <tt class="py-name">checkout_result</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-13" 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-13', 'gitCheckout', 'link-13');">gitCheckout</a></tt><tt class="py-op">(</tt> <tt class="py-name">git_branch</tt> <tt class="py-op">)</tt> </tt>
128<a name="L61"></a><tt class="py-lineno"> 61</tt> <tt class="py-line"> <tt class="py-name">pull_result</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-14" 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-14', 'gitPull', 'link-14');">gitPull</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
129<a name="L62"></a><tt class="py-lineno"> 62</tt> <tt class="py-line"> <tt class="py-name">cp_result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">checkout_result</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pull_result</tt> <tt class="py-op">)</tt> </tt>
130<a name="L63"></a><tt class="py-lineno"> 63</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
131<a name="L64"></a><tt class="py-lineno"> 64</tt> <tt class="py-line"> <tt class="py-name">checkout_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>
132<a name="L65"></a><tt class="py-lineno"> 65</tt> <tt class="py-line"> <tt class="py-name">pull_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>
133<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 id="link-15" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-15', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Skipped git checkout and pull"</tt> <tt class="py-op">)</tt> </tt>
134<a name="L67"></a><tt class="py-lineno"> 67</tt> <tt class="py-line"> <tt class="py-name">cp_result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">checkout_result</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pull_result</tt> <tt class="py-op">)</tt> </tt>
135<a name="L68"></a><tt class="py-lineno"> 68</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">cp_result</tt><tt class="py-op">,</tt> </tt>
136<a name="L69"></a><tt class="py-lineno"> 69</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
137<a name="L70"></a><tt class="py-lineno"> 70</tt> <tt class="py-line"> <tt id="link-16" class="py-name"><a title="TestON.core.teston.TestON.onfail
138TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-16', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
139<a name="L71"></a><tt class="py-lineno"> 71</tt> <tt class="py-line"> </tt>
140<a name="L72"></a><tt class="py-lineno"> 72</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-17', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"mvn clean &amp; install"</tt> <tt class="py-op">)</tt> </tt>
141<a name="L73"></a><tt class="py-lineno"> 73</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">git_pull</tt> <tt class="py-op">==</tt> <tt class="py-string">'on'</tt><tt class="py-op">:</tt> </tt>
142<a name="L74"></a><tt class="py-lineno"> 74</tt> <tt class="py-line"> <tt class="py-name">mvn_result</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-18" 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-18', 'cleanInstall', 'link-18');">cleanInstall</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
143<a name="L75"></a><tt class="py-lineno"> 75</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">mvn_result</tt><tt class="py-op">,</tt> </tt>
144<a name="L76"></a><tt class="py-lineno"> 76</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
145<a name="L77"></a><tt class="py-lineno"> 77</tt> <tt class="py-line"> <tt id="link-19" class="py-name"><a title="TestON.core.teston.TestON.onfail
146TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-19', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
147<a name="L78"></a><tt class="py-lineno"> 78</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
148<a name="L79"></a><tt class="py-lineno"> 79</tt> <tt class="py-line"> <tt class="py-name">mvn_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>
149<a name="L80"></a><tt class="py-lineno"> 80</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-20" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-20', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Skipped mvn clean install as git pull is disabled in params file"</tt><tt class="py-op">)</tt> </tt>
150<a name="L81"></a><tt class="py-lineno"> 81</tt> <tt class="py-line"> </tt>
151<a name="L82"></a><tt class="py-lineno"> 82</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.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
152TestON.drivers.common.cli.onosdriver.OnosDriver.getVersion" class="py-name" href="#" onclick="return doclink('link-21', 'getVersion', 'link-21');">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>
153<a name="L83"></a><tt class="py-lineno"> 83</tt> <tt class="py-line"> </tt>
154<a name="L84"></a><tt class="py-lineno"> 84</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-22', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Create ONOS package"</tt> <tt class="py-op">)</tt> </tt>
155<a name="L85"></a><tt class="py-lineno"> 85</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-23" 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-23', 'onosPackage', 'link-23');">onosPackage</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
156<a name="L86"></a><tt class="py-lineno"> 86</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>
157<a name="L87"></a><tt class="py-lineno"> 87</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
158<a name="L88"></a><tt class="py-lineno"> 88</tt> <tt class="py-line"> <tt id="link-24" class="py-name"><a title="TestON.core.teston.TestON.onfail
159TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-24', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
160<a name="L89"></a><tt class="py-lineno"> 89</tt> <tt class="py-line"> </tt>
161<a name="L90"></a><tt class="py-lineno"> 90</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-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstall ONOS package on all Nodes"</tt> <tt class="py-op">)</tt> </tt>
162<a name="L91"></a><tt class="py-lineno"> 91</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">TRUE</tt> </tt>
163<a name="L92"></a><tt class="py-lineno"> 92</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">int</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 class="py-op">:</tt> </tt>
164<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-26" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-26', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstalling package on ONOS Node IP: "</tt> <tt class="py-op">+</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
165<a name="L94"></a><tt class="py-lineno"> 94</tt> <tt class="py-line"> <tt class="py-name">u_result</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-27" 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-27', 'onosUninstall', 'link-27');">onosUninstall</a></tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
166<a name="L95"></a><tt class="py-lineno"> 95</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">u_result</tt><tt class="py-op">,</tt> </tt>
167<a name="L96"></a><tt class="py-lineno"> 96</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
168<a name="L97"></a><tt class="py-lineno"> 97</tt> <tt class="py-line"> <tt id="link-28" class="py-name"><a title="TestON.core.teston.TestON.onfail
169TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-28', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
170<a name="L98"></a><tt class="py-lineno"> 98</tt> <tt class="py-line"> <tt class="py-name">uninstallResult</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">uninstallResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">u_result</tt> <tt class="py-op">)</tt> </tt>
171<a name="L99"></a><tt class="py-lineno"> 99</tt> <tt class="py-line"> </tt>
172<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 id="link-29" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-29', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install ONOS package on all Nodes"</tt> <tt class="py-op">)</tt> </tt>
173<a name="L101"></a><tt class="py-lineno"> 101</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
174<a name="L102"></a><tt class="py-lineno"> 102</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">int</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 class="py-op">:</tt> </tt>
175<a name="L103"></a><tt class="py-lineno"> 103</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-30" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-30', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Intsalling package on ONOS Node IP: "</tt> <tt class="py-op">+</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
176<a name="L104"></a><tt class="py-lineno"> 104</tt> <tt class="py-line"> <tt class="py-name">i_result</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.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-31', 'onosInstall', 'link-31');">onosInstall</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
177<a name="L105"></a><tt class="py-lineno"> 105</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">i_result</tt><tt class="py-op">,</tt> </tt>
178<a name="L106"></a><tt class="py-lineno"> 106</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
179<a name="L107"></a><tt class="py-lineno"> 107</tt> <tt class="py-line"> <tt id="link-32" class="py-name"><a title="TestON.core.teston.TestON.onfail
180TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-32', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
181<a name="L108"></a><tt class="py-lineno"> 108</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">installResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">i_result</tt> <tt class="py-op">)</tt> </tt>
182<a name="L109"></a><tt class="py-lineno"> 109</tt> <tt class="py-line"> </tt>
183<a name="L110"></a><tt class="py-lineno"> 110</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-33" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-33', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify ONOS nodes UP status"</tt> <tt class="py-op">)</tt> </tt>
184<a name="L111"></a><tt class="py-lineno"> 111</tt> <tt class="py-line"> <tt class="py-name">statusResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
185<a name="L112"></a><tt class="py-lineno"> 112</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">int</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 class="py-op">:</tt> </tt>
186<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 id="link-34" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-34', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS Node "</tt> <tt class="py-op">+</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</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">" status:"</tt> <tt class="py-op">)</tt> </tt>
187<a name="L114"></a><tt class="py-lineno"> 114</tt> <tt class="py-line"> <tt class="py-name">onos_status</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.onosStatus()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStatus"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.onosStatus" class="py-name" href="#" onclick="return doclink('link-35', 'onosStatus', 'link-35');">onosStatus</a></tt><tt class="py-op">(</tt> <tt class="py-name">node</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
188<a name="L115"></a><tt class="py-lineno"> 115</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">onos_status</tt><tt class="py-op">,</tt> </tt>
189<a name="L116"></a><tt class="py-lineno"> 116</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Test step PASS"</tt><tt class="py-op">,</tt> </tt>
190<a name="L117"></a><tt class="py-lineno"> 117</tt> <tt class="py-line"> <tt id="link-36" class="py-name"><a title="TestON.core.teston.TestON.onfail
191TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-36', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Test step FAIL"</tt> <tt class="py-op">)</tt> </tt>
192<a name="L118"></a><tt class="py-lineno"> 118</tt> <tt class="py-line"> <tt class="py-name">statusResult</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">statusResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">onos_status</tt> <tt class="py-op">)</tt> </tt>
193<a name="L119"></a><tt class="py-lineno"> 119</tt> <tt class="py-line"> </tt>
194<a name="L120"></a><tt class="py-lineno"> 120</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-37" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-37', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Start ONOS CLI on all nodes"</tt> <tt class="py-op">)</tt> </tt>
195<a name="L121"></a><tt class="py-lineno"> 121</tt> <tt class="py-line"> <tt class="py-name">cliResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
196<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 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-2');">log</a></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-4');">step</a></tt><tt class="py-op">(</tt><tt class="py-string">" Start ONOS cli using thread "</tt><tt class="py-op">)</tt> </tt>
197<a name="L123"></a><tt class="py-lineno"> 123</tt> <tt class="py-line"> <tt class="py-name">startCliResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
198<a name="L124"></a><tt class="py-lineno"> 124</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
199<a name="L125"></a><tt class="py-lineno"> 125</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>
200<a name="L126"></a><tt class="py-lineno"> 126</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">int</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 class="py-op">:</tt> </tt>
201<a name="L127"></a><tt class="py-lineno"> 127</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-40" 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
202TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-40', 'Thread', 'link-40');">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-41" 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-41', 'startOnosCli', 'link-41');">startOnosCli</a></tt><tt class="py-op">,</tt> </tt>
203<a name="L128"></a><tt class="py-lineno"> 128</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
204<a name="L129"></a><tt class="py-lineno"> 129</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>
205<a name="L130"></a><tt class="py-lineno"> 130</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 class="py-name">onosIPs</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">karafTimeout</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
206<a name="L131"></a><tt class="py-lineno"> 131</tt> <tt class="py-line"> <tt class="py-name">pool</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>
207<a name="L132"></a><tt class="py-lineno"> 132</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>
208<a name="L133"></a><tt class="py-lineno"> 133</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
209<a name="L134"></a><tt class="py-lineno"> 134</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">pool</tt><tt class="py-op">:</tt> </tt>
210<a name="L135"></a><tt class="py-lineno"> 135</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>
211<a name="L136"></a><tt class="py-lineno"> 136</tt> <tt class="py-line"> <tt class="py-name">startCliResult</tt> <tt class="py-op">=</tt> <tt class="py-name">startCliResult</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>
212<a name="L137"></a><tt class="py-lineno"> 137</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>
213<a name="L138"></a><tt class="py-lineno"> 138</tt> <tt class="py-line"> </tt>
214<a name="L139"></a><tt class="py-lineno"> 139</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">startCliResult</tt><tt class="py-op">:</tt> </tt>
215<a name="L140"></a><tt class="py-lineno"> 140</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-42', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"ONOS CLI did not start up properly"</tt><tt class="py-op">)</tt> </tt>
216<a name="L141"></a><tt class="py-lineno"> 141</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-43" 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-43', 'cleanup', 'link-43');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
217<a name="L142"></a><tt class="py-lineno"> 142</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-44" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-44', 'exit', 'link-11');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
218<a name="L143"></a><tt class="py-lineno"> 143</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
219<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 id="link-45" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-45', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Successful CLI startup"</tt><tt class="py-op">)</tt> </tt>
220<a name="L145"></a><tt class="py-lineno"> 145</tt> <tt class="py-line"> <tt class="py-name">startCliResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
221<a name="L146"></a><tt class="py-lineno"> 146</tt> <tt class="py-line"> <tt class="py-name">case1Result</tt> <tt class="py-op">=</tt> <tt class="py-name">installResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">uninstallResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">statusResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">startCliResult</tt> </tt>
222<a name="L147"></a><tt class="py-lineno"> 147</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>
223<a name="L148"></a><tt class="py-lineno"> 148</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-46', 'log', 'link-2');">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 connecting to CLI: %2f seconds"</tt> <tt class="py-op">%</tt><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>
224<a name="L149"></a><tt class="py-lineno"> 149</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">case1Result</tt><tt class="py-op">,</tt> </tt>
225<a name="L150"></a><tt class="py-lineno"> 150</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Set up test environment PASS"</tt><tt class="py-op">,</tt> </tt>
226<a name="L151"></a><tt class="py-lineno"> 151</tt> <tt class="py-line"> <tt id="link-47" class="py-name"><a title="TestON.core.teston.TestON.onfail
227TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-47', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Set up test environment FAIL"</tt> <tt class="py-op">)</tt> </tt>
228</div><a name="L152"></a><tt class="py-lineno"> 152</tt> <tt class="py-line"> </tt>
229<a name="CHOtest.CASE20"></a><div id="CHOtest.CASE20-def"><a name="L153"></a><tt class="py-lineno"> 153</tt> <a class="py-toggle" href="#" id="CHOtest.CASE20-toggle" onclick="return toggle('CHOtest.CASE20');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE20">CASE20</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>
230</div><div id="CHOtest.CASE20-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE20-expanded"><a name="L154"></a><tt class="py-lineno"> 154</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
231<a name="L155"></a><tt class="py-lineno"> 155</tt> <tt class="py-line"><tt class="py-docstring"> This test script Loads a new Topology (Att) on CHO setup and balances all switches</tt> </tt>
232<a name="L156"></a><tt class="py-lineno"> 156</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
233<a name="L157"></a><tt class="py-lineno"> 157</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
234<a name="L158"></a><tt class="py-lineno"> 158</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
235<a name="L159"></a><tt class="py-lineno"> 159</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
236<a name="L160"></a><tt class="py-lineno"> 160</tt> <tt class="py-line"> </tt>
237<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 class="py-name">numMNswitches</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">'TOPO1'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numSwitches'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
238<a name="L162"></a><tt class="py-lineno"> 162</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNlinks</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">'TOPO1'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numLinks'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
239<a name="L163"></a><tt class="py-lineno"> 163</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNhosts</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">'TOPO1'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numHosts'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
240<a name="L164"></a><tt class="py-lineno"> 164</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">300</tt> </tt>
241<a name="L165"></a><tt class="py-lineno"> 165</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-48" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-48', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
242<a name="L166"></a><tt class="py-lineno"> 166</tt> <tt class="py-line"> <tt class="py-string">"Load Att topology and Balance all Mininet switches across controllers"</tt> <tt class="py-op">)</tt> </tt>
243<a name="L167"></a><tt class="py-lineno"> 167</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
244<a name="L168"></a><tt class="py-lineno"> 168</tt> <tt class="py-line"> <tt class="py-string">"________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
245<a name="L169"></a><tt class="py-lineno"> 169</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-50" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-50', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
246<a name="L170"></a><tt class="py-lineno"> 170</tt> <tt class="py-line"> <tt class="py-string">"Assign and Balance all Mininet switches across controllers"</tt> <tt class="py-op">)</tt> </tt>
247<a name="L171"></a><tt class="py-lineno"> 171</tt> <tt class="py-line"> </tt>
248<a name="L172"></a><tt class="py-lineno"> 172</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-51" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-51', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Stop any previous Mininet network topology"</tt> <tt class="py-op">)</tt> </tt>
249<a name="L173"></a><tt class="py-lineno"> 173</tt> <tt class="py-line"> <tt class="py-name">cliResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
250<a name="L174"></a><tt class="py-lineno"> 174</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">newTopo</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">'TOPO3'</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'topo'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
251<a name="L175"></a><tt class="py-lineno"> 175</tt> <tt class="py-line"> <tt class="py-name">stopStatus</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-52" 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-52', 'stopNet', 'link-52');">stopNet</a></tt><tt class="py-op">(</tt> <tt class="py-name">fileName</tt> <tt class="py-op">=</tt> <tt class="py-string">"topoSpine"</tt> <tt class="py-op">)</tt> </tt>
252<a name="L176"></a><tt class="py-lineno"> 176</tt> <tt class="py-line"> </tt>
253<a name="L177"></a><tt class="py-lineno"> 177</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-53" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-53', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Start Mininet with Att topology"</tt> <tt class="py-op">)</tt> </tt>
254<a name="L178"></a><tt class="py-lineno"> 178</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</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">'TOPO1'</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'topo'</tt><tt class="py-op">]</tt> </tt>
255<a name="L179"></a><tt class="py-lineno"> 179</tt> <tt class="py-line"> <tt class="py-name">startStatus</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-54" 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-54', 'startNet', 'link-54');">startNet</a></tt><tt class="py-op">(</tt><tt class="py-name">topoFile</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</tt><tt class="py-op">)</tt> </tt>
256<a name="L180"></a><tt class="py-lineno"> 180</tt> <tt class="py-line"> </tt>
257<a name="L181"></a><tt class="py-lineno"> 181</tt> <tt class="py-line"> <tt class="py-name">main</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-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assign switches to controllers"</tt> <tt class="py-op">)</tt> </tt>
258<a name="L182"></a><tt class="py-lineno"> 182</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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 class="py-comment"># 1 to ( num of switches +1 )</tt> </tt>
259<a name="L183"></a><tt class="py-lineno"> 183</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-56" 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-56', 'assignSwController', 'link-56');">assignSwController</a></tt><tt class="py-op">(</tt> </tt>
260<a name="L184"></a><tt class="py-lineno"> 184</tt> <tt class="py-line"> <tt class="py-name">sw</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>
261<a name="L185"></a><tt class="py-lineno"> 185</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 class="py-name">onosIPs</tt> <tt class="py-op">)</tt> </tt>
262<a name="L186"></a><tt class="py-lineno"> 186</tt> <tt class="py-line"> </tt>
263<a name="L187"></a><tt class="py-lineno"> 187</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
264<a name="L188"></a><tt class="py-lineno"> 188</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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>
265<a name="L189"></a><tt class="py-lineno"> 189</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-57" 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-57', 'getSwController', 'link-57');">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>
266<a name="L190"></a><tt class="py-lineno"> 190</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt> <tt class="py-string">"Response is "</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>
267<a name="L191"></a><tt class="py-lineno"> 191</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">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</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">response</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
268<a name="L192"></a><tt class="py-lineno"> 192</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">switch_mastership</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>
269<a name="L193"></a><tt class="py-lineno"> 193</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
270<a name="L194"></a><tt class="py-lineno"> 194</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
271<a name="L195"></a><tt class="py-lineno"> 195</tt> <tt class="py-line"> </tt>
272<a name="L196"></a><tt class="py-lineno"> 196</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switch_mastership</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>
273<a name="L197"></a><tt class="py-lineno"> 197</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-58" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-58', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Controller assignment successfull"</tt> <tt class="py-op">)</tt> </tt>
274<a name="L198"></a><tt class="py-lineno"> 198</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
275<a name="L199"></a><tt class="py-lineno"> 199</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-59" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-59', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Controller assignment failed"</tt> <tt class="py-op">)</tt> </tt>
276<a name="L200"></a><tt class="py-lineno"> 200</tt> <tt class="py-line"> </tt>
277<a name="L201"></a><tt class="py-lineno"> 201</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 class="py-comment"># waiting here to make sure topology converges across all nodes</tt> </tt>
278<a name="L202"></a><tt class="py-lineno"> 202</tt> <tt class="py-line"> </tt>
279<a name="L203"></a><tt class="py-lineno"> 203</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-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Balance devices across controllers"</tt> <tt class="py-op">)</tt> </tt>
280<a name="L204"></a><tt class="py-lineno"> 204</tt> <tt class="py-line"> <tt class="py-name">balanceResult</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-61" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.balanceMasters()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#balanceMasters"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.balanceMasters" class="py-name" href="#" onclick="return doclink('link-61', 'balanceMasters', 'link-61');">balanceMasters</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
281<a name="L205"></a><tt class="py-lineno"> 205</tt> <tt class="py-line"> <tt class="py-comment"># giving some breathing time for ONOS to complete re-balance</tt> </tt>
282<a name="L206"></a><tt class="py-lineno"> 206</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>
283<a name="L207"></a><tt class="py-lineno"> 207</tt> <tt class="py-line"> </tt>
284<a name="L208"></a><tt class="py-lineno"> 208</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-62" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#topology,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#topology"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
285TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-62', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
286<a name="L209"></a><tt class="py-lineno"> 209</tt> <tt class="py-line"> <tt class="py-name">topology_result</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-63" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.getTopology()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getTopology"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.getTopology" class="py-name" href="#" onclick="return doclink('link-63', 'getTopology', 'link-63');">getTopology</a></tt><tt class="py-op">(</tt> <tt class="py-name">topology_output</tt> <tt class="py-op">)</tt> </tt>
287<a name="L210"></a><tt class="py-lineno"> 210</tt> <tt class="py-line"> <tt class="py-name">case2Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">switch_mastership</tt> <tt class="py-keyword">and</tt> <tt class="py-name">startStatus</tt> <tt class="py-op">)</tt> </tt>
288<a name="L211"></a><tt class="py-lineno"> 211</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>
289<a name="L212"></a><tt class="py-lineno"> 212</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>
290<a name="L213"></a><tt class="py-lineno"> 213</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case2Result</tt><tt class="py-op">,</tt> </tt>
291<a name="L214"></a><tt class="py-lineno"> 214</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Starting new Att topology test PASS"</tt><tt class="py-op">,</tt> </tt>
292<a name="L215"></a><tt class="py-lineno"> 215</tt> <tt class="py-line"> <tt id="link-64" class="py-name"><a title="TestON.core.teston.TestON.onfail
293TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-64', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Starting new Att topology test FAIL"</tt> <tt class="py-op">)</tt> </tt>
294</div><a name="L216"></a><tt class="py-lineno"> 216</tt> <tt class="py-line"> </tt>
295<a name="CHOtest.CASE21"></a><div id="CHOtest.CASE21-def"><a name="L217"></a><tt class="py-lineno"> 217</tt> <a class="py-toggle" href="#" id="CHOtest.CASE21-toggle" onclick="return toggle('CHOtest.CASE21');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-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>
296</div><div id="CHOtest.CASE21-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE21-expanded"><a name="L218"></a><tt class="py-lineno"> 218</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
297<a name="L219"></a><tt class="py-lineno"> 219</tt> <tt class="py-line"><tt class="py-docstring"> This test script Loads a new Topology (Chordal) on CHO setup and balances all switches</tt> </tt>
298<a name="L220"></a><tt class="py-lineno"> 220</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
299<a name="L221"></a><tt class="py-lineno"> 221</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
300<a name="L222"></a><tt class="py-lineno"> 222</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
301<a name="L223"></a><tt class="py-lineno"> 223</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
302<a name="L224"></a><tt class="py-lineno"> 224</tt> <tt class="py-line"> </tt>
303<a name="L225"></a><tt class="py-lineno"> 225</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</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">'TOPO2'</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'topo'</tt><tt class="py-op">]</tt> </tt>
304<a name="L226"></a><tt class="py-lineno"> 226</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">'TOPO2'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numSwitches'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
305<a name="L227"></a><tt class="py-lineno"> 227</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNlinks</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">'TOPO2'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numLinks'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
306<a name="L228"></a><tt class="py-lineno"> 228</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNhosts</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">'TOPO2'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numHosts'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
307<a name="L229"></a><tt class="py-lineno"> 229</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">300</tt> </tt>
308<a name="L230"></a><tt class="py-lineno"> 230</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
309<a name="L231"></a><tt class="py-lineno"> 231</tt> <tt class="py-line"> <tt class="py-string">"Load Chordal topology and Balance all Mininet switches across controllers"</tt> <tt class="py-op">)</tt> </tt>
310<a name="L232"></a><tt class="py-lineno"> 232</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-66" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-66', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
311<a name="L233"></a><tt class="py-lineno"> 233</tt> <tt class="py-line"> <tt class="py-string">"________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
312<a name="L234"></a><tt class="py-lineno"> 234</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-67', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
313<a name="L235"></a><tt class="py-lineno"> 235</tt> <tt class="py-line"> <tt class="py-string">"Assign and Balance all Mininet switches across controllers"</tt> <tt class="py-op">)</tt> </tt>
314<a name="L236"></a><tt class="py-lineno"> 236</tt> <tt class="py-line"> </tt>
315<a name="L237"></a><tt class="py-lineno"> 237</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-68" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-68', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Stop any previous Mininet network topology"</tt> <tt class="py-op">)</tt> </tt>
316<a name="L238"></a><tt class="py-lineno"> 238</tt> <tt class="py-line"> <tt class="py-name">stopStatus</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-69" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.stopNet" class="py-name" href="#" onclick="return doclink('link-69', 'stopNet', 'link-52');">stopNet</a></tt><tt class="py-op">(</tt><tt class="py-name">fileName</tt> <tt class="py-op">=</tt> <tt class="py-string">"topoAtt"</tt> <tt class="py-op">)</tt> </tt>
317<a name="L239"></a><tt class="py-lineno"> 239</tt> <tt class="py-line"> </tt>
318<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-70" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-70', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Start Mininet with Chordal topology"</tt> <tt class="py-op">)</tt> </tt>
319<a name="L241"></a><tt class="py-lineno"> 241</tt> <tt class="py-line"> <tt class="py-name">startStatus</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-71" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.startNet" class="py-name" href="#" onclick="return doclink('link-71', 'startNet', 'link-54');">startNet</a></tt><tt class="py-op">(</tt><tt class="py-name">topoFile</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</tt><tt class="py-op">)</tt> </tt>
320<a name="L242"></a><tt class="py-lineno"> 242</tt> <tt class="py-line"> </tt>
321<a name="L243"></a><tt class="py-lineno"> 243</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.step" class="py-name" href="#" onclick="return doclink('link-72', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assign switches to controllers"</tt> <tt class="py-op">)</tt> </tt>
322<a name="L244"></a><tt class="py-lineno"> 244</tt> <tt class="py-line"> </tt>
323<a name="L245"></a><tt class="py-lineno"> 245</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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 class="py-comment"># 1 to ( num of switches +1 )</tt> </tt>
324<a name="L246"></a><tt class="py-lineno"> 246</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-73" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.assignSwController" class="py-name" href="#" onclick="return doclink('link-73', 'assignSwController', 'link-56');">assignSwController</a></tt><tt class="py-op">(</tt> </tt>
325<a name="L247"></a><tt class="py-lineno"> 247</tt> <tt class="py-line"> <tt class="py-name">sw</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>
326<a name="L248"></a><tt class="py-lineno"> 248</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 class="py-name">onosIPs</tt> <tt class="py-op">)</tt> </tt>
327<a name="L249"></a><tt class="py-lineno"> 249</tt> <tt class="py-line"> </tt>
328<a name="L250"></a><tt class="py-lineno"> 250</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
329<a name="L251"></a><tt class="py-lineno"> 251</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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>
330<a name="L252"></a><tt class="py-lineno"> 252</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-74" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwController" class="py-name" href="#" onclick="return doclink('link-74', 'getSwController', 'link-57');">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>
331<a name="L253"></a><tt class="py-lineno"> 253</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt> <tt class="py-string">"Response is "</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>
332<a name="L254"></a><tt class="py-lineno"> 254</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">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</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">response</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
333<a name="L255"></a><tt class="py-lineno"> 255</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">switch_mastership</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>
334<a name="L256"></a><tt class="py-lineno"> 256</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
335<a name="L257"></a><tt class="py-lineno"> 257</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
336<a name="L258"></a><tt class="py-lineno"> 258</tt> <tt class="py-line"> </tt>
337<a name="L259"></a><tt class="py-lineno"> 259</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switch_mastership</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>
338<a name="L260"></a><tt class="py-lineno"> 260</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-75', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Controller assignment successfull"</tt> <tt class="py-op">)</tt> </tt>
339<a name="L261"></a><tt class="py-lineno"> 261</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
340<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-76" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-76', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Controller assignment failed"</tt> <tt class="py-op">)</tt> </tt>
341<a name="L263"></a><tt class="py-lineno"> 263</tt> <tt class="py-line"> </tt>
342<a name="L264"></a><tt class="py-lineno"> 264</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-77" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-77', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Balance devices across controllers"</tt> <tt class="py-op">)</tt> </tt>
343<a name="L265"></a><tt class="py-lineno"> 265</tt> <tt class="py-line"> <tt class="py-name">balanceResult</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-78" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.balanceMasters" class="py-name" href="#" onclick="return doclink('link-78', 'balanceMasters', 'link-61');">balanceMasters</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
344<a name="L266"></a><tt class="py-lineno"> 266</tt> <tt class="py-line"> <tt class="py-comment"># giving some breathing time for ONOS to complete re-balance</tt> </tt>
345<a name="L267"></a><tt class="py-lineno"> 267</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>
346<a name="L268"></a><tt class="py-lineno"> 268</tt> <tt class="py-line"> </tt>
347<a name="L269"></a><tt class="py-lineno"> 269</tt> <tt class="py-line"> <tt class="py-name">case21Result</tt> <tt class="py-op">=</tt> <tt class="py-name">switch_mastership</tt> </tt>
348<a name="L270"></a><tt class="py-lineno"> 270</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>
349<a name="L271"></a><tt class="py-lineno"> 271</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>
350<a name="L272"></a><tt class="py-lineno"> 272</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>
351<a name="L273"></a><tt class="py-lineno"> 273</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case21Result</tt><tt class="py-op">,</tt> </tt>
352<a name="L274"></a><tt class="py-lineno"> 274</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Starting new Chordal topology test PASS"</tt><tt class="py-op">,</tt> </tt>
353<a name="L275"></a><tt class="py-lineno"> 275</tt> <tt class="py-line"> <tt id="link-79" class="py-name"><a title="TestON.core.teston.TestON.onfail
354TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-79', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Starting new Chordal topology test FAIL"</tt> <tt class="py-op">)</tt> </tt>
355</div><a name="L276"></a><tt class="py-lineno"> 276</tt> <tt class="py-line"> </tt>
356<a name="CHOtest.CASE22"></a><div id="CHOtest.CASE22-def"><a name="L277"></a><tt class="py-lineno"> 277</tt> <a class="py-toggle" href="#" id="CHOtest.CASE22-toggle" onclick="return toggle('CHOtest.CASE22');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE22">CASE22</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>
357</div><div id="CHOtest.CASE22-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE22-expanded"><a name="L278"></a><tt class="py-lineno"> 278</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
358<a name="L279"></a><tt class="py-lineno"> 279</tt> <tt class="py-line"><tt class="py-docstring"> This test script Loads a new Topology (Spine) on CHO setup and balances all switches</tt> </tt>
359<a name="L280"></a><tt class="py-lineno"> 280</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
360<a name="L281"></a><tt class="py-lineno"> 281</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
361<a name="L282"></a><tt class="py-lineno"> 282</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
362<a name="L283"></a><tt class="py-lineno"> 283</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
363<a name="L284"></a><tt class="py-lineno"> 284</tt> <tt class="py-line"> </tt>
364<a name="L285"></a><tt class="py-lineno"> 285</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</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">'TOPO3'</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'topo'</tt><tt class="py-op">]</tt> </tt>
365<a name="L286"></a><tt class="py-lineno"> 286</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">'TOPO3'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numSwitches'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
366<a name="L287"></a><tt class="py-lineno"> 287</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNlinks</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">'TOPO3'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numLinks'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
367<a name="L288"></a><tt class="py-lineno"> 288</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNhosts</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">'TOPO3'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'numHosts'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt>
368<a name="L289"></a><tt class="py-lineno"> 289</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">600</tt> </tt>
369<a name="L290"></a><tt class="py-lineno"> 290</tt> <tt class="py-line"> </tt>
370<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 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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
371<a name="L292"></a><tt class="py-lineno"> 292</tt> <tt class="py-line"> <tt class="py-string">"Load Spine and Leaf topology and Balance all Mininet switches across controllers"</tt> <tt class="py-op">)</tt> </tt>
372<a name="L293"></a><tt class="py-lineno"> 293</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
373<a name="L294"></a><tt class="py-lineno"> 294</tt> <tt class="py-line"> <tt class="py-string">"________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
374<a name="L295"></a><tt class="py-lineno"> 295</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-82" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-82', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
375<a name="L296"></a><tt class="py-lineno"> 296</tt> <tt class="py-line"> <tt class="py-string">"Assign and Balance all Mininet switches across controllers"</tt> <tt class="py-op">)</tt> </tt>
376<a name="L297"></a><tt class="py-lineno"> 297</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-83', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Stop any previous Mininet network topology"</tt> <tt class="py-op">)</tt> </tt>
377<a name="L298"></a><tt class="py-lineno"> 298</tt> <tt class="py-line"> <tt class="py-name">stopStatus</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-84" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.stopNet" class="py-name" href="#" onclick="return doclink('link-84', 'stopNet', 'link-52');">stopNet</a></tt><tt class="py-op">(</tt><tt class="py-name">fileName</tt> <tt class="py-op">=</tt> <tt class="py-string">"topoChordal"</tt> <tt class="py-op">)</tt> </tt>
378<a name="L299"></a><tt class="py-lineno"> 299</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-85" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-85', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Start Mininet with Spine topology"</tt> <tt class="py-op">)</tt> </tt>
379<a name="L300"></a><tt class="py-lineno"> 300</tt> <tt class="py-line"> <tt class="py-name">startStatus</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-86" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.startNet" class="py-name" href="#" onclick="return doclink('link-86', 'startNet', 'link-54');">startNet</a></tt><tt class="py-op">(</tt><tt class="py-name">topoFile</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">newTopo</tt><tt class="py-op">)</tt> </tt>
380<a name="L301"></a><tt class="py-lineno"> 301</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>
381<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 id="link-87" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-87', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Assign switches to controllers"</tt> <tt class="py-op">)</tt> </tt>
382<a name="L303"></a><tt class="py-lineno"> 303</tt> <tt class="py-line"> </tt>
383<a name="L304"></a><tt class="py-lineno"> 304</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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 class="py-comment"># 1 to ( num of switches +1 )</tt> </tt>
384<a name="L305"></a><tt class="py-lineno"> 305</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-88" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.assignSwController" class="py-name" href="#" onclick="return doclink('link-88', 'assignSwController', 'link-56');">assignSwController</a></tt><tt class="py-op">(</tt> </tt>
385<a name="L306"></a><tt class="py-lineno"> 306</tt> <tt class="py-line"> <tt class="py-name">sw</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>
386<a name="L307"></a><tt class="py-lineno"> 307</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 class="py-name">onosIPs</tt> <tt class="py-op">)</tt> </tt>
387<a name="L308"></a><tt class="py-lineno"> 308</tt> <tt class="py-line"> </tt>
388<a name="L309"></a><tt class="py-lineno"> 309</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
389<a name="L310"></a><tt class="py-lineno"> 310</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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>
390<a name="L311"></a><tt class="py-lineno"> 311</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-89" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.getSwController" class="py-name" href="#" onclick="return doclink('link-89', 'getSwController', 'link-57');">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>
391<a name="L312"></a><tt class="py-lineno"> 312</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt> <tt class="py-string">"Response is "</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>
392<a name="L313"></a><tt class="py-lineno"> 313</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">main</tt><tt class="py-op">.</tt><tt class="py-name">onosIPs</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">response</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
393<a name="L314"></a><tt class="py-lineno"> 314</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">switch_mastership</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>
394<a name="L315"></a><tt class="py-lineno"> 315</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
395<a name="L316"></a><tt class="py-lineno"> 316</tt> <tt class="py-line"> <tt class="py-name">switch_mastership</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
396<a name="L317"></a><tt class="py-lineno"> 317</tt> <tt class="py-line"> </tt>
397<a name="L318"></a><tt class="py-lineno"> 318</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switch_mastership</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>
398<a name="L319"></a><tt class="py-lineno"> 319</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-90" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-90', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Controller assignment successfull"</tt> <tt class="py-op">)</tt> </tt>
399<a name="L320"></a><tt class="py-lineno"> 320</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
400<a name="L321"></a><tt class="py-lineno"> 321</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-91" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-91', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Controller assignment failed"</tt> <tt class="py-op">)</tt> </tt>
401<a name="L322"></a><tt class="py-lineno"> 322</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>
402<a name="L323"></a><tt class="py-lineno"> 323</tt> <tt class="py-line"> </tt>
403<a name="L324"></a><tt class="py-lineno"> 324</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-92" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-92', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Balance devices across controllers"</tt> <tt class="py-op">)</tt> </tt>
404<a name="L325"></a><tt class="py-lineno"> 325</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">int</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 class="py-op">:</tt> </tt>
405<a name="L326"></a><tt class="py-lineno"> 326</tt> <tt class="py-line"> <tt class="py-name">balanceResult</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-93" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.balanceMasters" class="py-name" href="#" onclick="return doclink('link-93', 'balanceMasters', 'link-61');">balanceMasters</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
406<a name="L327"></a><tt class="py-lineno"> 327</tt> <tt class="py-line"> <tt class="py-comment"># giving some breathing time for ONOS to complete re-balance</tt> </tt>
407<a name="L328"></a><tt class="py-lineno"> 328</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">3</tt> <tt class="py-op">)</tt> </tt>
408<a name="L329"></a><tt class="py-lineno"> 329</tt> <tt class="py-line"> </tt>
409<a name="L330"></a><tt class="py-lineno"> 330</tt> <tt class="py-line"> <tt class="py-name">case22Result</tt> <tt class="py-op">=</tt> <tt class="py-name">switch_mastership</tt> </tt>
410<a name="L331"></a><tt class="py-lineno"> 331</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>
411<a name="L332"></a><tt class="py-lineno"> 332</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>
412<a name="L333"></a><tt class="py-lineno"> 333</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>
413<a name="L334"></a><tt class="py-lineno"> 334</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case22Result</tt><tt class="py-op">,</tt> </tt>
414<a name="L335"></a><tt class="py-lineno"> 335</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Starting new Spine topology test PASS"</tt><tt class="py-op">,</tt> </tt>
415<a name="L336"></a><tt class="py-lineno"> 336</tt> <tt class="py-line"> <tt id="link-94" class="py-name"><a title="TestON.core.teston.TestON.onfail
416TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-94', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Starting new Spine topology test FAIL"</tt> <tt class="py-op">)</tt> </tt>
417</div><a name="L337"></a><tt class="py-lineno"> 337</tt> <tt class="py-line"> </tt>
418<a name="CHOtest.CASE3"></a><div id="CHOtest.CASE3-def"><a name="L338"></a><tt class="py-lineno"> 338</tt> <a class="py-toggle" href="#" id="CHOtest.CASE3-toggle" onclick="return toggle('CHOtest.CASE3');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-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>
419</div><div id="CHOtest.CASE3-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE3-expanded"><a name="L339"></a><tt class="py-lineno"> 339</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
420<a name="L340"></a><tt class="py-lineno"> 340</tt> <tt class="py-line"><tt class="py-docstring"> This Test case will be extended to collect and store more data related</tt> </tt>
421<a name="L341"></a><tt class="py-lineno"> 341</tt> <tt class="py-line"><tt class="py-docstring"> ONOS state.</tt> </tt>
422<a name="L342"></a><tt class="py-lineno"> 342</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
423<a name="L343"></a><tt class="py-lineno"> 343</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
424<a name="L344"></a><tt class="py-lineno"> 344</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
425<a name="L345"></a><tt class="py-lineno"> 345</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
426<a name="L346"></a><tt class="py-lineno"> 346</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
427<a name="L347"></a><tt class="py-lineno"> 347</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceLinks</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
428<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 class="py-name">deviceActiveLinksCount</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
429<a name="L349"></a><tt class="py-lineno"> 349</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">devicePortsEnabledCount</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
430<a name="L350"></a><tt class="py-lineno"> 350</tt> <tt class="py-line"> </tt>
431<a name="L351"></a><tt class="py-lineno"> 351</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-95" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-95', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
432<a name="L352"></a><tt class="py-lineno"> 352</tt> <tt class="py-line"> <tt class="py-string">"Collect and Store topology details from ONOS before running any Tests"</tt> <tt class="py-op">)</tt> </tt>
433<a name="L353"></a><tt class="py-lineno"> 353</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-96" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-96', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
434<a name="L354"></a><tt class="py-lineno"> 354</tt> <tt class="py-line"> <tt class="py-string">"____________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
435<a name="L355"></a><tt class="py-lineno"> 355</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-97" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-97', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collect and Store Topology Details from ONOS"</tt> <tt class="py-op">)</tt> </tt>
436<a name="L356"></a><tt class="py-lineno"> 356</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-98" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-98', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collect and store current number of switches and links"</tt> <tt class="py-op">)</tt> </tt>
437<a name="L357"></a><tt class="py-lineno"> 357</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-99" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
438TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-99', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
439<a name="L358"></a><tt class="py-lineno"> 358</tt> <tt class="py-line"> <tt class="py-name">topology_result</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-100" class="py-name"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.getTopology" class="py-name" href="#" onclick="return doclink('link-100', 'getTopology', 'link-63');">getTopology</a></tt><tt class="py-op">(</tt> <tt class="py-name">topology_output</tt> <tt class="py-op">)</tt> </tt>
440<a name="L359"></a><tt class="py-lineno"> 359</tt> <tt class="py-line"> <tt class="py-name">numOnosDevices</tt> <tt class="py-op">=</tt> <tt class="py-name">topology_result</tt><tt class="py-op">[</tt> <tt class="py-string">'devices'</tt> <tt class="py-op">]</tt> </tt>
441<a name="L360"></a><tt class="py-lineno"> 360</tt> <tt class="py-line"> <tt class="py-name">numOnosLinks</tt> <tt class="py-op">=</tt> <tt class="py-name">topology_result</tt><tt class="py-op">[</tt> <tt class="py-string">'links'</tt> <tt class="py-op">]</tt> </tt>
442<a name="L361"></a><tt class="py-lineno"> 361</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">TRUE</tt> </tt>
443<a name="L362"></a><tt class="py-lineno"> 362</tt> <tt class="py-line"> </tt>
444<a name="L363"></a><tt class="py-lineno"> 363</tt> <tt class="py-line"> <tt class="py-keyword">if</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">numMNswitches</tt> <tt class="py-op">==</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">numOnosDevices</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNlinks</tt> <tt class="py-op">==</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">numOnosLinks</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
445<a name="L364"></a><tt class="py-lineno"> 364</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-101" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-101', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Store Device DPIDs"</tt> <tt class="py-op">)</tt> </tt>
446<a name="L365"></a><tt class="py-lineno"> 365</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-op">(</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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>
447<a name="L366"></a><tt class="py-lineno"> 366</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"of:00000000000000"</tt> <tt class="py-op">+</tt> <tt class="py-name">format</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-string">'02x'</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
448<a name="L367"></a><tt class="py-lineno"> 367</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Device DPIDs in Store: \n"</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">deviceDPIDs</tt> <tt class="py-op">)</tt> </tt>
449<a name="L368"></a><tt class="py-lineno"> 368</tt> <tt class="py-line"> </tt>
450<a name="L369"></a><tt class="py-lineno"> 369</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-102" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-102', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Store Host MACs"</tt> <tt class="py-op">)</tt> </tt>
451<a name="L370"></a><tt class="py-lineno"> 370</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-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNhosts</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>
452<a name="L371"></a><tt class="py-lineno"> 371</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-string">"00:00:00:00:00:"</tt> <tt class="py-op">+</tt> <tt class="py-name">format</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-string">'02x'</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"/-1"</tt> <tt class="py-op">)</tt> </tt>
453<a name="L372"></a><tt class="py-lineno"> 372</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Host MACs in Store: \n"</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">hostMACs</tt> <tt class="py-op">)</tt> </tt>
454<a name="L373"></a><tt class="py-lineno"> 373</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
455<a name="L374"></a><tt class="py-lineno"> 374</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Creating dictionary of DPID and HostMacs"</tt> </tt>
456<a name="L375"></a><tt class="py-lineno"> 375</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">hostMACs</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
457<a name="L376"></a><tt class="py-lineno"> 376</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">[</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</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">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</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">'/'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
458<a name="L377"></a><tt class="py-lineno"> 377</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">MACsDict</tt> </tt>
459<a name="L378"></a><tt class="py-lineno"> 378</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-103" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-103', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collect and store all Devices Links"</tt> <tt class="py-op">)</tt> </tt>
460<a name="L379"></a><tt class="py-lineno"> 379</tt> <tt class="py-line"> <tt class="py-name">linksResult</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" 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
461TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-104', 'links', 'link-104');">links</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>
462<a name="L380"></a><tt class="py-lineno"> 380</tt> <tt class="py-line"> <tt class="py-name">ansi_escape</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt> <tt class="py-string">r'\x1b[^m]*m'</tt> <tt class="py-op">)</tt> </tt>
463<a name="L381"></a><tt class="py-lineno"> 381</tt> <tt class="py-line"> <tt class="py-name">linksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">ansi_escape</tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt> <tt class="py-string">''</tt><tt class="py-op">,</tt> <tt class="py-name">linksResult</tt> <tt class="py-op">)</tt> </tt>
464<a name="L382"></a><tt class="py-lineno"> 382</tt> <tt class="py-line"> <tt class="py-name">linksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">linksResult</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">" links"</tt><tt class="py-op">,</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">"\r\r"</tt><tt class="py-op">,</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt>
465<a name="L383"></a><tt class="py-lineno"> 383</tt> <tt class="py-line"> <tt class="py-name">linksResult</tt> <tt class="py-op">=</tt> <tt class="py-name">linksResult</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
466<a name="L384"></a><tt class="py-lineno"> 384</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceLinks</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt> <tt class="py-name">linksResult</tt> <tt class="py-op">)</tt> </tt>
467<a name="L385"></a><tt class="py-lineno"> 385</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Device Links Stored: \n"</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">deviceLinks</tt> <tt class="py-op">)</tt> </tt>
468<a name="L386"></a><tt class="py-lineno"> 386</tt> <tt class="py-line"> <tt class="py-comment"># this will be asserted to check with the params provided count of</tt> </tt>
469<a name="L387"></a><tt class="py-lineno"> 387</tt> <tt class="py-line"> <tt class="py-comment"># links</tt> </tt>
470<a name="L388"></a><tt class="py-lineno"> 388</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Length of Links Store"</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">deviceLinks</tt> <tt class="py-op">)</tt> </tt>
471<a name="L389"></a><tt class="py-lineno"> 389</tt> <tt class="py-line"> </tt>
472<a name="L390"></a><tt class="py-lineno"> 390</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-105" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-105', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collect and store each Device ports enabled Count"</tt> <tt class="py-op">)</tt> </tt>
473<a name="L391"></a><tt class="py-lineno"> 391</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>
474<a name="L392"></a><tt class="py-lineno"> 392</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">xrange</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">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">int</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 class="py-op">:</tt> </tt>
475<a name="L393"></a><tt class="py-lineno"> 393</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
476<a name="L394"></a><tt class="py-lineno"> 394</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-106" 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
477TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-106', 'cli', 'link-106');">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>
478<a name="L395"></a><tt class="py-lineno"> 395</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
479<a name="L396"></a><tt class="py-lineno"> 396</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
480<a name="L397"></a><tt class="py-lineno"> 397</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">"of:00000000000000"</tt> <tt class="py-op">+</tt> <tt class="py-name">format</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-string">'02x'</tt> <tt class="py-op">)</tt> </tt>
481<a name="L398"></a><tt class="py-lineno"> 398</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-107" class="py-name"><a title="TestON.core.Thread
482TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-107', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt><tt class="py-name">target</tt> <tt class="py-op">=</tt> <tt id="link-108" class="py-name"><a title="TestON.bin.cli
483TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-108', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-109" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevicePortsEnabledCount()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getDevicePortsEnabledCount"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevicePortsEnabledCount" class="py-name" href="#" onclick="return doclink('link-109', 'getDevicePortsEnabledCount', 'link-109');">getDevicePortsEnabledCount</a></tt><tt class="py-op">,</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> <tt class="py-name">name</tt> <tt class="py-op">=</tt> <tt class="py-string">"getDevicePortsEnabledCount"</tt><tt class="py-op">,</tt><tt class="py-name">args</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">dpid</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
484<a name="L399"></a><tt class="py-lineno"> 399</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>
485<a name="L400"></a><tt class="py-lineno"> 400</tt> <tt class="py-line"> <tt class="py-name">pool</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>
486<a name="L401"></a><tt class="py-lineno"> 401</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
487<a name="L402"></a><tt class="py-lineno"> 402</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
488<a name="L403"></a><tt class="py-lineno"> 403</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
489<a name="L404"></a><tt class="py-lineno"> 404</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
490<a name="L405"></a><tt class="py-lineno"> 405</tt> <tt class="py-line"> <tt class="py-name">portResult</tt> <tt class="py-op">=</tt> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
491<a name="L406"></a><tt class="py-lineno"> 406</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">devicePortsEnabledCount</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">portResult</tt> <tt class="py-op">)</tt> </tt>
492<a name="L407"></a><tt class="py-lineno"> 407</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Device Enabled Port Counts Stored: \n"</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">devicePortsEnabledCount</tt> <tt class="py-op">)</tt> </tt>
493<a name="L408"></a><tt class="py-lineno"> 408</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>
494<a name="L409"></a><tt class="py-lineno"> 409</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-110" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-110', 'log', 'link-2');">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 counting enabled ports of the switches: %2f seconds"</tt> <tt class="py-op">%</tt><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>
495<a name="L410"></a><tt class="py-lineno"> 410</tt> <tt class="py-line"> </tt>
496<a name="L411"></a><tt class="py-lineno"> 411</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-111" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-111', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Collect and store each Device active links Count"</tt> <tt class="py-op">)</tt> </tt>
497<a name="L412"></a><tt class="py-lineno"> 412</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>
498<a name="L413"></a><tt class="py-lineno"> 413</tt> <tt class="py-line"> </tt>
499<a name="L414"></a><tt class="py-lineno"> 414</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">xrange</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">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">int</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 class="py-op">:</tt> </tt>
500<a name="L415"></a><tt class="py-lineno"> 415</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
501<a name="L416"></a><tt class="py-lineno"> 416</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-112" class="py-name"><a title="TestON.bin.cli
502TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-112', 'cli', 'link-106');">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>
503<a name="L417"></a><tt class="py-lineno"> 417</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
504<a name="L418"></a><tt class="py-lineno"> 418</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
505<a name="L419"></a><tt class="py-lineno"> 419</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">"of:00000000000000"</tt> <tt class="py-op">+</tt> <tt class="py-name">format</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-string">'02x'</tt> <tt class="py-op">)</tt> </tt>
506<a name="L420"></a><tt class="py-lineno"> 420</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-113" class="py-name"><a title="TestON.core.Thread
507TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-113', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt> <tt class="py-op">=</tt> <tt id="link-114" class="py-name"><a title="TestON.bin.cli
508TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-114', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-115" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDeviceLinksActiveCount()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getDeviceLinksActiveCount"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDeviceLinksActiveCount" class="py-name" href="#" onclick="return doclink('link-115', 'getDeviceLinksActiveCount', 'link-115');">getDeviceLinksActiveCount</a></tt><tt class="py-op">,</tt> </tt>
509<a name="L421"></a><tt class="py-lineno"> 421</tt> <tt class="py-line"> <tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
510<a name="L422"></a><tt class="py-lineno"> 422</tt> <tt class="py-line"> <tt class="py-name">name</tt> <tt class="py-op">=</tt> <tt class="py-string">"getDevicePortsEnabledCount"</tt><tt class="py-op">,</tt> </tt>
511<a name="L423"></a><tt class="py-lineno"> 423</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">dpid</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
512<a name="L424"></a><tt class="py-lineno"> 424</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>
513<a name="L425"></a><tt class="py-lineno"> 425</tt> <tt class="py-line"> <tt class="py-name">pool</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>
514<a name="L426"></a><tt class="py-lineno"> 426</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
515<a name="L427"></a><tt class="py-lineno"> 427</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
516<a name="L428"></a><tt class="py-lineno"> 428</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
517<a name="L429"></a><tt class="py-lineno"> 429</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
518<a name="L430"></a><tt class="py-lineno"> 430</tt> <tt class="py-line"> <tt class="py-name">linkCountResult</tt> <tt class="py-op">=</tt> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
519<a name="L431"></a><tt class="py-lineno"> 431</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceActiveLinksCount</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">linkCountResult</tt> <tt class="py-op">)</tt> </tt>
520<a name="L432"></a><tt class="py-lineno"> 432</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Device Active Links Count Stored: \n"</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">deviceActiveLinksCount</tt> <tt class="py-op">)</tt> </tt>
521<a name="L433"></a><tt class="py-lineno"> 433</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>
522<a name="L434"></a><tt class="py-lineno"> 434</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-116', 'log', 'link-2');">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 counting all enabled links of the switches: %2f seconds"</tt> <tt class="py-op">%</tt><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>
523<a name="L435"></a><tt class="py-lineno"> 435</tt> <tt class="py-line"> </tt>
524<a name="L436"></a><tt class="py-lineno"> 436</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
525<a name="L437"></a><tt class="py-lineno"> 437</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-117" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-117', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Devices (expected): %s, Links (expected): %s"</tt> <tt class="py-op">%</tt> </tt>
526<a name="L438"></a><tt class="py-lineno"> 438</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">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
527<a name="L439"></a><tt class="py-lineno"> 439</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Devices (actual): %s, Links (actual): %s"</tt> <tt class="py-op">%</tt> </tt>
528<a name="L440"></a><tt class="py-lineno"> 440</tt> <tt class="py-line"> <tt class="py-op">(</tt> <tt class="py-name">numOnosDevices</tt> <tt class="py-op">,</tt> <tt class="py-name">numOnosLinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
529<a name="L441"></a><tt class="py-lineno"> 441</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-119" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-119', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Topology does not match, exiting CHO test..."</tt><tt class="py-op">)</tt> </tt>
530<a name="L442"></a><tt class="py-lineno"> 442</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>
531<a name="L443"></a><tt class="py-lineno"> 443</tt> <tt class="py-line"> <tt class="py-comment"># It's better exit here from running the test</tt> </tt>
532<a name="L444"></a><tt class="py-lineno"> 444</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-120" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-120', 'cleanup', 'link-43');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
533<a name="L445"></a><tt class="py-lineno"> 445</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-121" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-121', 'exit', 'link-11');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
534<a name="L446"></a><tt class="py-lineno"> 446</tt> <tt class="py-line"> </tt>
535<a name="L447"></a><tt class="py-lineno"> 447</tt> <tt class="py-line"> <tt class="py-comment"># just returning TRUE for now as this one just collects data</tt> </tt>
536<a name="L448"></a><tt class="py-lineno"> 448</tt> <tt class="py-line"> <tt class="py-name">case3Result</tt> <tt class="py-op">=</tt> <tt class="py-name">topoResult</tt> </tt>
537<a name="L449"></a><tt class="py-lineno"> 449</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">case3Result</tt><tt class="py-op">,</tt> </tt>
538<a name="L450"></a><tt class="py-lineno"> 450</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Saving ONOS topology data test PASS"</tt><tt class="py-op">,</tt> </tt>
539<a name="L451"></a><tt class="py-lineno"> 451</tt> <tt class="py-line"> <tt id="link-122" class="py-name"><a title="TestON.core.teston.TestON.onfail
540TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-122', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Saving ONOS topology data test FAIL"</tt> <tt class="py-op">)</tt> </tt>
541</div><a name="L452"></a><tt class="py-lineno"> 452</tt> <tt class="py-line"> </tt>
542<a name="CHOtest.CASE40"></a><div id="CHOtest.CASE40-def"><a name="L453"></a><tt class="py-lineno"> 453</tt> <a class="py-toggle" href="#" id="CHOtest.CASE40-toggle" onclick="return toggle('CHOtest.CASE40');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE40">CASE40</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>
543</div><div id="CHOtest.CASE40-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE40-expanded"><a name="L454"></a><tt class="py-lineno"> 454</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
544<a name="L455"></a><tt class="py-lineno"> 455</tt> <tt class="py-line"><tt class="py-docstring"> Verify Reactive forwarding (Att Topology)</tt> </tt>
545<a name="L456"></a><tt class="py-lineno"> 456</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
546<a name="L457"></a><tt class="py-lineno"> 457</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
547<a name="L458"></a><tt class="py-lineno"> 458</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
548<a name="L459"></a><tt class="py-lineno"> 459</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
549<a name="L460"></a><tt class="py-lineno"> 460</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-123', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Reactive forwarding (Att Topology)"</tt> <tt class="py-op">)</tt> </tt>
550<a name="L461"></a><tt class="py-lineno"> 461</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-124" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-124', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"______________________________________________"</tt> <tt class="py-op">)</tt> </tt>
551<a name="L462"></a><tt class="py-lineno"> 462</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-125" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-125', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Reactive forwarding and Verify ping all"</tt> <tt class="py-op">)</tt> </tt>
552<a name="L463"></a><tt class="py-lineno"> 463</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-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
553<a name="L464"></a><tt class="py-lineno"> 464</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
554<a name="L465"></a><tt class="py-lineno"> 465</tt> <tt class="py-line"> <tt class="py-comment"># Activate fwd app</tt> </tt>
555<a name="L466"></a><tt class="py-lineno"> 466</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-127" 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
556TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp" class="py-name" href="#" onclick="return doclink('link-127', 'activateApp', 'link-127');">activateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
557<a name="L467"></a><tt class="py-lineno"> 467</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>
558<a name="L468"></a><tt class="py-lineno"> 468</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
559<a name="L469"></a><tt class="py-lineno"> 469</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-128" class="py-name"><a title="TestON.bin.cli
560TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-128', 'cli', 'link-106');">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>
561<a name="L470"></a><tt class="py-lineno"> 470</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-129" class="py-name"><a title="TestON.core.Thread
562TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-129', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-130" class="py-name"><a title="TestON.bin.cli
563TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-130', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-131" 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-131', 'appToIDCheck', 'link-131');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
564<a name="L471"></a><tt class="py-lineno"> 471</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>
565<a name="L472"></a><tt class="py-lineno"> 472</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>
566<a name="L473"></a><tt class="py-lineno"> 473</tt> <tt class="py-line"> <tt class="py-name">pool</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>
567<a name="L474"></a><tt class="py-lineno"> 474</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>
568<a name="L475"></a><tt class="py-lineno"> 475</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">pool</tt><tt class="py-op">:</tt> </tt>
569<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">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
570<a name="L477"></a><tt class="py-lineno"> 477</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>
571<a name="L478"></a><tt class="py-lineno"> 478</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>
572<a name="L479"></a><tt class="py-lineno"> 479</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>
573<a name="L480"></a><tt class="py-lineno"> 480</tt> <tt class="py-line"> <tt id="link-132" class="py-name"><a title="TestON.core.teston.TestON.onfail
574TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-132', 'onfail', 'link-6');">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>
575<a name="L481"></a><tt class="py-lineno"> 481</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>
576<a name="L482"></a><tt class="py-lineno"> 482</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-133" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-133', 'log', 'link-2');">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-134" 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
577TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-134', 'apps', 'link-134');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
578<a name="L483"></a><tt class="py-lineno"> 483</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-135" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-135', 'log', 'link-2');">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-136" 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-136', 'appIDs', 'link-136');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
579<a name="L484"></a><tt class="py-lineno"> 484</tt> <tt class="py-line"> </tt>
580<a name="L485"></a><tt class="py-lineno"> 485</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>
581<a name="L486"></a><tt class="py-lineno"> 486</tt> <tt class="py-line"> </tt>
582<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-137" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-137', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Pingall"</tt> <tt class="py-op">)</tt> </tt>
583<a name="L488"></a><tt class="py-lineno"> 488</tt> <tt class="py-line"> <tt class="py-name">ping_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>
584<a name="L489"></a><tt class="py-lineno"> 489</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>
585<a name="L490"></a><tt class="py-lineno"> 490</tt> <tt class="py-line"> <tt class="py-name">ping_result</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-138" 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-138', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">)</tt> </tt>
586<a name="L491"></a><tt class="py-lineno"> 491</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>
587<a name="L492"></a><tt class="py-lineno"> 492</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
588<a name="L493"></a><tt class="py-lineno"> 493</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-139" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-139', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
589<a name="L494"></a><tt class="py-lineno"> 494</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
590<a name="L495"></a><tt class="py-lineno"> 495</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
591<a name="L496"></a><tt class="py-lineno"> 496</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
592<a name="L497"></a><tt class="py-lineno"> 497</tt> <tt class="py-line"> </tt>
593<a name="L498"></a><tt class="py-lineno"> 498</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ping_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 class="py-op">:</tt> </tt>
594<a name="L499"></a><tt class="py-lineno"> 499</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-140" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-140', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode successful"</tt> <tt class="py-op">)</tt> </tt>
595<a name="L500"></a><tt class="py-lineno"> 500</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
596<a name="L501"></a><tt class="py-lineno"> 501</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-141', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode failed"</tt> <tt class="py-op">)</tt> </tt>
597<a name="L502"></a><tt class="py-lineno"> 502</tt> <tt class="py-line"> </tt>
598<a name="L503"></a><tt class="py-lineno"> 503</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-142" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-142', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Disable Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
599<a name="L504"></a><tt class="py-lineno"> 504</tt> <tt class="py-line"> </tt>
600<a name="L505"></a><tt class="py-lineno"> 505</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-143" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-143', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstall reactive forwarding app"</tt> <tt class="py-op">)</tt> </tt>
601<a name="L506"></a><tt class="py-lineno"> 506</tt> <tt class="py-line"> <tt class="py-name">appResults</tt> <tt class="py-op">=</tt> <tt class="py-name">appResults</tt> <tt class="py-keyword">and</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-144" 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
602TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deactivateApp" class="py-name" href="#" onclick="return doclink('link-144', 'deactivateApp', 'link-144');">deactivateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
603<a name="L507"></a><tt class="py-lineno"> 507</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
604<a name="L508"></a><tt class="py-lineno"> 508</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-145" class="py-name"><a title="TestON.bin.cli
605TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-145', 'cli', 'link-106');">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>
606<a name="L509"></a><tt class="py-lineno"> 509</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-146" class="py-name"><a title="TestON.core.Thread
607TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-146', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-147" class="py-name"><a title="TestON.bin.cli
608TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-147', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-148" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-148', 'appToIDCheck', 'link-131');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
609<a name="L510"></a><tt class="py-lineno"> 510</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>
610<a name="L511"></a><tt class="py-lineno"> 511</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>
611<a name="L512"></a><tt class="py-lineno"> 512</tt> <tt class="py-line"> <tt class="py-name">pool</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>
612<a name="L513"></a><tt class="py-lineno"> 513</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>
613<a name="L514"></a><tt class="py-lineno"> 514</tt> <tt class="py-line"> </tt>
614<a name="L515"></a><tt class="py-lineno"> 515</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">pool</tt><tt class="py-op">:</tt> </tt>
615<a name="L516"></a><tt class="py-lineno"> 516</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>
616<a name="L517"></a><tt class="py-lineno"> 517</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>
617<a name="L518"></a><tt class="py-lineno"> 518</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>
618<a name="L519"></a><tt class="py-lineno"> 519</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>
619<a name="L520"></a><tt class="py-lineno"> 520</tt> <tt class="py-line"> <tt id="link-149" class="py-name"><a title="TestON.core.teston.TestON.onfail
620TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-149', 'onfail', 'link-6');">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>
621<a name="L521"></a><tt class="py-lineno"> 521</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>
622<a name="L522"></a><tt class="py-lineno"> 522</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-2');">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-151" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
623TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-151', 'apps', 'link-134');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
624<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-152" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-152', 'log', 'link-2');">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-153" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-153', 'appIDs', 'link-136');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
625<a name="L524"></a><tt class="py-lineno"> 524</tt> <tt class="py-line"> </tt>
626<a name="L525"></a><tt class="py-lineno"> 525</tt> <tt class="py-line"> <tt class="py-comment"># Waiting for reative flows to be cleared.</tt> </tt>
627<a name="L526"></a><tt class="py-lineno"> 526</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>
628<a name="L527"></a><tt class="py-lineno"> 527</tt> <tt class="py-line"> <tt class="py-name">case40Result</tt> <tt class="py-op">=</tt> <tt class="py-name">installResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">uninstallResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ping_result</tt> </tt>
629<a name="L528"></a><tt class="py-lineno"> 528</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">case40Result</tt><tt class="py-op">,</tt> </tt>
630<a name="L529"></a><tt class="py-lineno"> 529</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Mode Pingall test PASS"</tt><tt class="py-op">,</tt> </tt>
631<a name="L530"></a><tt class="py-lineno"> 530</tt> <tt class="py-line"> <tt id="link-154" class="py-name"><a title="TestON.core.teston.TestON.onfail
632TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-154', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Mode Pingall test FAIL"</tt> <tt class="py-op">)</tt> </tt>
633</div><a name="L531"></a><tt class="py-lineno"> 531</tt> <tt class="py-line"> </tt>
634<a name="CHOtest.CASE41"></a><div id="CHOtest.CASE41-def"><a name="L532"></a><tt class="py-lineno"> 532</tt> <a class="py-toggle" href="#" id="CHOtest.CASE41-toggle" onclick="return toggle('CHOtest.CASE41');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE41">CASE41</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>
635</div><div id="CHOtest.CASE41-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE41-expanded"><a name="L533"></a><tt class="py-lineno"> 533</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
636<a name="L534"></a><tt class="py-lineno"> 534</tt> <tt class="py-line"><tt class="py-docstring"> Verify Reactive forwarding (Chordal Topology)</tt> </tt>
637<a name="L535"></a><tt class="py-lineno"> 535</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
638<a name="L536"></a><tt class="py-lineno"> 536</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
639<a name="L537"></a><tt class="py-lineno"> 537</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
640<a name="L538"></a><tt class="py-lineno"> 538</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
641<a name="L539"></a><tt class="py-lineno"> 539</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Reactive forwarding (Chordal Topology)"</tt> <tt class="py-op">)</tt> </tt>
642<a name="L540"></a><tt class="py-lineno"> 540</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-156" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-156', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"______________________________________________"</tt> <tt class="py-op">)</tt> </tt>
643<a name="L541"></a><tt class="py-lineno"> 541</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-157', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Reactive forwarding and Verify ping all"</tt> <tt class="py-op">)</tt> </tt>
644<a name="L542"></a><tt class="py-lineno"> 542</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-158" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-158', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
645<a name="L543"></a><tt class="py-lineno"> 543</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
646<a name="L544"></a><tt class="py-lineno"> 544</tt> <tt class="py-line"> <tt class="py-comment"># Activate fwd app</tt> </tt>
647<a name="L545"></a><tt class="py-lineno"> 545</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-159" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.activateApp
648TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp" class="py-name" href="#" onclick="return doclink('link-159', 'activateApp', 'link-127');">activateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
649<a name="L546"></a><tt class="py-lineno"> 546</tt> <tt class="py-line"> </tt>
650<a name="L547"></a><tt class="py-lineno"> 547</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>
651<a name="L548"></a><tt class="py-lineno"> 548</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
652<a name="L549"></a><tt class="py-lineno"> 549</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-160" class="py-name"><a title="TestON.bin.cli
653TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-160', 'cli', 'link-106');">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>
654<a name="L550"></a><tt class="py-lineno"> 550</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-161" class="py-name"><a title="TestON.core.Thread
655TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-161', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-162" class="py-name"><a title="TestON.bin.cli
656TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-162', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-163" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-163', 'appToIDCheck', 'link-131');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
657<a name="L551"></a><tt class="py-lineno"> 551</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>
658<a name="L552"></a><tt class="py-lineno"> 552</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>
659<a name="L553"></a><tt class="py-lineno"> 553</tt> <tt class="py-line"> <tt class="py-name">pool</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>
660<a name="L554"></a><tt class="py-lineno"> 554</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>
661<a name="L555"></a><tt class="py-lineno"> 555</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">pool</tt><tt class="py-op">:</tt> </tt>
662<a name="L556"></a><tt class="py-lineno"> 556</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>
663<a name="L557"></a><tt class="py-lineno"> 557</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>
664<a name="L558"></a><tt class="py-lineno"> 558</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>
665<a name="L559"></a><tt class="py-lineno"> 559</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>
666<a name="L560"></a><tt class="py-lineno"> 560</tt> <tt class="py-line"> <tt id="link-164" class="py-name"><a title="TestON.core.teston.TestON.onfail
667TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-164', 'onfail', 'link-6');">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>
668<a name="L561"></a><tt class="py-lineno"> 561</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>
669<a name="L562"></a><tt class="py-lineno"> 562</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-165" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-165', 'log', 'link-2');">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-166" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
670TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-166', 'apps', 'link-134');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
671<a name="L563"></a><tt class="py-lineno"> 563</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-167" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-167', 'log', 'link-2');">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-168" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-168', 'appIDs', 'link-136');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
672<a name="L564"></a><tt class="py-lineno"> 564</tt> <tt class="py-line"> </tt>
673<a name="L565"></a><tt class="py-lineno"> 565</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>
674<a name="L566"></a><tt class="py-lineno"> 566</tt> <tt class="py-line"> </tt>
675<a name="L567"></a><tt class="py-lineno"> 567</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-169', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Pingall"</tt> <tt class="py-op">)</tt> </tt>
676<a name="L568"></a><tt class="py-lineno"> 568</tt> <tt class="py-line"> <tt class="py-name">ping_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>
677<a name="L569"></a><tt class="py-lineno"> 569</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>
678<a name="L570"></a><tt class="py-lineno"> 570</tt> <tt class="py-line"> <tt class="py-name">ping_result</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-170" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-170', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">)</tt> </tt>
679<a name="L571"></a><tt class="py-lineno"> 571</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>
680<a name="L572"></a><tt class="py-lineno"> 572</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
681<a name="L573"></a><tt class="py-lineno"> 573</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-171" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-171', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
682<a name="L574"></a><tt class="py-lineno"> 574</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
683<a name="L575"></a><tt class="py-lineno"> 575</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
684<a name="L576"></a><tt class="py-lineno"> 576</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
685<a name="L577"></a><tt class="py-lineno"> 577</tt> <tt class="py-line"> </tt>
686<a name="L578"></a><tt class="py-lineno"> 578</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ping_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 class="py-op">:</tt> </tt>
687<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-172" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-172', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode successful"</tt> <tt class="py-op">)</tt> </tt>
688<a name="L580"></a><tt class="py-lineno"> 580</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
689<a name="L581"></a><tt class="py-lineno"> 581</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-173" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-173', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode failed"</tt> <tt class="py-op">)</tt> </tt>
690<a name="L582"></a><tt class="py-lineno"> 582</tt> <tt class="py-line"> </tt>
691<a name="L583"></a><tt class="py-lineno"> 583</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-174', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Disable Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
692<a name="L584"></a><tt class="py-lineno"> 584</tt> <tt class="py-line"> </tt>
693<a name="L585"></a><tt class="py-lineno"> 585</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-175" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-175', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstall reactive forwarding app"</tt> <tt class="py-op">)</tt> </tt>
694<a name="L586"></a><tt class="py-lineno"> 586</tt> <tt class="py-line"> <tt class="py-name">appResults</tt> <tt class="py-op">=</tt> <tt class="py-name">appResults</tt> <tt class="py-keyword">and</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-176" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.deactivateApp
695TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deactivateApp" class="py-name" href="#" onclick="return doclink('link-176', 'deactivateApp', 'link-144');">deactivateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
696<a name="L587"></a><tt class="py-lineno"> 587</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
697<a name="L588"></a><tt class="py-lineno"> 588</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-177" class="py-name"><a title="TestON.bin.cli
698TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-177', 'cli', 'link-106');">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>
699<a name="L589"></a><tt class="py-lineno"> 589</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-178" class="py-name"><a title="TestON.core.Thread
700TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-178', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-179" class="py-name"><a title="TestON.bin.cli
701TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-179', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-180" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-180', 'appToIDCheck', 'link-131');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
702<a name="L590"></a><tt class="py-lineno"> 590</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>
703<a name="L591"></a><tt class="py-lineno"> 591</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>
704<a name="L592"></a><tt class="py-lineno"> 592</tt> <tt class="py-line"> <tt class="py-name">pool</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>
705<a name="L593"></a><tt class="py-lineno"> 593</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>
706<a name="L594"></a><tt class="py-lineno"> 594</tt> <tt class="py-line"> </tt>
707<a name="L595"></a><tt class="py-lineno"> 595</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">pool</tt><tt class="py-op">:</tt> </tt>
708<a name="L596"></a><tt class="py-lineno"> 596</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>
709<a name="L597"></a><tt class="py-lineno"> 597</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>
710<a name="L598"></a><tt class="py-lineno"> 598</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>
711<a name="L599"></a><tt class="py-lineno"> 599</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>
712<a name="L600"></a><tt class="py-lineno"> 600</tt> <tt class="py-line"> <tt id="link-181" class="py-name"><a title="TestON.core.teston.TestON.onfail
713TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-181', 'onfail', 'link-6');">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>
714<a name="L601"></a><tt class="py-lineno"> 601</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>
715<a name="L602"></a><tt class="py-lineno"> 602</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-182" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-182', 'log', 'link-2');">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-183" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
716TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-183', 'apps', 'link-134');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
717<a name="L603"></a><tt class="py-lineno"> 603</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-184" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-184', 'log', 'link-2');">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-185" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-185', 'appIDs', 'link-136');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
718<a name="L604"></a><tt class="py-lineno"> 604</tt> <tt class="py-line"> </tt>
719<a name="L605"></a><tt class="py-lineno"> 605</tt> <tt class="py-line"> <tt class="py-comment"># Waiting for reative flows to be cleared.</tt> </tt>
720<a name="L606"></a><tt class="py-lineno"> 606</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>
721<a name="L607"></a><tt class="py-lineno"> 607</tt> <tt class="py-line"> <tt class="py-name">case41Result</tt> <tt class="py-op">=</tt> <tt class="py-name">installResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">uninstallResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ping_result</tt> </tt>
722<a name="L608"></a><tt class="py-lineno"> 608</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">case41Result</tt><tt class="py-op">,</tt> </tt>
723<a name="L609"></a><tt class="py-lineno"> 609</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Mode Pingall test PASS"</tt><tt class="py-op">,</tt> </tt>
724<a name="L610"></a><tt class="py-lineno"> 610</tt> <tt class="py-line"> <tt id="link-186" class="py-name"><a title="TestON.core.teston.TestON.onfail
725TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-186', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Mode Pingall test FAIL"</tt> <tt class="py-op">)</tt> </tt>
726</div><a name="L611"></a><tt class="py-lineno"> 611</tt> <tt class="py-line"> </tt>
727<a name="CHOtest.CASE42"></a><div id="CHOtest.CASE42-def"><a name="L612"></a><tt class="py-lineno"> 612</tt> <a class="py-toggle" href="#" id="CHOtest.CASE42-toggle" onclick="return toggle('CHOtest.CASE42');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE42">CASE42</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>
728</div><div id="CHOtest.CASE42-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE42-expanded"><a name="L613"></a><tt class="py-lineno"> 613</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
729<a name="L614"></a><tt class="py-lineno"> 614</tt> <tt class="py-line"><tt class="py-docstring"> Verify Reactive forwarding (Spine Topology)</tt> </tt>
730<a name="L615"></a><tt class="py-lineno"> 615</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
731<a name="L616"></a><tt class="py-lineno"> 616</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
732<a name="L617"></a><tt class="py-lineno"> 617</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
733<a name="L618"></a><tt class="py-lineno"> 618</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
734<a name="L619"></a><tt class="py-lineno"> 619</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Reactive forwarding (Spine Topology)"</tt> <tt class="py-op">)</tt> </tt>
735<a name="L620"></a><tt class="py-lineno"> 620</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-188" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-188', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"______________________________________________"</tt> <tt class="py-op">)</tt> </tt>
736<a name="L621"></a><tt class="py-lineno"> 621</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-189', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Reactive forwarding and Verify ping all"</tt> <tt class="py-op">)</tt> </tt>
737<a name="L622"></a><tt class="py-lineno"> 622</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-190" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-190', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
738<a name="L623"></a><tt class="py-lineno"> 623</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
739<a name="L624"></a><tt class="py-lineno"> 624</tt> <tt class="py-line"> <tt class="py-comment"># Activate fwd app</tt> </tt>
740<a name="L625"></a><tt class="py-lineno"> 625</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-191" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.activateApp
741TestON.drivers.common.cli.onosclidriver.OnosCliDriver.activateApp" class="py-name" href="#" onclick="return doclink('link-191', 'activateApp', 'link-127');">activateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
742<a name="L626"></a><tt class="py-lineno"> 626</tt> <tt class="py-line"> </tt>
743<a name="L627"></a><tt class="py-lineno"> 627</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>
744<a name="L628"></a><tt class="py-lineno"> 628</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
745<a name="L629"></a><tt class="py-lineno"> 629</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-192" class="py-name"><a title="TestON.bin.cli
746TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-192', 'cli', 'link-106');">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>
747<a name="L630"></a><tt class="py-lineno"> 630</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-193" class="py-name"><a title="TestON.core.Thread
748TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-193', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-194" class="py-name"><a title="TestON.bin.cli
749TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-194', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-195" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-195', 'appToIDCheck', 'link-131');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
750<a name="L631"></a><tt class="py-lineno"> 631</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>
751<a name="L632"></a><tt class="py-lineno"> 632</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>
752<a name="L633"></a><tt class="py-lineno"> 633</tt> <tt class="py-line"> <tt class="py-name">pool</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>
753<a name="L634"></a><tt class="py-lineno"> 634</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>
754<a name="L635"></a><tt class="py-lineno"> 635</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">pool</tt><tt class="py-op">:</tt> </tt>
755<a name="L636"></a><tt class="py-lineno"> 636</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>
756<a name="L637"></a><tt class="py-lineno"> 637</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>
757<a name="L638"></a><tt class="py-lineno"> 638</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>
758<a name="L639"></a><tt class="py-lineno"> 639</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>
759<a name="L640"></a><tt class="py-lineno"> 640</tt> <tt class="py-line"> <tt id="link-196" class="py-name"><a title="TestON.core.teston.TestON.onfail
760TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-196', 'onfail', 'link-6');">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>
761<a name="L641"></a><tt class="py-lineno"> 641</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>
762<a name="L642"></a><tt class="py-lineno"> 642</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-197" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-197', 'log', 'link-2');">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-198" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
763TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-198', 'apps', 'link-134');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
764<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-199" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-199', 'log', 'link-2');">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-200" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-200', 'appIDs', 'link-136');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
765<a name="L644"></a><tt class="py-lineno"> 644</tt> <tt class="py-line"> </tt>
766<a name="L645"></a><tt class="py-lineno"> 645</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>
767<a name="L646"></a><tt class="py-lineno"> 646</tt> <tt class="py-line"> </tt>
768<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-201" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-201', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Pingall"</tt> <tt class="py-op">)</tt> </tt>
769<a name="L648"></a><tt class="py-lineno"> 648</tt> <tt class="py-line"> <tt class="py-name">ping_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>
770<a name="L649"></a><tt class="py-lineno"> 649</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>
771<a name="L650"></a><tt class="py-lineno"> 650</tt> <tt class="py-line"> <tt class="py-name">ping_result</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-202" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-202', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">)</tt> </tt>
772<a name="L651"></a><tt class="py-lineno"> 651</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>
773<a name="L652"></a><tt class="py-lineno"> 652</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
774<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-203" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-203', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
775<a name="L654"></a><tt class="py-lineno"> 654</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
776<a name="L655"></a><tt class="py-lineno"> 655</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
777<a name="L656"></a><tt class="py-lineno"> 656</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
778<a name="L657"></a><tt class="py-lineno"> 657</tt> <tt class="py-line"> </tt>
779<a name="L658"></a><tt class="py-lineno"> 658</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ping_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 class="py-op">:</tt> </tt>
780<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-204" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-204', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode successful"</tt> <tt class="py-op">)</tt> </tt>
781<a name="L660"></a><tt class="py-lineno"> 660</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
782<a name="L661"></a><tt class="py-lineno"> 661</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode failed"</tt> <tt class="py-op">)</tt> </tt>
783<a name="L662"></a><tt class="py-lineno"> 662</tt> <tt class="py-line"> </tt>
784<a name="L663"></a><tt class="py-lineno"> 663</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-206" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-206', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Disable Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
785<a name="L664"></a><tt class="py-lineno"> 664</tt> <tt class="py-line"> </tt>
786<a name="L665"></a><tt class="py-lineno"> 665</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-207" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-207', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Uninstall reactive forwarding app"</tt> <tt class="py-op">)</tt> </tt>
787<a name="L666"></a><tt class="py-lineno"> 666</tt> <tt class="py-line"> <tt class="py-name">appResults</tt> <tt class="py-op">=</tt> <tt class="py-name">appResults</tt> <tt class="py-keyword">and</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-208" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.deactivateApp
788TestON.drivers.common.cli.onosclidriver.OnosCliDriver.deactivateApp" class="py-name" href="#" onclick="return doclink('link-208', 'deactivateApp', 'link-144');">deactivateApp</a></tt><tt class="py-op">(</tt> <tt class="py-string">"org.onosproject.fwd"</tt> <tt class="py-op">)</tt> </tt>
789<a name="L667"></a><tt class="py-lineno"> 667</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
790<a name="L668"></a><tt class="py-lineno"> 668</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-209" class="py-name"><a title="TestON.bin.cli
791TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-209', 'cli', 'link-106');">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>
792<a name="L669"></a><tt class="py-lineno"> 669</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-210" class="py-name"><a title="TestON.core.Thread
793TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-210', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-211" class="py-name"><a title="TestON.bin.cli
794TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-211', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-212" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appToIDCheck" class="py-name" href="#" onclick="return doclink('link-212', 'appToIDCheck', 'link-131');">appToIDCheck</a></tt><tt class="py-op">,</tt> </tt>
795<a name="L670"></a><tt class="py-lineno"> 670</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>
796<a name="L671"></a><tt class="py-lineno"> 671</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>
797<a name="L672"></a><tt class="py-lineno"> 672</tt> <tt class="py-line"> <tt class="py-name">pool</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>
798<a name="L673"></a><tt class="py-lineno"> 673</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>
799<a name="L674"></a><tt class="py-lineno"> 674</tt> <tt class="py-line"> </tt>
800<a name="L675"></a><tt class="py-lineno"> 675</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">pool</tt><tt class="py-op">:</tt> </tt>
801<a name="L676"></a><tt class="py-lineno"> 676</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>
802<a name="L677"></a><tt class="py-lineno"> 677</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>
803<a name="L678"></a><tt class="py-lineno"> 678</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>
804<a name="L679"></a><tt class="py-lineno"> 679</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>
805<a name="L680"></a><tt class="py-lineno"> 680</tt> <tt class="py-line"> <tt id="link-213" class="py-name"><a title="TestON.core.teston.TestON.onfail
806TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-213', 'onfail', 'link-6');">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>
807<a name="L681"></a><tt class="py-lineno"> 681</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>
808<a name="L682"></a><tt class="py-lineno"> 682</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-214" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-214', 'log', 'link-2');">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-215" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.apps
809TestON.drivers.common.cli.onosclidriver.OnosCliDriver.apps" class="py-name" href="#" onclick="return doclink('link-215', 'apps', 'link-134');">apps</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
810<a name="L683"></a><tt class="py-lineno"> 683</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-2');">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-217" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.appIDs" class="py-name" href="#" onclick="return doclink('link-217', 'appIDs', 'link-136');">appIDs</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
811<a name="L684"></a><tt class="py-lineno"> 684</tt> <tt class="py-line"> </tt>
812<a name="L685"></a><tt class="py-lineno"> 685</tt> <tt class="py-line"> <tt class="py-comment"># Waiting for reative flows to be cleared.</tt> </tt>
813<a name="L686"></a><tt class="py-lineno"> 686</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>
814<a name="L687"></a><tt class="py-lineno"> 687</tt> <tt class="py-line"> <tt class="py-name">case42Result</tt> <tt class="py-op">=</tt> <tt class="py-name">installResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">uninstallResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ping_result</tt> </tt>
815<a name="L688"></a><tt class="py-lineno"> 688</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">case42Result</tt><tt class="py-op">,</tt> </tt>
816<a name="L689"></a><tt class="py-lineno"> 689</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Mode Pingall test PASS"</tt><tt class="py-op">,</tt> </tt>
817<a name="L690"></a><tt class="py-lineno"> 690</tt> <tt class="py-line"> <tt id="link-218" class="py-name"><a title="TestON.core.teston.TestON.onfail
818TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-218', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Reactive Mode Pingall test FAIL"</tt> <tt class="py-op">)</tt> </tt>
819</div><a name="L691"></a><tt class="py-lineno"> 691</tt> <tt class="py-line"> </tt>
820<a name="CHOtest.CASE5"></a><div id="CHOtest.CASE5-def"><a name="L692"></a><tt class="py-lineno"> 692</tt> <a class="py-toggle" href="#" id="CHOtest.CASE5-toggle" onclick="return toggle('CHOtest.CASE5');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-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>
821</div><div id="CHOtest.CASE5-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE5-expanded"><a name="L693"></a><tt class="py-lineno"> 693</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
822<a name="L694"></a><tt class="py-lineno"> 694</tt> <tt class="py-line"><tt class="py-docstring"> Compare current ONOS topology with reference data</tt> </tt>
823<a name="L695"></a><tt class="py-lineno"> 695</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
824<a name="L696"></a><tt class="py-lineno"> 696</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
825<a name="L697"></a><tt class="py-lineno"> 697</tt> <tt class="py-line"> </tt>
826<a name="L698"></a><tt class="py-lineno"> 698</tt> <tt class="py-line"> <tt class="py-name">devicesDPIDTemp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
827<a name="L699"></a><tt class="py-lineno"> 699</tt> <tt class="py-line"> <tt class="py-name">hostMACsTemp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
828<a name="L700"></a><tt class="py-lineno"> 700</tt> <tt class="py-line"> <tt class="py-name">deviceLinksTemp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
829<a name="L701"></a><tt class="py-lineno"> 701</tt> <tt class="py-line"> <tt class="py-name">deviceActiveLinksCountTemp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
830<a name="L702"></a><tt class="py-lineno"> 702</tt> <tt class="py-line"> <tt class="py-name">devicePortsEnabledCountTemp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
831<a name="L703"></a><tt class="py-lineno"> 703</tt> <tt class="py-line"> </tt>
832<a name="L704"></a><tt class="py-lineno"> 704</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
833<a name="L705"></a><tt class="py-lineno"> 705</tt> <tt class="py-line"> <tt class="py-string">"Compare ONOS topology with reference data in Stores"</tt> <tt class="py-op">)</tt> </tt>
834<a name="L706"></a><tt class="py-lineno"> 706</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-220" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-220', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"__________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
835<a name="L707"></a><tt class="py-lineno"> 707</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.case" class="py-name" href="#" onclick="return doclink('link-221', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Compare ONOS topology with reference data"</tt> <tt class="py-op">)</tt> </tt>
836<a name="L708"></a><tt class="py-lineno"> 708</tt> <tt class="py-line"> </tt>
837<a name="L709"></a><tt class="py-lineno"> 709</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-222', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Compare current Device ports enabled with reference"</tt> <tt class="py-op">)</tt> </tt>
838<a name="L710"></a><tt class="py-lineno"> 710</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>
839<a name="L711"></a><tt class="py-lineno"> 711</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">xrange</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">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">int</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 class="py-op">:</tt> </tt>
840<a name="L712"></a><tt class="py-lineno"> 712</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
841<a name="L713"></a><tt class="py-lineno"> 713</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-223" class="py-name"><a title="TestON.bin.cli
842TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-223', 'cli', 'link-106');">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>
843<a name="L714"></a><tt class="py-lineno"> 714</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
844<a name="L715"></a><tt class="py-lineno"> 715</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
845<a name="L716"></a><tt class="py-lineno"> 716</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">"of:00000000000000"</tt> <tt class="py-op">+</tt> <tt class="py-name">format</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-string">'02x'</tt> <tt class="py-op">)</tt> </tt>
846<a name="L717"></a><tt class="py-lineno"> 717</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-224" class="py-name"><a title="TestON.core.Thread
847TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-224', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt><tt class="py-name">target</tt> <tt class="py-op">=</tt> <tt id="link-225" class="py-name"><a title="TestON.bin.cli
848TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-225', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-226" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDevicePortsEnabledCount" class="py-name" href="#" onclick="return doclink('link-226', 'getDevicePortsEnabledCount', 'link-109');">getDevicePortsEnabledCount</a></tt><tt class="py-op">,</tt> </tt>
849<a name="L718"></a><tt class="py-lineno"> 718</tt> <tt class="py-line"> <tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
850<a name="L719"></a><tt class="py-lineno"> 719</tt> <tt class="py-line"> <tt class="py-name">name</tt> <tt class="py-op">=</tt> <tt class="py-string">"getDevicePortsEnabledCount"</tt><tt class="py-op">,</tt> </tt>
851<a name="L720"></a><tt class="py-lineno"> 720</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">dpid</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
852<a name="L721"></a><tt class="py-lineno"> 721</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>
853<a name="L722"></a><tt class="py-lineno"> 722</tt> <tt class="py-line"> <tt class="py-name">pool</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>
854<a name="L723"></a><tt class="py-lineno"> 723</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
855<a name="L724"></a><tt class="py-lineno"> 724</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
856<a name="L725"></a><tt class="py-lineno"> 725</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
857<a name="L726"></a><tt class="py-lineno"> 726</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
858<a name="L727"></a><tt class="py-lineno"> 727</tt> <tt class="py-line"> <tt class="py-name">portResult</tt> <tt class="py-op">=</tt> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
859<a name="L728"></a><tt class="py-lineno"> 728</tt> <tt class="py-line"> <tt class="py-comment">#portTemp = re.split( r'\t+', portResult )</tt> </tt>
860<a name="L729"></a><tt class="py-lineno"> 729</tt> <tt class="py-line"> <tt class="py-comment">#portCount = portTemp[ 1 ].replace( "\r\r\n\x1b[32m", "" )</tt> </tt>
861<a name="L730"></a><tt class="py-lineno"> 730</tt> <tt class="py-line"> <tt class="py-name">devicePortsEnabledCountTemp</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">portResult</tt> <tt class="py-op">)</tt> </tt>
862<a name="L731"></a><tt class="py-lineno"> 731</tt> <tt class="py-line"> </tt>
863<a name="L732"></a><tt class="py-lineno"> 732</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>
864<a name="L733"></a><tt class="py-lineno"> 733</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-227" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-227', 'log', 'link-2');">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 counting enabled ports of the switches: %2f seconds"</tt> <tt class="py-op">%</tt><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>
865<a name="L734"></a><tt class="py-lineno"> 734</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> </tt>
866<a name="L735"></a><tt class="py-lineno"> 735</tt> <tt class="py-line"> <tt class="py-string">"Device Enabled ports EXPECTED: %s"</tt> <tt class="py-op">%</tt> </tt>
867<a name="L736"></a><tt class="py-lineno"> 736</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">devicePortsEnabledCount</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
868<a name="L737"></a><tt class="py-lineno"> 737</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-229" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-229', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> </tt>
869<a name="L738"></a><tt class="py-lineno"> 738</tt> <tt class="py-line"> <tt class="py-string">"Device Enabled ports ACTUAL: %s"</tt> <tt class="py-op">%</tt> </tt>
870<a name="L739"></a><tt class="py-lineno"> 739</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">devicePortsEnabledCountTemp</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
871<a name="L740"></a><tt class="py-lineno"> 740</tt> <tt class="py-line"> </tt>
872<a name="L741"></a><tt class="py-lineno"> 741</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">cmp</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">devicePortsEnabledCount</tt><tt class="py-op">,</tt> </tt>
873<a name="L742"></a><tt class="py-lineno"> 742</tt> <tt class="py-line"> <tt class="py-name">devicePortsEnabledCountTemp</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
874<a name="L743"></a><tt class="py-lineno"> 743</tt> <tt class="py-line"> <tt class="py-name">stepResult1</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
875<a name="L744"></a><tt class="py-lineno"> 744</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
876<a name="L745"></a><tt class="py-lineno"> 745</tt> <tt class="py-line"> <tt class="py-name">stepResult1</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
877<a name="L746"></a><tt class="py-lineno"> 746</tt> <tt class="py-line"> </tt>
878<a name="L747"></a><tt class="py-lineno"> 747</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-230" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-230', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Compare Device active links with reference"</tt> <tt class="py-op">)</tt> </tt>
879<a name="L748"></a><tt class="py-lineno"> 748</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>
880<a name="L749"></a><tt class="py-lineno"> 749</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">xrange</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">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</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">int</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 class="py-op">:</tt> </tt>
881<a name="L750"></a><tt class="py-lineno"> 750</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
882<a name="L751"></a><tt class="py-lineno"> 751</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-231" class="py-name"><a title="TestON.bin.cli
883TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-231', 'cli', 'link-106');">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>
884<a name="L752"></a><tt class="py-lineno"> 752</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
885<a name="L753"></a><tt class="py-lineno"> 753</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
886<a name="L754"></a><tt class="py-lineno"> 754</tt> <tt class="py-line"> <tt class="py-name">dpid</tt> <tt class="py-op">=</tt> <tt class="py-string">"of:00000000000000"</tt> <tt class="py-op">+</tt> <tt class="py-name">format</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-string">'02x'</tt> <tt class="py-op">)</tt> </tt>
887<a name="L755"></a><tt class="py-lineno"> 755</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-232" class="py-name"><a title="TestON.core.Thread
888TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-232', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt><tt class="py-name">target</tt> <tt class="py-op">=</tt> <tt id="link-233" class="py-name"><a title="TestON.bin.cli
889TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-233', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-234" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getDeviceLinksActiveCount" class="py-name" href="#" onclick="return doclink('link-234', 'getDeviceLinksActiveCount', 'link-115');">getDeviceLinksActiveCount</a></tt><tt class="py-op">,</tt> </tt>
890<a name="L756"></a><tt class="py-lineno"> 756</tt> <tt class="py-line"> <tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
891<a name="L757"></a><tt class="py-lineno"> 757</tt> <tt class="py-line"> <tt class="py-name">name</tt> <tt class="py-op">=</tt> <tt class="py-string">"getDeviceLinksActiveCount"</tt><tt class="py-op">,</tt> </tt>
892<a name="L758"></a><tt class="py-lineno"> 758</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">dpid</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
893<a name="L759"></a><tt class="py-lineno"> 759</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>
894<a name="L760"></a><tt class="py-lineno"> 760</tt> <tt class="py-line"> <tt class="py-name">pool</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>
895<a name="L761"></a><tt class="py-lineno"> 761</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
896<a name="L762"></a><tt class="py-lineno"> 762</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
897<a name="L763"></a><tt class="py-lineno"> 763</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
898<a name="L764"></a><tt class="py-lineno"> 764</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
899<a name="L765"></a><tt class="py-lineno"> 765</tt> <tt class="py-line"> <tt class="py-name">linkCountResult</tt> <tt class="py-op">=</tt> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt> </tt>
900<a name="L766"></a><tt class="py-lineno"> 766</tt> <tt class="py-line"> <tt class="py-comment">#linkCountTemp = re.split( r'\t+', linkCountResult )</tt> </tt>
901<a name="L767"></a><tt class="py-lineno"> 767</tt> <tt class="py-line"> <tt class="py-comment">#linkCount = linkCountTemp[ 1 ].replace( "\r\r\n\x1b[32m", "" )</tt> </tt>
902<a name="L768"></a><tt class="py-lineno"> 768</tt> <tt class="py-line"> <tt class="py-name">deviceActiveLinksCountTemp</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">linkCountResult</tt> <tt class="py-op">)</tt> </tt>
903<a name="L769"></a><tt class="py-lineno"> 769</tt> <tt class="py-line"> </tt>
904<a name="L770"></a><tt class="py-lineno"> 770</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>
905<a name="L771"></a><tt class="py-lineno"> 771</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-2');">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 counting all enabled links of the switches: %2f seconds"</tt> <tt class="py-op">%</tt><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>
906<a name="L772"></a><tt class="py-lineno"> 772</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-236" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-236', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> </tt>
907<a name="L773"></a><tt class="py-lineno"> 773</tt> <tt class="py-line"> <tt class="py-string">"Device Active links EXPECTED: %s"</tt> <tt class="py-op">%</tt> </tt>
908<a name="L774"></a><tt class="py-lineno"> 774</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">deviceActiveLinksCount</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
909<a name="L775"></a><tt class="py-lineno"> 775</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-237" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-237', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> </tt>
910<a name="L776"></a><tt class="py-lineno"> 776</tt> <tt class="py-line"> <tt class="py-string">"Device Active links ACTUAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">deviceActiveLinksCountTemp</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
911<a name="L777"></a><tt class="py-lineno"> 777</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">cmp</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceActiveLinksCount</tt><tt class="py-op">,</tt> <tt class="py-name">deviceActiveLinksCountTemp</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
912<a name="L778"></a><tt class="py-lineno"> 778</tt> <tt class="py-line"> <tt class="py-name">stepResult2</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
913<a name="L779"></a><tt class="py-lineno"> 779</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
914<a name="L780"></a><tt class="py-lineno"> 780</tt> <tt class="py-line"> <tt class="py-name">stepResult2</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
915<a name="L781"></a><tt class="py-lineno"> 781</tt> <tt class="py-line"> </tt>
916<a name="L782"></a><tt class="py-lineno"> 782</tt> <tt class="py-line"> <tt class="py-string">"""</tt> </tt>
917<a name="L783"></a><tt class="py-lineno"> 783</tt> <tt class="py-line"><tt class="py-string"> place holder for comparing devices, hosts, paths and intents if required.</tt> </tt>
918<a name="L784"></a><tt class="py-lineno"> 784</tt> <tt class="py-line"><tt class="py-string"> Links and ports data would be incorrect with out devices anyways.</tt> </tt>
919<a name="L785"></a><tt class="py-lineno"> 785</tt> <tt class="py-line"><tt class="py-string"> """</tt> </tt>
920<a name="L786"></a><tt class="py-lineno"> 786</tt> <tt class="py-line"> <tt class="py-name">case5Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">stepResult1</tt> <tt class="py-keyword">and</tt> <tt class="py-name">stepResult2</tt> <tt class="py-op">)</tt> </tt>
921<a name="L787"></a><tt class="py-lineno"> 787</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">case5Result</tt><tt class="py-op">,</tt> </tt>
922<a name="L788"></a><tt class="py-lineno"> 788</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Compare Topology test PASS"</tt><tt class="py-op">,</tt> </tt>
923<a name="L789"></a><tt class="py-lineno"> 789</tt> <tt class="py-line"> <tt id="link-238" class="py-name"><a title="TestON.core.teston.TestON.onfail
924TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-238', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Compare Topology test FAIL"</tt> <tt class="py-op">)</tt> </tt>
925</div><a name="L790"></a><tt class="py-lineno"> 790</tt> <tt class="py-line"> </tt>
926<a name="CHOtest.CASE60"></a><div id="CHOtest.CASE60-def"><a name="L791"></a><tt class="py-lineno"> 791</tt> <a class="py-toggle" href="#" id="CHOtest.CASE60-toggle" onclick="return toggle('CHOtest.CASE60');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE60">CASE60</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
927</div><div id="CHOtest.CASE60-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE60-expanded"><a name="L792"></a><tt class="py-lineno"> 792</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
928<a name="L793"></a><tt class="py-lineno"> 793</tt> <tt class="py-line"><tt class="py-docstring"> Install 300 host intents and verify ping all (Att Topology)</tt> </tt>
929<a name="L794"></a><tt class="py-lineno"> 794</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
930<a name="L795"></a><tt class="py-lineno"> 795</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-239" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-239', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Add 300 host intents and verify pingall (Att Topology)"</tt> <tt class="py-op">)</tt> </tt>
931<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-240" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-240', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________________________"</tt> <tt class="py-op">)</tt> </tt>
932<a name="L797"></a><tt class="py-lineno"> 797</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
933<a name="L798"></a><tt class="py-lineno"> 798</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
934<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-241" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-241', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install 300 host intents"</tt> <tt class="py-op">)</tt> </tt>
935<a name="L800"></a><tt class="py-lineno"> 800</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-242" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-242', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add host Intents"</tt> <tt class="py-op">)</tt> </tt>
936<a name="L801"></a><tt class="py-lineno"> 801</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
937<a name="L802"></a><tt class="py-lineno"> 802</tt> <tt class="py-line"> <tt class="py-name">hostCombos</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt> <tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">combinations</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</tt><tt class="py-op">,</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
938<a name="L803"></a><tt class="py-lineno"> 803</tt> <tt class="py-line"> </tt>
939<a name="L804"></a><tt class="py-lineno"> 804</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
940<a name="L805"></a><tt class="py-lineno"> 805</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>
941<a name="L806"></a><tt class="py-lineno"> 806</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">xrange</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 class="py-name">hostCombos</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
942<a name="L807"></a><tt class="py-lineno"> 807</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
943<a name="L808"></a><tt class="py-lineno"> 808</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-243" class="py-name"><a title="TestON.bin.cli
944TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-243', 'cli', 'link-106');">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>
945<a name="L809"></a><tt class="py-lineno"> 809</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">hostCombos</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
946<a name="L810"></a><tt class="py-lineno"> 810</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
947<a name="L811"></a><tt class="py-lineno"> 811</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-244" class="py-name"><a title="TestON.core.Thread
948TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-244', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-245" class="py-name"><a title="TestON.bin.cli
949TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-245', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-246" 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
950TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addHostIntent" class="py-name" href="#" onclick="return doclink('link-246', 'addHostIntent', 'link-246');">addHostIntent</a></tt><tt class="py-op">,</tt> </tt>
951<a name="L812"></a><tt class="py-lineno"> 812</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
952<a name="L813"></a><tt class="py-lineno"> 813</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addHostIntent"</tt><tt class="py-op">,</tt> </tt>
953<a name="L814"></a><tt class="py-lineno"> 814</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">hostCombos</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">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">hostCombos</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 class="py-op">]</tt><tt class="py-op">)</tt> </tt>
954<a name="L815"></a><tt class="py-lineno"> 815</tt> <tt class="py-line"> <tt class="py-name">pool</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>
955<a name="L816"></a><tt class="py-lineno"> 816</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>
956<a name="L817"></a><tt class="py-lineno"> 817</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
957<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 class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
958<a name="L819"></a><tt class="py-lineno"> 819</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
959<a name="L820"></a><tt class="py-lineno"> 820</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
960<a name="L821"></a><tt class="py-lineno"> 821</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
961<a name="L822"></a><tt class="py-lineno"> 822</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>
962<a name="L823"></a><tt class="py-lineno"> 823</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-2');">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 adding host intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
963<a name="L824"></a><tt class="py-lineno"> 824</tt> <tt class="py-line"> </tt>
964<a name="L825"></a><tt class="py-lineno"> 825</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
965<a name="L826"></a><tt class="py-lineno"> 826</tt> <tt class="py-line"> <tt class="py-name">intentsJson</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-248" 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
966TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-248', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
967<a name="L827"></a><tt class="py-lineno"> 827</tt> <tt class="py-line"> <tt class="py-name">getIntentStateResult</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-249" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#getIntentState,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getIntentState"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState
968TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState" class="py-name" href="#" onclick="return doclink('link-249', 'getIntentState', 'link-249');">getIntentState</a></tt><tt class="py-op">(</tt><tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt><tt class="py-op">,</tt> </tt>
969<a name="L828"></a><tt class="py-lineno"> 828</tt> <tt class="py-line"> <tt class="py-name">intentsJson</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsJson</tt><tt class="py-op">)</tt> </tt>
970<a name="L829"></a><tt class="py-lineno"> 829</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"len of intent ID"</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">intentIdList</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
971<a name="L830"></a><tt class="py-lineno"> 830</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"len of intent state results"</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">getIntentStateResult</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
972<a name="L831"></a><tt class="py-lineno"> 831</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">getIntentStateResult</tt> </tt>
973<a name="L832"></a><tt class="py-lineno"> 832</tt> <tt class="py-line"> <tt class="py-comment"># Takes awhile for all the onos to get the intents</tt> </tt>
974<a name="L833"></a><tt class="py-lineno"> 833</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>
975<a name="L834"></a><tt class="py-lineno"> 834</tt> <tt class="py-line"> <tt class="py-string">"""intentState = main.TRUE</tt> </tt>
976<a name="L835"></a><tt class="py-lineno"> 835</tt> <tt class="py-line"><tt class="py-string"> for i in getIntentStateResult:</tt> </tt>
977<a name="L836"></a><tt class="py-lineno"> 836</tt> <tt class="py-line"><tt class="py-string"> if getIntentStateResult.get( 'state' ) != 'INSTALLED':</tt> </tt>
978<a name="L837"></a><tt class="py-lineno"> 837</tt> <tt class="py-line"><tt class="py-string"> """</tt> </tt>
979<a name="L838"></a><tt class="py-lineno"> 838</tt> <tt class="py-line"> </tt>
980<a name="L839"></a><tt class="py-lineno"> 839</tt> <tt class="py-line"> </tt>
981<a name="L840"></a><tt class="py-lineno"> 840</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-250" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-250', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
982<a name="L841"></a><tt class="py-lineno"> 841</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>
983<a name="L842"></a><tt class="py-lineno"> 842</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>
984<a name="L843"></a><tt class="py-lineno"> 843</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-251" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-251', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
985<a name="L844"></a><tt class="py-lineno"> 844</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>
986<a name="L845"></a><tt class="py-lineno"> 845</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
987<a name="L846"></a><tt class="py-lineno"> 846</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
988<a name="L847"></a><tt class="py-lineno"> 847</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
989<a name="L848"></a><tt class="py-lineno"> 848</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
990<a name="L849"></a><tt class="py-lineno"> 849</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
991<a name="L850"></a><tt class="py-lineno"> 850</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">pingResult</tt><tt class="py-op">,</tt> </tt>
992<a name="L851"></a><tt class="py-lineno"> 851</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
993<a name="L852"></a><tt class="py-lineno"> 852</tt> <tt class="py-line"> <tt id="link-253" class="py-name"><a title="TestON.core.teston.TestON.onfail
994TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-253', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
995<a name="L853"></a><tt class="py-lineno"> 853</tt> <tt class="py-line"> </tt>
996<a name="L854"></a><tt class="py-lineno"> 854</tt> <tt class="py-line"> <tt class="py-name">case60Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">intentResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResult</tt> <tt class="py-op">)</tt> </tt>
997<a name="L855"></a><tt class="py-lineno"> 855</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>
998<a name="L856"></a><tt class="py-lineno"> 856</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>
999<a name="L857"></a><tt class="py-lineno"> 857</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case60Result</tt><tt class="py-op">,</tt> </tt>
1000<a name="L858"></a><tt class="py-lineno"> 858</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 300 Host Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
1001<a name="L859"></a><tt class="py-lineno"> 859</tt> <tt class="py-line"> <tt id="link-254" class="py-name"><a title="TestON.core.teston.TestON.onfail
1002TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-254', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 300 Host Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1003</div><a name="L860"></a><tt class="py-lineno"> 860</tt> <tt class="py-line"> </tt>
1004<a name="CHOtest.CASE61"></a><div id="CHOtest.CASE61-def"><a name="L861"></a><tt class="py-lineno"> 861</tt> <a class="py-toggle" href="#" id="CHOtest.CASE61-toggle" onclick="return toggle('CHOtest.CASE61');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE61">CASE61</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1005</div><div id="CHOtest.CASE61-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE61-expanded"><a name="L862"></a><tt class="py-lineno"> 862</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1006<a name="L863"></a><tt class="py-lineno"> 863</tt> <tt class="py-line"><tt class="py-docstring"> Install 600 host intents and verify ping all for Chordal Topology</tt> </tt>
1007<a name="L864"></a><tt class="py-lineno"> 864</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1008<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-255" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-255', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Add 600 host intents and verify pingall (Chordal Topo)"</tt> <tt class="py-op">)</tt> </tt>
1009<a name="L866"></a><tt class="py-lineno"> 866</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-256" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-256', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________________________"</tt> <tt class="py-op">)</tt> </tt>
1010<a name="L867"></a><tt class="py-lineno"> 867</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1011<a name="L868"></a><tt class="py-lineno"> 868</tt> <tt class="py-line"> </tt>
1012<a name="L869"></a><tt class="py-lineno"> 869</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-257" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-257', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install 600 host intents"</tt> <tt class="py-op">)</tt> </tt>
1013<a name="L870"></a><tt class="py-lineno"> 870</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-258', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add host Intents"</tt> <tt class="py-op">)</tt> </tt>
1014<a name="L871"></a><tt class="py-lineno"> 871</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1015<a name="L872"></a><tt class="py-lineno"> 872</tt> <tt class="py-line"> <tt class="py-name">hostCombos</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt> <tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">combinations</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</tt><tt class="py-op">,</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1016<a name="L873"></a><tt class="py-lineno"> 873</tt> <tt class="py-line"> </tt>
1017<a name="L874"></a><tt class="py-lineno"> 874</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1018<a name="L875"></a><tt class="py-lineno"> 875</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>
1019<a name="L876"></a><tt class="py-lineno"> 876</tt> <tt class="py-line"> </tt>
1020<a name="L877"></a><tt class="py-lineno"> 877</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">xrange</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 class="py-name">hostCombos</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1021<a name="L878"></a><tt class="py-lineno"> 878</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1022<a name="L879"></a><tt class="py-lineno"> 879</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-259" class="py-name"><a title="TestON.bin.cli
1023TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-259', 'cli', 'link-106');">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>
1024<a name="L880"></a><tt class="py-lineno"> 880</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">hostCombos</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1025<a name="L881"></a><tt class="py-lineno"> 881</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
1026<a name="L882"></a><tt class="py-lineno"> 882</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-260" class="py-name"><a title="TestON.core.Thread
1027TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-260', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-261" class="py-name"><a title="TestON.bin.cli
1028TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-261', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-262" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addHostIntent
1029TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addHostIntent" class="py-name" href="#" onclick="return doclink('link-262', 'addHostIntent', 'link-246');">addHostIntent</a></tt><tt class="py-op">,</tt> </tt>
1030<a name="L883"></a><tt class="py-lineno"> 883</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
1031<a name="L884"></a><tt class="py-lineno"> 884</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addHostIntent"</tt><tt class="py-op">,</tt> </tt>
1032<a name="L885"></a><tt class="py-lineno"> 885</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">hostCombos</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">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">hostCombos</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 class="py-op">]</tt><tt class="py-op">)</tt> </tt>
1033<a name="L886"></a><tt class="py-lineno"> 886</tt> <tt class="py-line"> <tt class="py-name">pool</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>
1034<a name="L887"></a><tt class="py-lineno"> 887</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>
1035<a name="L888"></a><tt class="py-lineno"> 888</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1036<a name="L889"></a><tt class="py-lineno"> 889</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1037<a name="L890"></a><tt class="py-lineno"> 890</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
1038<a name="L891"></a><tt class="py-lineno"> 891</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1039<a name="L892"></a><tt class="py-lineno"> 892</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
1040<a name="L893"></a><tt class="py-lineno"> 893</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>
1041<a name="L894"></a><tt class="py-lineno"> 894</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-263" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-263', 'log', 'link-2');">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 adding host intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
1042<a name="L895"></a><tt class="py-lineno"> 895</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1043<a name="L896"></a><tt class="py-lineno"> 896</tt> <tt class="py-line"> <tt class="py-name">intentsJson</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-264" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
1044TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-264', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1045<a name="L897"></a><tt class="py-lineno"> 897</tt> <tt class="py-line"> <tt class="py-name">getIntentStateResult</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-265" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState
1046TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState" class="py-name" href="#" onclick="return doclink('link-265', 'getIntentState', 'link-249');">getIntentState</a></tt><tt class="py-op">(</tt><tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt><tt class="py-op">,</tt> </tt>
1047<a name="L898"></a><tt class="py-lineno"> 898</tt> <tt class="py-line"> <tt class="py-name">intentsJson</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsJson</tt><tt class="py-op">)</tt> </tt>
1048<a name="L899"></a><tt class="py-lineno"> 899</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">getIntentStateResult</tt> </tt>
1049<a name="L900"></a><tt class="py-lineno"> 900</tt> <tt class="py-line"> </tt>
1050<a name="L901"></a><tt class="py-lineno"> 901</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-266" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-266', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1051<a name="L902"></a><tt class="py-lineno"> 902</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>
1052<a name="L903"></a><tt class="py-lineno"> 903</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>
1053<a name="L904"></a><tt class="py-lineno"> 904</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-267" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-267', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1054<a name="L905"></a><tt class="py-lineno"> 905</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>
1055<a name="L906"></a><tt class="py-lineno"> 906</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1056<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-268" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-268', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1057<a name="L908"></a><tt class="py-lineno"> 908</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1058<a name="L909"></a><tt class="py-lineno"> 909</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1059<a name="L910"></a><tt class="py-lineno"> 910</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1060<a name="L911"></a><tt class="py-lineno"> 911</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">pingResult</tt><tt class="py-op">,</tt> </tt>
1061<a name="L912"></a><tt class="py-lineno"> 912</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1062<a name="L913"></a><tt class="py-lineno"> 913</tt> <tt class="py-line"> <tt id="link-269" class="py-name"><a title="TestON.core.teston.TestON.onfail
1063TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-269', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1064<a name="L914"></a><tt class="py-lineno"> 914</tt> <tt class="py-line"> </tt>
1065<a name="L915"></a><tt class="py-lineno"> 915</tt> <tt class="py-line"> <tt class="py-name">case14Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">intentResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResult</tt> <tt class="py-op">)</tt> </tt>
1066<a name="L916"></a><tt class="py-lineno"> 916</tt> <tt class="py-line"> </tt>
1067<a name="L917"></a><tt class="py-lineno"> 917</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>
1068<a name="L918"></a><tt class="py-lineno"> 918</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>
1069<a name="L919"></a><tt class="py-lineno"> 919</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case14Result</tt><tt class="py-op">,</tt> </tt>
1070<a name="L920"></a><tt class="py-lineno"> 920</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 300 Host Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
1071<a name="L921"></a><tt class="py-lineno"> 921</tt> <tt class="py-line"> <tt id="link-270" class="py-name"><a title="TestON.core.teston.TestON.onfail
1072TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-270', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 300 Host Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1073</div><a name="L922"></a><tt class="py-lineno"> 922</tt> <tt class="py-line"> </tt>
1074<a name="CHOtest.CASE62"></a><div id="CHOtest.CASE62-def"><a name="L923"></a><tt class="py-lineno"> 923</tt> <a class="py-toggle" href="#" id="CHOtest.CASE62-toggle" onclick="return toggle('CHOtest.CASE62');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE62">CASE62</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1075</div><div id="CHOtest.CASE62-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE62-expanded"><a name="L924"></a><tt class="py-lineno"> 924</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1076<a name="L925"></a><tt class="py-lineno"> 925</tt> <tt class="py-line"><tt class="py-docstring"> Install 2278 host intents and verify ping all for Spine Topology</tt> </tt>
1077<a name="L926"></a><tt class="py-lineno"> 926</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1078<a name="L927"></a><tt class="py-lineno"> 927</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-271" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-271', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Add 2278 host intents and verify pingall (Spine Topo)"</tt> <tt class="py-op">)</tt> </tt>
1079<a name="L928"></a><tt class="py-lineno"> 928</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-272" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-272', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________________________"</tt> <tt class="py-op">)</tt> </tt>
1080<a name="L929"></a><tt class="py-lineno"> 929</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1081<a name="L930"></a><tt class="py-lineno"> 930</tt> <tt class="py-line"> </tt>
1082<a name="L931"></a><tt class="py-lineno"> 931</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-273" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-273', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install 2278 host intents"</tt> <tt class="py-op">)</tt> </tt>
1083<a name="L932"></a><tt class="py-lineno"> 932</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-274', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add host Intents"</tt> <tt class="py-op">)</tt> </tt>
1084<a name="L933"></a><tt class="py-lineno"> 933</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1085<a name="L934"></a><tt class="py-lineno"> 934</tt> <tt class="py-line"> <tt class="py-name">hostCombos</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt> <tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">combinations</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</tt><tt class="py-op">,</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1086<a name="L935"></a><tt class="py-lineno"> 935</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">300</tt> </tt>
1087<a name="L936"></a><tt class="py-lineno"> 936</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1088<a name="L937"></a><tt class="py-lineno"> 937</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>
1089<a name="L938"></a><tt class="py-lineno"> 938</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">xrange</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 class="py-name">hostCombos</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1090<a name="L939"></a><tt class="py-lineno"> 939</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1091<a name="L940"></a><tt class="py-lineno"> 940</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-275" class="py-name"><a title="TestON.bin.cli
1092TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-275', 'cli', 'link-106');">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>
1093<a name="L941"></a><tt class="py-lineno"> 941</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">hostCombos</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1094<a name="L942"></a><tt class="py-lineno"> 942</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
1095<a name="L943"></a><tt class="py-lineno"> 943</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-276" class="py-name"><a title="TestON.core.Thread
1096TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-276', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-277" class="py-name"><a title="TestON.bin.cli
1097TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-277', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-278" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addHostIntent
1098TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addHostIntent" class="py-name" href="#" onclick="return doclink('link-278', 'addHostIntent', 'link-246');">addHostIntent</a></tt><tt class="py-op">,</tt> </tt>
1099<a name="L944"></a><tt class="py-lineno"> 944</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
1100<a name="L945"></a><tt class="py-lineno"> 945</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addHostIntent"</tt><tt class="py-op">,</tt> </tt>
1101<a name="L946"></a><tt class="py-lineno"> 946</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">hostCombos</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">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">hostCombos</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 class="py-op">]</tt><tt class="py-op">)</tt> </tt>
1102<a name="L947"></a><tt class="py-lineno"> 947</tt> <tt class="py-line"> <tt class="py-name">pool</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>
1103<a name="L948"></a><tt class="py-lineno"> 948</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>
1104<a name="L949"></a><tt class="py-lineno"> 949</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1105<a name="L950"></a><tt class="py-lineno"> 950</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1106<a name="L951"></a><tt class="py-lineno"> 951</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
1107<a name="L952"></a><tt class="py-lineno"> 952</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1108<a name="L953"></a><tt class="py-lineno"> 953</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
1109<a name="L954"></a><tt class="py-lineno"> 954</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>
1110<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-279" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-279', 'log', 'link-2');">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 adding host intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
1111<a name="L956"></a><tt class="py-lineno"> 956</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1112<a name="L957"></a><tt class="py-lineno"> 957</tt> <tt class="py-line"> <tt class="py-name">intentsJson</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-280" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
1113TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-280', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1114<a name="L958"></a><tt class="py-lineno"> 958</tt> <tt class="py-line"> <tt class="py-name">getIntentStateResult</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-281" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState
1115TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState" class="py-name" href="#" onclick="return doclink('link-281', 'getIntentState', 'link-249');">getIntentState</a></tt><tt class="py-op">(</tt><tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt><tt class="py-op">,</tt> </tt>
1116<a name="L959"></a><tt class="py-lineno"> 959</tt> <tt class="py-line"> <tt class="py-name">intentsJson</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsJson</tt><tt class="py-op">)</tt> </tt>
1117<a name="L960"></a><tt class="py-lineno"> 960</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">getIntentStateResult</tt> </tt>
1118<a name="L961"></a><tt class="py-lineno"> 961</tt> <tt class="py-line"> </tt>
1119<a name="L962"></a><tt class="py-lineno"> 962</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-282" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-282', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1120<a name="L963"></a><tt class="py-lineno"> 963</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>
1121<a name="L964"></a><tt class="py-lineno"> 964</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>
1122<a name="L965"></a><tt class="py-lineno"> 965</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-283" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-283', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1123<a name="L966"></a><tt class="py-lineno"> 966</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>
1124<a name="L967"></a><tt class="py-lineno"> 967</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1125<a name="L968"></a><tt class="py-lineno"> 968</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-284" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-284', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1126<a name="L969"></a><tt class="py-lineno"> 969</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1127<a name="L970"></a><tt class="py-lineno"> 970</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1128<a name="L971"></a><tt class="py-lineno"> 971</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1129<a name="L972"></a><tt class="py-lineno"> 972</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">pingResult</tt><tt class="py-op">,</tt> </tt>
1130<a name="L973"></a><tt class="py-lineno"> 973</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1131<a name="L974"></a><tt class="py-lineno"> 974</tt> <tt class="py-line"> <tt id="link-285" class="py-name"><a title="TestON.core.teston.TestON.onfail
1132TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-285', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1133<a name="L975"></a><tt class="py-lineno"> 975</tt> <tt class="py-line"> </tt>
1134<a name="L976"></a><tt class="py-lineno"> 976</tt> <tt class="py-line"> <tt class="py-name">case15Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">intentResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResult</tt> <tt class="py-op">)</tt> </tt>
1135<a name="L977"></a><tt class="py-lineno"> 977</tt> <tt class="py-line"> </tt>
1136<a name="L978"></a><tt class="py-lineno"> 978</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>
1137<a name="L979"></a><tt class="py-lineno"> 979</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>
1138<a name="L980"></a><tt class="py-lineno"> 980</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case15Result</tt><tt class="py-op">,</tt> </tt>
1139<a name="L981"></a><tt class="py-lineno"> 981</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 2278 Host Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
1140<a name="L982"></a><tt class="py-lineno"> 982</tt> <tt class="py-line"> <tt id="link-286" class="py-name"><a title="TestON.core.teston.TestON.onfail
1141TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-286', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 2278 Host Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1142</div><a name="L983"></a><tt class="py-lineno"> 983</tt> <tt class="py-line"> </tt>
1143<a name="CHOtest.CASE70"></a><div id="CHOtest.CASE70-def"><a name="L984"></a><tt class="py-lineno"> 984</tt> <a class="py-toggle" href="#" id="CHOtest.CASE70-toggle" onclick="return toggle('CHOtest.CASE70');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE70">CASE70</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>
1144</div><div id="CHOtest.CASE70-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE70-expanded"><a name="L985"></a><tt class="py-lineno"> 985</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1145<a name="L986"></a><tt class="py-lineno"> 986</tt> <tt class="py-line"><tt class="py-docstring"> Randomly bring some core links down and verify ping all ( Host Intents-Att Topo)</tt> </tt>
1146<a name="L987"></a><tt class="py-lineno"> 987</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1147<a name="L988"></a><tt class="py-lineno"> 988</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1148<a name="L989"></a><tt class="py-lineno"> 989</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1149<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 class="py-name">randomLink2</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1150<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 class="py-name">randomLink3</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1151<a name="L992"></a><tt class="py-lineno"> 992</tt> <tt class="py-line"> <tt class="py-name">link1End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS3a'</tt> <tt class="py-op">]</tt> </tt>
1152<a name="L993"></a><tt class="py-lineno"> 993</tt> <tt class="py-line"> <tt class="py-name">link1End2</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS3b'</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>
1153<a name="L994"></a><tt class="py-lineno"> 994</tt> <tt class="py-line"> <tt class="py-name">link2End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS14a'</tt> <tt class="py-op">]</tt> </tt>
1154<a name="L995"></a><tt class="py-lineno"> 995</tt> <tt class="py-line"> <tt class="py-name">link2End2</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS14b'</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>
1155<a name="L996"></a><tt class="py-lineno"> 996</tt> <tt class="py-line"> <tt class="py-name">link3End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS18a'</tt> <tt class="py-op">]</tt> </tt>
1156<a name="L997"></a><tt class="py-lineno"> 997</tt> <tt class="py-line"> <tt class="py-name">link3End2</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS18b'</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>
1157<a name="L998"></a><tt class="py-lineno"> 998</tt> <tt class="py-line"> <tt class="py-name">switchLinksToToggle</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'toggleLinks'</tt> <tt class="py-op">]</tt> </tt>
1158<a name="L999"></a><tt class="py-lineno"> 999</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1159<a name="L1000"></a><tt class="py-lineno">1000</tt> <tt class="py-line"> </tt>
1160<a name="L1001"></a><tt class="py-lineno">1001</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-287" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-287', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Randomly bring some core links down and verify ping all (Host Intents-Att Topo)"</tt> <tt class="py-op">)</tt> </tt>
1161<a name="L1002"></a><tt class="py-lineno">1002</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1162<a name="L1003"></a><tt class="py-lineno">1003</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-289', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Host intents - Randomly bring some core links down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1163<a name="L1004"></a><tt class="py-lineno">1004</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-290" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-290', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify number of Switch links to toggle on each Core Switch are between 1 - 5"</tt> <tt class="py-op">)</tt> </tt>
1164<a name="L1005"></a><tt class="py-lineno">1005</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> </tt>
1165<a name="L1006"></a><tt class="py-lineno">1006</tt> <tt class="py-line"> <tt class="py-number">0</tt> <tt class="py-keyword">or</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">5</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1166<a name="L1007"></a><tt class="py-lineno">1007</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-291" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-291', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Please check your PARAMS file. Valid range for number of switch links to toggle is between 1 to 5"</tt> <tt class="py-op">)</tt> </tt>
1167<a name="L1008"></a><tt class="py-lineno">1008</tt> <tt class="py-line"> <tt class="py-comment">#main.cleanup()</tt> </tt>
1168<a name="L1009"></a><tt class="py-lineno">1009</tt> <tt class="py-line"> <tt class="py-comment">#main.exit()</tt> </tt>
1169<a name="L1010"></a><tt class="py-lineno">1010</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
1170<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-292" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-292', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"User provided Core switch links range to toggle is correct, proceeding to run the test"</tt> <tt class="py-op">)</tt> </tt>
1171<a name="L1012"></a><tt class="py-lineno">1012</tt> <tt class="py-line"> </tt>
1172<a name="L1013"></a><tt class="py-lineno">1013</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.step" class="py-name" href="#" onclick="return doclink('link-293', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cut links on Core devices using user provided range"</tt> <tt class="py-op">)</tt> </tt>
1173<a name="L1014"></a><tt class="py-lineno">1014</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt> <tt class="py-name">link1End2</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1174<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 class="py-name">randomLink2</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt> <tt class="py-name">link2End2</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1175<a name="L1016"></a><tt class="py-lineno">1016</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt> <tt class="py-name">link3End2</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1176<a name="L1017"></a><tt class="py-lineno">1017</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">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1177<a name="L1018"></a><tt class="py-lineno">1018</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-294" 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-294', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1178<a name="L1019"></a><tt class="py-lineno">1019</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link1End1</tt><tt class="py-op">,</tt> </tt>
1179<a name="L1020"></a><tt class="py-lineno">1020</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1180<a name="L1021"></a><tt class="py-lineno">1021</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
1181<a name="L1022"></a><tt class="py-lineno">1022</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1182<a name="L1023"></a><tt class="py-lineno">1023</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-295" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-295', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1183<a name="L1024"></a><tt class="py-lineno">1024</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link2End1</tt><tt class="py-op">,</tt> </tt>
1184<a name="L1025"></a><tt class="py-lineno">1025</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1185<a name="L1026"></a><tt class="py-lineno">1026</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
1186<a name="L1027"></a><tt class="py-lineno">1027</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1187<a name="L1028"></a><tt class="py-lineno">1028</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-296" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-296', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1188<a name="L1029"></a><tt class="py-lineno">1029</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link3End1</tt><tt class="py-op">,</tt> </tt>
1189<a name="L1030"></a><tt class="py-lineno">1030</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1190<a name="L1031"></a><tt class="py-lineno">1031</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
1191<a name="L1032"></a><tt class="py-lineno">1032</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1192<a name="L1033"></a><tt class="py-lineno">1033</tt> <tt class="py-line"> </tt>
1193<a name="L1034"></a><tt class="py-lineno">1034</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-297" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1194TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-297', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1195<a name="L1035"></a><tt class="py-lineno">1035</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-298" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#checkStatus,Method TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#checkStatus"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1196TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-298', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1197<a name="L1036"></a><tt class="py-lineno">1036</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt>
1198<a name="L1037"></a><tt class="py-lineno">1037</tt> <tt class="py-line"> <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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">*</tt> <tt class="py-number">6</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1199<a name="L1038"></a><tt class="py-lineno">1038</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>
1200<a name="L1039"></a><tt class="py-lineno">1039</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>
1201<a name="L1040"></a><tt class="py-lineno">1040</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkDown</tt><tt class="py-op">,</tt> </tt>
1202<a name="L1041"></a><tt class="py-lineno">1041</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Down discovered properly"</tt><tt class="py-op">,</tt> </tt>
1203<a name="L1042"></a><tt class="py-lineno">1042</tt> <tt class="py-line"> <tt id="link-299" class="py-name"><a title="TestON.core.teston.TestON.onfail
1204TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-299', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link down was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1205<a name="L1043"></a><tt class="py-lineno">1043</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1206<a name="L1044"></a><tt class="py-lineno">1044</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1207<a name="L1045"></a><tt class="py-lineno">1045</tt> <tt class="py-line"> </tt>
1208<a name="L1046"></a><tt class="py-lineno">1046</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-300', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1209<a name="L1047"></a><tt class="py-lineno">1047</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1210<a name="L1048"></a><tt class="py-lineno">1048</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>
1211<a name="L1049"></a><tt class="py-lineno">1049</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</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-301" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-301', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">)</tt> </tt>
1212<a name="L1050"></a><tt class="py-lineno">1050</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>
1213<a name="L1051"></a><tt class="py-lineno">1051</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1214<a name="L1052"></a><tt class="py-lineno">1052</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1215<a name="L1053"></a><tt class="py-lineno">1053</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1216<a name="L1054"></a><tt class="py-lineno">1054</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1217<a name="L1055"></a><tt class="py-lineno">1055</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1218<a name="L1056"></a><tt class="py-lineno">1056</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">pingResultLinkDown</tt><tt class="py-op">,</tt> </tt>
1219<a name="L1057"></a><tt class="py-lineno">1057</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1220<a name="L1058"></a><tt class="py-lineno">1058</tt> <tt class="py-line"> <tt id="link-303" class="py-name"><a title="TestON.core.teston.TestON.onfail
1221TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-303', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1222<a name="L1059"></a><tt class="py-lineno">1059</tt> <tt class="py-line"> </tt>
1223<a name="L1060"></a><tt class="py-lineno">1060</tt> <tt class="py-line"> <tt class="py-name">caseResult70</tt> <tt class="py-op">=</tt> <tt class="py-name">linkDown</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkDown</tt> </tt>
1224<a name="L1061"></a><tt class="py-lineno">1061</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">caseResult70</tt><tt class="py-op">,</tt> </tt>
1225<a name="L1062"></a><tt class="py-lineno">1062</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test PASS"</tt><tt class="py-op">,</tt> </tt>
1226<a name="L1063"></a><tt class="py-lineno">1063</tt> <tt class="py-line"> <tt id="link-304" class="py-name"><a title="TestON.core.teston.TestON.onfail
1227TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-304', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1228</div><a name="L1064"></a><tt class="py-lineno">1064</tt> <tt class="py-line"> </tt>
1229<a name="CHOtest.CASE80"></a><div id="CHOtest.CASE80-def"><a name="L1065"></a><tt class="py-lineno">1065</tt> <a class="py-toggle" href="#" id="CHOtest.CASE80-toggle" onclick="return toggle('CHOtest.CASE80');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE80">CASE80</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>
1230</div><div id="CHOtest.CASE80-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE80-expanded"><a name="L1066"></a><tt class="py-lineno">1066</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1231<a name="L1067"></a><tt class="py-lineno">1067</tt> <tt class="py-line"><tt class="py-docstring"> Bring the core links up that are down and verify ping all ( Host Intents-Att Topo )</tt> </tt>
1232<a name="L1068"></a><tt class="py-lineno">1068</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1233<a name="L1069"></a><tt class="py-lineno">1069</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1234<a name="L1070"></a><tt class="py-lineno">1070</tt> <tt class="py-line"> <tt class="py-name">link1End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS3a'</tt> <tt class="py-op">]</tt> </tt>
1235<a name="L1071"></a><tt class="py-lineno">1071</tt> <tt class="py-line"> <tt class="py-name">link2End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS14a'</tt> <tt class="py-op">]</tt> </tt>
1236<a name="L1072"></a><tt class="py-lineno">1072</tt> <tt class="py-line"> <tt class="py-name">link3End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS18a'</tt> <tt class="py-op">]</tt> </tt>
1237<a name="L1073"></a><tt class="py-lineno">1073</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1238<a name="L1074"></a><tt class="py-lineno">1074</tt> <tt class="py-line"> <tt class="py-name">switchLinksToToggle</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'toggleLinks'</tt> <tt class="py-op">]</tt> </tt>
1239<a name="L1075"></a><tt class="py-lineno">1075</tt> <tt class="py-line"> </tt>
1240<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-305" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-305', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1241<a name="L1077"></a><tt class="py-lineno">1077</tt> <tt class="py-line"> <tt class="py-string">"Bring the core links up that are down and verify ping all (Host Intents-Att Topo"</tt> <tt class="py-op">)</tt> </tt>
1242<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-306" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-306', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1243<a name="L1079"></a><tt class="py-lineno">1079</tt> <tt class="py-line"> <tt class="py-string">"__________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1244<a name="L1080"></a><tt class="py-lineno">1080</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-307" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-307', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
1245<a name="L1081"></a><tt class="py-lineno">1081</tt> <tt class="py-line"> <tt class="py-string">"Host intents - Bring the core links up that are down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1246<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-308" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-308', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Bring randomly cut links on Core devices up"</tt> <tt class="py-op">)</tt> </tt>
1247<a name="L1083"></a><tt class="py-lineno">1083</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">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1248<a name="L1084"></a><tt class="py-lineno">1084</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-309" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-309', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1249<a name="L1085"></a><tt class="py-lineno">1085</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link1End1</tt><tt class="py-op">,</tt> </tt>
1250<a name="L1086"></a><tt class="py-lineno">1086</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1251<a name="L1087"></a><tt class="py-lineno">1087</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
1252<a name="L1088"></a><tt class="py-lineno">1088</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1253<a name="L1089"></a><tt class="py-lineno">1089</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-310" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-310', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1254<a name="L1090"></a><tt class="py-lineno">1090</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link2End1</tt><tt class="py-op">,</tt> </tt>
1255<a name="L1091"></a><tt class="py-lineno">1091</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1256<a name="L1092"></a><tt class="py-lineno">1092</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
1257<a name="L1093"></a><tt class="py-lineno">1093</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1258<a name="L1094"></a><tt class="py-lineno">1094</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-311" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-311', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1259<a name="L1095"></a><tt class="py-lineno">1095</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link3End1</tt><tt class="py-op">,</tt> </tt>
1260<a name="L1096"></a><tt class="py-lineno">1096</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1261<a name="L1097"></a><tt class="py-lineno">1097</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
1262<a name="L1098"></a><tt class="py-lineno">1098</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1263<a name="L1099"></a><tt class="py-lineno">1099</tt> <tt class="py-line"> </tt>
1264<a name="L1100"></a><tt class="py-lineno">1100</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-312" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1265TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-312', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1266<a name="L1101"></a><tt class="py-lineno">1101</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-313" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1267TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-313', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1268<a name="L1102"></a><tt class="py-lineno">1102</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> </tt>
1269<a name="L1103"></a><tt class="py-lineno">1103</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> </tt>
1270<a name="L1104"></a><tt class="py-lineno">1104</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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1271<a name="L1105"></a><tt class="py-lineno">1105</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>
1272<a name="L1106"></a><tt class="py-lineno">1106</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>
1273<a name="L1107"></a><tt class="py-lineno">1107</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkUp</tt><tt class="py-op">,</tt> </tt>
1274<a name="L1108"></a><tt class="py-lineno">1108</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link up discovered properly"</tt><tt class="py-op">,</tt> </tt>
1275<a name="L1109"></a><tt class="py-lineno">1109</tt> <tt class="py-line"> <tt id="link-314" class="py-name"><a title="TestON.core.teston.TestON.onfail
1276TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-314', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link up was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1277<a name="L1110"></a><tt class="py-lineno">1110</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1278<a name="L1111"></a><tt class="py-lineno">1111</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1279<a name="L1112"></a><tt class="py-lineno">1112</tt> <tt class="py-line"> </tt>
1280<a name="L1113"></a><tt class="py-lineno">1113</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-315" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-315', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1281<a name="L1114"></a><tt class="py-lineno">1114</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1282<a name="L1115"></a><tt class="py-lineno">1115</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>
1283<a name="L1116"></a><tt class="py-lineno">1116</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</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-316" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-316', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">)</tt> </tt>
1284<a name="L1117"></a><tt class="py-lineno">1117</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>
1285<a name="L1118"></a><tt class="py-lineno">1118</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1286<a name="L1119"></a><tt class="py-lineno">1119</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-317" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-317', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1287<a name="L1120"></a><tt class="py-lineno">1120</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1288<a name="L1121"></a><tt class="py-lineno">1121</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1289<a name="L1122"></a><tt class="py-lineno">1122</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1290<a name="L1123"></a><tt class="py-lineno">1123</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">pingResultLinkUp</tt><tt class="py-op">,</tt> </tt>
1291<a name="L1124"></a><tt class="py-lineno">1124</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1292<a name="L1125"></a><tt class="py-lineno">1125</tt> <tt class="py-line"> <tt id="link-318" class="py-name"><a title="TestON.core.teston.TestON.onfail
1293TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-318', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1294<a name="L1126"></a><tt class="py-lineno">1126</tt> <tt class="py-line"> </tt>
1295<a name="L1127"></a><tt class="py-lineno">1127</tt> <tt class="py-line"> <tt class="py-name">caseResult80</tt> <tt class="py-op">=</tt> <tt class="py-name">linkUp</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkUp</tt> </tt>
1296<a name="L1128"></a><tt class="py-lineno">1128</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">caseResult80</tt><tt class="py-op">,</tt> </tt>
1297<a name="L1129"></a><tt class="py-lineno">1129</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test PASS"</tt><tt class="py-op">,</tt> </tt>
1298<a name="L1130"></a><tt class="py-lineno">1130</tt> <tt class="py-line"> <tt id="link-319" class="py-name"><a title="TestON.core.teston.TestON.onfail
1299TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-319', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1300</div><a name="L1131"></a><tt class="py-lineno">1131</tt> <tt class="py-line"> </tt>
1301<a name="CHOtest.CASE71"></a><div id="CHOtest.CASE71-def"><a name="L1132"></a><tt class="py-lineno">1132</tt> <a class="py-toggle" href="#" id="CHOtest.CASE71-toggle" onclick="return toggle('CHOtest.CASE71');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE71">CASE71</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>
1302</div><div id="CHOtest.CASE71-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE71-expanded"><a name="L1133"></a><tt class="py-lineno">1133</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1303<a name="L1134"></a><tt class="py-lineno">1134</tt> <tt class="py-line"><tt class="py-docstring"> Randomly bring some core links down and verify ping all ( Point Intents-Att Topo)</tt> </tt>
1304<a name="L1135"></a><tt class="py-lineno">1135</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1305<a name="L1136"></a><tt class="py-lineno">1136</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1306<a name="L1137"></a><tt class="py-lineno">1137</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1307<a name="L1138"></a><tt class="py-lineno">1138</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1308<a name="L1139"></a><tt class="py-lineno">1139</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1309<a name="L1140"></a><tt class="py-lineno">1140</tt> <tt class="py-line"> <tt class="py-name">link1End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS3a'</tt> <tt class="py-op">]</tt> </tt>
1310<a name="L1141"></a><tt class="py-lineno">1141</tt> <tt class="py-line"> <tt class="py-name">link1End2</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS3b'</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>
1311<a name="L1142"></a><tt class="py-lineno">1142</tt> <tt class="py-line"> <tt class="py-name">link2End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS14a'</tt> <tt class="py-op">]</tt> </tt>
1312<a name="L1143"></a><tt class="py-lineno">1143</tt> <tt class="py-line"> <tt class="py-name">link2End2</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS14b'</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>
1313<a name="L1144"></a><tt class="py-lineno">1144</tt> <tt class="py-line"> <tt class="py-name">link3End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS18a'</tt> <tt class="py-op">]</tt> </tt>
1314<a name="L1145"></a><tt class="py-lineno">1145</tt> <tt class="py-line"> <tt class="py-name">link3End2</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS18b'</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>
1315<a name="L1146"></a><tt class="py-lineno">1146</tt> <tt class="py-line"> <tt class="py-name">switchLinksToToggle</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'toggleLinks'</tt> <tt class="py-op">]</tt> </tt>
1316<a name="L1147"></a><tt class="py-lineno">1147</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1317<a name="L1148"></a><tt class="py-lineno">1148</tt> <tt class="py-line"> </tt>
1318<a name="L1149"></a><tt class="py-lineno">1149</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-320" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-320', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Randomly bring some core links down and verify ping all (Point Intents-Att Topo)"</tt> <tt class="py-op">)</tt> </tt>
1319<a name="L1150"></a><tt class="py-lineno">1150</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1320<a name="L1151"></a><tt class="py-lineno">1151</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-322', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Point intents - Randomly bring some core links down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1321<a name="L1152"></a><tt class="py-lineno">1152</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-323', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify number of Switch links to toggle on each Core Switch are between 1 - 5"</tt> <tt class="py-op">)</tt> </tt>
1322<a name="L1153"></a><tt class="py-lineno">1153</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> </tt>
1323<a name="L1154"></a><tt class="py-lineno">1154</tt> <tt class="py-line"> <tt class="py-number">0</tt> <tt class="py-keyword">or</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">5</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1324<a name="L1155"></a><tt class="py-lineno">1155</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-324" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-324', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Please check your PARAMS file. Valid range for number of switch links to toggle is between 1 to 5"</tt> <tt class="py-op">)</tt> </tt>
1325<a name="L1156"></a><tt class="py-lineno">1156</tt> <tt class="py-line"> <tt class="py-comment">#main.cleanup()</tt> </tt>
1326<a name="L1157"></a><tt class="py-lineno">1157</tt> <tt class="py-line"> <tt class="py-comment">#main.exit()</tt> </tt>
1327<a name="L1158"></a><tt class="py-lineno">1158</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
1328<a name="L1159"></a><tt class="py-lineno">1159</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"User provided Core switch links range to toggle is correct, proceeding to run the test"</tt> <tt class="py-op">)</tt> </tt>
1329<a name="L1160"></a><tt class="py-lineno">1160</tt> <tt class="py-line"> </tt>
1330<a name="L1161"></a><tt class="py-lineno">1161</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-326" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-326', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cut links on Core devices using user provided range"</tt> <tt class="py-op">)</tt> </tt>
1331<a name="L1162"></a><tt class="py-lineno">1162</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt> <tt class="py-name">link1End2</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1332<a name="L1163"></a><tt class="py-lineno">1163</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt> <tt class="py-name">link2End2</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1333<a name="L1164"></a><tt class="py-lineno">1164</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt> <tt class="py-name">link3End2</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1334<a name="L1165"></a><tt class="py-lineno">1165</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">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1335<a name="L1166"></a><tt class="py-lineno">1166</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-327" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-327', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1336<a name="L1167"></a><tt class="py-lineno">1167</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link1End1</tt><tt class="py-op">,</tt> </tt>
1337<a name="L1168"></a><tt class="py-lineno">1168</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1338<a name="L1169"></a><tt class="py-lineno">1169</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
1339<a name="L1170"></a><tt class="py-lineno">1170</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1340<a name="L1171"></a><tt class="py-lineno">1171</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-328" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-328', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1341<a name="L1172"></a><tt class="py-lineno">1172</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link2End1</tt><tt class="py-op">,</tt> </tt>
1342<a name="L1173"></a><tt class="py-lineno">1173</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1343<a name="L1174"></a><tt class="py-lineno">1174</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
1344<a name="L1175"></a><tt class="py-lineno">1175</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1345<a name="L1176"></a><tt class="py-lineno">1176</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-329" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-329', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1346<a name="L1177"></a><tt class="py-lineno">1177</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link3End1</tt><tt class="py-op">,</tt> </tt>
1347<a name="L1178"></a><tt class="py-lineno">1178</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1348<a name="L1179"></a><tt class="py-lineno">1179</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt> <tt class="py-op">)</tt> </tt>
1349<a name="L1180"></a><tt class="py-lineno">1180</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1350<a name="L1181"></a><tt class="py-lineno">1181</tt> <tt class="py-line"> </tt>
1351<a name="L1182"></a><tt class="py-lineno">1182</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-330" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1352TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-330', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1353<a name="L1183"></a><tt class="py-lineno">1183</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-331" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1354TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-331', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1355<a name="L1184"></a><tt class="py-lineno">1184</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt>
1356<a name="L1185"></a><tt class="py-lineno">1185</tt> <tt class="py-line"> <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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">*</tt> <tt class="py-number">6</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1357<a name="L1186"></a><tt class="py-lineno">1186</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>
1358<a name="L1187"></a><tt class="py-lineno">1187</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>
1359<a name="L1188"></a><tt class="py-lineno">1188</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkDown</tt><tt class="py-op">,</tt> </tt>
1360<a name="L1189"></a><tt class="py-lineno">1189</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Down discovered properly"</tt><tt class="py-op">,</tt> </tt>
1361<a name="L1190"></a><tt class="py-lineno">1190</tt> <tt class="py-line"> <tt id="link-332" class="py-name"><a title="TestON.core.teston.TestON.onfail
1362TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-332', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link down was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1363<a name="L1191"></a><tt class="py-lineno">1191</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1364<a name="L1192"></a><tt class="py-lineno">1192</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1365<a name="L1193"></a><tt class="py-lineno">1193</tt> <tt class="py-line"> </tt>
1366<a name="L1194"></a><tt class="py-lineno">1194</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-333" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-333', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1367<a name="L1195"></a><tt class="py-lineno">1195</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1368<a name="L1196"></a><tt class="py-lineno">1196</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>
1369<a name="L1197"></a><tt class="py-lineno">1197</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</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-334" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-334', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">)</tt> </tt>
1370<a name="L1198"></a><tt class="py-lineno">1198</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>
1371<a name="L1199"></a><tt class="py-lineno">1199</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1372<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-335" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-335', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1373<a name="L1201"></a><tt class="py-lineno">1201</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1374<a name="L1202"></a><tt class="py-lineno">1202</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1375<a name="L1203"></a><tt class="py-lineno">1203</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1376<a name="L1204"></a><tt class="py-lineno">1204</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">pingResultLinkDown</tt><tt class="py-op">,</tt> </tt>
1377<a name="L1205"></a><tt class="py-lineno">1205</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1378<a name="L1206"></a><tt class="py-lineno">1206</tt> <tt class="py-line"> <tt id="link-336" class="py-name"><a title="TestON.core.teston.TestON.onfail
1379TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-336', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1380<a name="L1207"></a><tt class="py-lineno">1207</tt> <tt class="py-line"> </tt>
1381<a name="L1208"></a><tt class="py-lineno">1208</tt> <tt class="py-line"> <tt class="py-name">caseResult71</tt> <tt class="py-op">=</tt> <tt class="py-name">linkDown</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkDown</tt> </tt>
1382<a name="L1209"></a><tt class="py-lineno">1209</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">caseResult71</tt><tt class="py-op">,</tt> </tt>
1383<a name="L1210"></a><tt class="py-lineno">1210</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test PASS"</tt><tt class="py-op">,</tt> </tt>
1384<a name="L1211"></a><tt class="py-lineno">1211</tt> <tt class="py-line"> <tt id="link-337" class="py-name"><a title="TestON.core.teston.TestON.onfail
1385TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-337', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1386</div><a name="L1212"></a><tt class="py-lineno">1212</tt> <tt class="py-line"> </tt>
1387<a name="CHOtest.CASE81"></a><div id="CHOtest.CASE81-def"><a name="L1213"></a><tt class="py-lineno">1213</tt> <a class="py-toggle" href="#" id="CHOtest.CASE81-toggle" onclick="return toggle('CHOtest.CASE81');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE81">CASE81</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>
1388</div><div id="CHOtest.CASE81-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE81-expanded"><a name="L1214"></a><tt class="py-lineno">1214</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1389<a name="L1215"></a><tt class="py-lineno">1215</tt> <tt class="py-line"><tt class="py-docstring"> Bring the core links up that are down and verify ping all ( Point Intents-Att Topo )</tt> </tt>
1390<a name="L1216"></a><tt class="py-lineno">1216</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1391<a name="L1217"></a><tt class="py-lineno">1217</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1392<a name="L1218"></a><tt class="py-lineno">1218</tt> <tt class="py-line"> <tt class="py-name">link1End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS3a'</tt> <tt class="py-op">]</tt> </tt>
1393<a name="L1219"></a><tt class="py-lineno">1219</tt> <tt class="py-line"> <tt class="py-name">link2End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS14a'</tt> <tt class="py-op">]</tt> </tt>
1394<a name="L1220"></a><tt class="py-lineno">1220</tt> <tt class="py-line"> <tt class="py-name">link3End1</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS18a'</tt> <tt class="py-op">]</tt> </tt>
1395<a name="L1221"></a><tt class="py-lineno">1221</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1396<a name="L1222"></a><tt class="py-lineno">1222</tt> <tt class="py-line"> <tt class="py-name">switchLinksToToggle</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">'ATTCORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'toggleLinks'</tt> <tt class="py-op">]</tt> </tt>
1397<a name="L1223"></a><tt class="py-lineno">1223</tt> <tt class="py-line"> </tt>
1398<a name="L1224"></a><tt class="py-lineno">1224</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1399<a name="L1225"></a><tt class="py-lineno">1225</tt> <tt class="py-line"> <tt class="py-string">"Bring the core links up that are down and verify ping all ( Point Intents-Att Topo"</tt> <tt class="py-op">)</tt> </tt>
1400<a name="L1226"></a><tt class="py-lineno">1226</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1401<a name="L1227"></a><tt class="py-lineno">1227</tt> <tt class="py-line"> <tt class="py-string">"__________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1402<a name="L1228"></a><tt class="py-lineno">1228</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-340" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-340', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
1403<a name="L1229"></a><tt class="py-lineno">1229</tt> <tt class="py-line"> <tt class="py-string">"Point intents - Bring the core links up that are down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1404<a name="L1230"></a><tt class="py-lineno">1230</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-341', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Bring randomly cut links on Core devices up"</tt> <tt class="py-op">)</tt> </tt>
1405<a name="L1231"></a><tt class="py-lineno">1231</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">int</tt><tt class="py-op">(</tt> <tt class="py-name">switchLinksToToggle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1406<a name="L1232"></a><tt class="py-lineno">1232</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-342" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-342', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1407<a name="L1233"></a><tt class="py-lineno">1233</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link1End1</tt><tt class="py-op">,</tt> </tt>
1408<a name="L1234"></a><tt class="py-lineno">1234</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1409<a name="L1235"></a><tt class="py-lineno">1235</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
1410<a name="L1236"></a><tt class="py-lineno">1236</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1411<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 class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-343" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-343', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1412<a name="L1238"></a><tt class="py-lineno">1238</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link2End1</tt><tt class="py-op">,</tt> </tt>
1413<a name="L1239"></a><tt class="py-lineno">1239</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1414<a name="L1240"></a><tt class="py-lineno">1240</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
1415<a name="L1241"></a><tt class="py-lineno">1241</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1416<a name="L1242"></a><tt class="py-lineno">1242</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-344" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-344', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1417<a name="L1243"></a><tt class="py-lineno">1243</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link3End1</tt><tt class="py-op">,</tt> </tt>
1418<a name="L1244"></a><tt class="py-lineno">1244</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt><tt class="py-op">[</tt> <tt class="py-name">i</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1419<a name="L1245"></a><tt class="py-lineno">1245</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt> <tt class="py-op">)</tt> </tt>
1420<a name="L1246"></a><tt class="py-lineno">1246</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1421<a name="L1247"></a><tt class="py-lineno">1247</tt> <tt class="py-line"> </tt>
1422<a name="L1248"></a><tt class="py-lineno">1248</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-345" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1423TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-345', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1424<a name="L1249"></a><tt class="py-lineno">1249</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-346" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1425TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-346', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1426<a name="L1250"></a><tt class="py-lineno">1250</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> </tt>
1427<a name="L1251"></a><tt class="py-lineno">1251</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> </tt>
1428<a name="L1252"></a><tt class="py-lineno">1252</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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1429<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>
1430<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">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt><tt class="py-op">,</tt> </tt>
1431<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">linkUp</tt><tt class="py-op">,</tt> </tt>
1432<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">"Link up discovered properly"</tt><tt class="py-op">,</tt> </tt>
1433<a name="L1257"></a><tt class="py-lineno">1257</tt> <tt class="py-line"> <tt id="link-347" class="py-name"><a title="TestON.core.teston.TestON.onfail
1434TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-347', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link up was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1435<a name="L1258"></a><tt class="py-lineno">1258</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1436<a name="L1259"></a><tt class="py-lineno">1259</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1437<a name="L1260"></a><tt class="py-lineno">1260</tt> <tt class="py-line"> </tt>
1438<a name="L1261"></a><tt class="py-lineno">1261</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-348" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-348', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1439<a name="L1262"></a><tt class="py-lineno">1262</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1440<a name="L1263"></a><tt class="py-lineno">1263</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>
1441<a name="L1264"></a><tt class="py-lineno">1264</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</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-349" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-349', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">)</tt> </tt>
1442<a name="L1265"></a><tt class="py-lineno">1265</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>
1443<a name="L1266"></a><tt class="py-lineno">1266</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1444<a name="L1267"></a><tt class="py-lineno">1267</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1445<a name="L1268"></a><tt class="py-lineno">1268</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1446<a name="L1269"></a><tt class="py-lineno">1269</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1447<a name="L1270"></a><tt class="py-lineno">1270</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1448<a name="L1271"></a><tt class="py-lineno">1271</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">pingResultLinkUp</tt><tt class="py-op">,</tt> </tt>
1449<a name="L1272"></a><tt class="py-lineno">1272</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1450<a name="L1273"></a><tt class="py-lineno">1273</tt> <tt class="py-line"> <tt id="link-351" class="py-name"><a title="TestON.core.teston.TestON.onfail
1451TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-351', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1452<a name="L1274"></a><tt class="py-lineno">1274</tt> <tt class="py-line"> </tt>
1453<a name="L1275"></a><tt class="py-lineno">1275</tt> <tt class="py-line"> <tt class="py-name">caseResult81</tt> <tt class="py-op">=</tt> <tt class="py-name">linkUp</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkUp</tt> </tt>
1454<a name="L1276"></a><tt class="py-lineno">1276</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">caseResult81</tt><tt class="py-op">,</tt> </tt>
1455<a name="L1277"></a><tt class="py-lineno">1277</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test PASS"</tt><tt class="py-op">,</tt> </tt>
1456<a name="L1278"></a><tt class="py-lineno">1278</tt> <tt class="py-line"> <tt id="link-352" class="py-name"><a title="TestON.core.teston.TestON.onfail
1457TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-352', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1458</div><a name="L1279"></a><tt class="py-lineno">1279</tt> <tt class="py-line"> </tt>
1459<a name="CHOtest.CASE72"></a><div id="CHOtest.CASE72-def"><a name="L1280"></a><tt class="py-lineno">1280</tt> <a class="py-toggle" href="#" id="CHOtest.CASE72-toggle" onclick="return toggle('CHOtest.CASE72');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE72">CASE72</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>
1460</div><div id="CHOtest.CASE72-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE72-expanded"><a name="L1281"></a><tt class="py-lineno">1281</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1461<a name="L1282"></a><tt class="py-lineno">1282</tt> <tt class="py-line"><tt class="py-docstring"> Randomly bring some links down and verify ping all ( Host Intents-Chordal Topo)</tt> </tt>
1462<a name="L1283"></a><tt class="py-lineno">1283</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1463<a name="L1284"></a><tt class="py-lineno">1284</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1464<a name="L1285"></a><tt class="py-lineno">1285</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1465<a name="L1286"></a><tt class="py-lineno">1286</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1466<a name="L1287"></a><tt class="py-lineno">1287</tt> <tt class="py-line"> </tt>
1467<a name="L1288"></a><tt class="py-lineno">1288</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Randomly bring some core links down and verify ping all (Host Intents-Chordal Topo)"</tt> <tt class="py-op">)</tt> </tt>
1468<a name="L1289"></a><tt class="py-lineno">1289</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-354" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-354', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1469<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-355" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-355', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Host intents - Randomly bring some core links down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1470<a name="L1291"></a><tt class="py-lineno">1291</tt> <tt class="py-line"> <tt class="py-name">switches</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1471<a name="L1292"></a><tt class="py-lineno">1292</tt> <tt class="py-line"> <tt class="py-name">switchesComb</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1472<a name="L1293"></a><tt class="py-lineno">1293</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">numMNswitches</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1473<a name="L1294"></a><tt class="py-lineno">1294</tt> <tt class="py-line"> <tt class="py-name">switches</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-string">'s%d'</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-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
1474<a name="L1295"></a><tt class="py-lineno">1295</tt> <tt class="py-line"> <tt class="py-name">switchesLinksComb</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt><tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">combinations</tt><tt class="py-op">(</tt><tt class="py-name">switches</tt><tt class="py-op">,</tt><tt class="py-number">2</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
1475<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 class="py-name">randomLinks</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt><tt class="py-name">switchesLinksComb</tt><tt class="py-op">,</tt> <tt class="py-number">5</tt> <tt class="py-op">)</tt> </tt>
1476<a name="L1297"></a><tt class="py-lineno">1297</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">randomLinks</tt> </tt>
1477<a name="L1298"></a><tt class="py-lineno">1298</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-356', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cut links on random devices"</tt> <tt class="py-op">)</tt> </tt>
1478<a name="L1299"></a><tt class="py-lineno">1299</tt> <tt class="py-line"> </tt>
1479<a name="L1300"></a><tt class="py-lineno">1300</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">switch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLinks</tt><tt class="py-op">:</tt> </tt>
1480<a name="L1301"></a><tt class="py-lineno">1301</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-357" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-357', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1481<a name="L1302"></a><tt class="py-lineno">1302</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1482<a name="L1303"></a><tt class="py-lineno">1303</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1483<a name="L1304"></a><tt class="py-lineno">1304</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt><tt class="py-op">)</tt> </tt>
1484<a name="L1305"></a><tt class="py-lineno">1305</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1485<a name="L1306"></a><tt class="py-lineno">1306</tt> <tt class="py-line"> </tt>
1486<a name="L1307"></a><tt class="py-lineno">1307</tt> <tt class="py-line"> <tt class="py-name">topology_output</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.topology
1487TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-358', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1488<a name="L1308"></a><tt class="py-lineno">1308</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-359" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1489TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-359', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1490<a name="L1309"></a><tt class="py-lineno">1309</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt>
1491<a name="L1310"></a><tt class="py-lineno">1310</tt> <tt class="py-line"> <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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">5</tt> <tt class="py-op">*</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1492<a name="L1311"></a><tt class="py-lineno">1311</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>
1493<a name="L1312"></a><tt class="py-lineno">1312</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>
1494<a name="L1313"></a><tt class="py-lineno">1313</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkDown</tt><tt class="py-op">,</tt> </tt>
1495<a name="L1314"></a><tt class="py-lineno">1314</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Down discovered properly"</tt><tt class="py-op">,</tt> </tt>
1496<a name="L1315"></a><tt class="py-lineno">1315</tt> <tt class="py-line"> <tt id="link-360" class="py-name"><a title="TestON.core.teston.TestON.onfail
1497TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-360', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link down was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1498<a name="L1316"></a><tt class="py-lineno">1316</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1499<a name="L1317"></a><tt class="py-lineno">1317</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1500<a name="L1318"></a><tt class="py-lineno">1318</tt> <tt class="py-line"> </tt>
1501<a name="L1319"></a><tt class="py-lineno">1319</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-361" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-361', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1502<a name="L1320"></a><tt class="py-lineno">1320</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1503<a name="L1321"></a><tt class="py-lineno">1321</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>
1504<a name="L1322"></a><tt class="py-lineno">1322</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</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-362" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-362', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1505<a name="L1323"></a><tt class="py-lineno">1323</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>
1506<a name="L1324"></a><tt class="py-lineno">1324</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1507<a name="L1325"></a><tt class="py-lineno">1325</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-363" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-363', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1508<a name="L1326"></a><tt class="py-lineno">1326</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1509<a name="L1327"></a><tt class="py-lineno">1327</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1510<a name="L1328"></a><tt class="py-lineno">1328</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1511<a name="L1329"></a><tt class="py-lineno">1329</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">pingResultLinkDown</tt><tt class="py-op">,</tt> </tt>
1512<a name="L1330"></a><tt class="py-lineno">1330</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1513<a name="L1331"></a><tt class="py-lineno">1331</tt> <tt class="py-line"> <tt id="link-364" class="py-name"><a title="TestON.core.teston.TestON.onfail
1514TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-364', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1515<a name="L1332"></a><tt class="py-lineno">1332</tt> <tt class="py-line"> </tt>
1516<a name="L1333"></a><tt class="py-lineno">1333</tt> <tt class="py-line"> <tt class="py-name">caseResult71</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResultLinkDown</tt> </tt>
1517<a name="L1334"></a><tt class="py-lineno">1334</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">caseResult71</tt><tt class="py-op">,</tt> </tt>
1518<a name="L1335"></a><tt class="py-lineno">1335</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test PASS"</tt><tt class="py-op">,</tt> </tt>
1519<a name="L1336"></a><tt class="py-lineno">1336</tt> <tt class="py-line"> <tt id="link-365" class="py-name"><a title="TestON.core.teston.TestON.onfail
1520TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-365', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1521</div><a name="L1337"></a><tt class="py-lineno">1337</tt> <tt class="py-line"> </tt>
1522<a name="CHOtest.CASE82"></a><div id="CHOtest.CASE82-def"><a name="L1338"></a><tt class="py-lineno">1338</tt> <a class="py-toggle" href="#" id="CHOtest.CASE82-toggle" onclick="return toggle('CHOtest.CASE82');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE82">CASE82</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>
1523</div><div id="CHOtest.CASE82-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE82-expanded"><a name="L1339"></a><tt class="py-lineno">1339</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1524<a name="L1340"></a><tt class="py-lineno">1340</tt> <tt class="py-line"><tt class="py-docstring"> Bring the core links up that are down and verify ping all ( Host Intents Chordal Topo )</tt> </tt>
1525<a name="L1341"></a><tt class="py-lineno">1341</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1526<a name="L1342"></a><tt class="py-lineno">1342</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1527<a name="L1343"></a><tt class="py-lineno">1343</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1528<a name="L1344"></a><tt class="py-lineno">1344</tt> <tt class="py-line"> </tt>
1529<a name="L1345"></a><tt class="py-lineno">1345</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-366" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-366', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1530<a name="L1346"></a><tt class="py-lineno">1346</tt> <tt class="py-line"> <tt class="py-string">"Bring the core links up that are down and verify ping all (Host Intents-Chordal Topo"</tt> <tt class="py-op">)</tt> </tt>
1531<a name="L1347"></a><tt class="py-lineno">1347</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-367" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-367', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1532<a name="L1348"></a><tt class="py-lineno">1348</tt> <tt class="py-line"> <tt class="py-string">"__________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1533<a name="L1349"></a><tt class="py-lineno">1349</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-368" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-368', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
1534<a name="L1350"></a><tt class="py-lineno">1350</tt> <tt class="py-line"> <tt class="py-string">"Host intents - Bring the core links up that are down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1535<a name="L1351"></a><tt class="py-lineno">1351</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-369" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-369', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Bring randomly cut links on devices up"</tt> <tt class="py-op">)</tt> </tt>
1536<a name="L1352"></a><tt class="py-lineno">1352</tt> <tt class="py-line"> </tt>
1537<a name="L1353"></a><tt class="py-lineno">1353</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">switch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLinks</tt><tt class="py-op">:</tt> </tt>
1538<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 class="py-name">Mininet1</tt><tt class="py-op">.</tt><tt id="link-370" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-370', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1539<a name="L1355"></a><tt class="py-lineno">1355</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1540<a name="L1356"></a><tt class="py-lineno">1356</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1541<a name="L1357"></a><tt class="py-lineno">1357</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt><tt class="py-op">)</tt> </tt>
1542<a name="L1358"></a><tt class="py-lineno">1358</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1543<a name="L1359"></a><tt class="py-lineno">1359</tt> <tt class="py-line"> </tt>
1544<a name="L1360"></a><tt class="py-lineno">1360</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-371" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1545TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-371', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1546<a name="L1361"></a><tt class="py-lineno">1361</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-372" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1547TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-372', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1548<a name="L1362"></a><tt class="py-lineno">1362</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> </tt>
1549<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 class="py-name">numMNswitches</tt><tt class="py-op">,</tt> </tt>
1550<a name="L1364"></a><tt class="py-lineno">1364</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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1551<a name="L1365"></a><tt class="py-lineno">1365</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>
1552<a name="L1366"></a><tt class="py-lineno">1366</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>
1553<a name="L1367"></a><tt class="py-lineno">1367</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkUp</tt><tt class="py-op">,</tt> </tt>
1554<a name="L1368"></a><tt class="py-lineno">1368</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link up discovered properly"</tt><tt class="py-op">,</tt> </tt>
1555<a name="L1369"></a><tt class="py-lineno">1369</tt> <tt class="py-line"> <tt id="link-373" class="py-name"><a title="TestON.core.teston.TestON.onfail
1556TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-373', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link up was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1557<a name="L1370"></a><tt class="py-lineno">1370</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1558<a name="L1371"></a><tt class="py-lineno">1371</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1559<a name="L1372"></a><tt class="py-lineno">1372</tt> <tt class="py-line"> </tt>
1560<a name="L1373"></a><tt class="py-lineno">1373</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-374', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1561<a name="L1374"></a><tt class="py-lineno">1374</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1562<a name="L1375"></a><tt class="py-lineno">1375</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>
1563<a name="L1376"></a><tt class="py-lineno">1376</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</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-375" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-375', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1564<a name="L1377"></a><tt class="py-lineno">1377</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>
1565<a name="L1378"></a><tt class="py-lineno">1378</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1566<a name="L1379"></a><tt class="py-lineno">1379</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1567<a name="L1380"></a><tt class="py-lineno">1380</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1568<a name="L1381"></a><tt class="py-lineno">1381</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1569<a name="L1382"></a><tt class="py-lineno">1382</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1570<a name="L1383"></a><tt class="py-lineno">1383</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">pingResultLinkUp</tt><tt class="py-op">,</tt> </tt>
1571<a name="L1384"></a><tt class="py-lineno">1384</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1572<a name="L1385"></a><tt class="py-lineno">1385</tt> <tt class="py-line"> <tt id="link-377" class="py-name"><a title="TestON.core.teston.TestON.onfail
1573TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-377', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1574<a name="L1386"></a><tt class="py-lineno">1386</tt> <tt class="py-line"> </tt>
1575<a name="L1387"></a><tt class="py-lineno">1387</tt> <tt class="py-line"> <tt class="py-name">caseResult82</tt> <tt class="py-op">=</tt> <tt class="py-name">linkUp</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkUp</tt> </tt>
1576<a name="L1388"></a><tt class="py-lineno">1388</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">caseResult82</tt><tt class="py-op">,</tt> </tt>
1577<a name="L1389"></a><tt class="py-lineno">1389</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test PASS"</tt><tt class="py-op">,</tt> </tt>
1578<a name="L1390"></a><tt class="py-lineno">1390</tt> <tt class="py-line"> <tt id="link-378" class="py-name"><a title="TestON.core.teston.TestON.onfail
1579TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-378', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1580</div><a name="L1391"></a><tt class="py-lineno">1391</tt> <tt class="py-line"> </tt>
1581<a name="CHOtest.CASE73"></a><div id="CHOtest.CASE73-def"><a name="L1392"></a><tt class="py-lineno">1392</tt> <a class="py-toggle" href="#" id="CHOtest.CASE73-toggle" onclick="return toggle('CHOtest.CASE73');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE73">CASE73</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>
1582</div><div id="CHOtest.CASE73-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE73-expanded"><a name="L1393"></a><tt class="py-lineno">1393</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1583<a name="L1394"></a><tt class="py-lineno">1394</tt> <tt class="py-line"><tt class="py-docstring"> Randomly bring some links down and verify ping all ( Point Intents-Chordal Topo)</tt> </tt>
1584<a name="L1395"></a><tt class="py-lineno">1395</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1585<a name="L1396"></a><tt class="py-lineno">1396</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1586<a name="L1397"></a><tt class="py-lineno">1397</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1587<a name="L1398"></a><tt class="py-lineno">1398</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1588<a name="L1399"></a><tt class="py-lineno">1399</tt> <tt class="py-line"> </tt>
1589<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-379" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-379', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Randomly bring some core links down and verify ping all ( Point Intents-Chordal Topo)"</tt> <tt class="py-op">)</tt> </tt>
1590<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 id="link-380" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-380', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1591<a name="L1402"></a><tt class="py-lineno">1402</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-381', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Point intents - Randomly bring some core links down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1592<a name="L1403"></a><tt class="py-lineno">1403</tt> <tt class="py-line"> <tt class="py-name">switches</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1593<a name="L1404"></a><tt class="py-lineno">1404</tt> <tt class="py-line"> <tt class="py-name">switchesComb</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1594<a name="L1405"></a><tt class="py-lineno">1405</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">numMNswitches</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1595<a name="L1406"></a><tt class="py-lineno">1406</tt> <tt class="py-line"> <tt class="py-name">switches</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-string">'s%d'</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-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
1596<a name="L1407"></a><tt class="py-lineno">1407</tt> <tt class="py-line"> <tt class="py-name">switchesLinksComb</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt><tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">combinations</tt><tt class="py-op">(</tt><tt class="py-name">switches</tt><tt class="py-op">,</tt><tt class="py-number">2</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
1597<a name="L1408"></a><tt class="py-lineno">1408</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLinks</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt><tt class="py-name">switchesLinksComb</tt><tt class="py-op">,</tt> <tt class="py-number">5</tt> <tt class="py-op">)</tt> </tt>
1598<a name="L1409"></a><tt class="py-lineno">1409</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">randomLinks</tt> </tt>
1599<a name="L1410"></a><tt class="py-lineno">1410</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-382" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-382', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cut links on random devices"</tt> <tt class="py-op">)</tt> </tt>
1600<a name="L1411"></a><tt class="py-lineno">1411</tt> <tt class="py-line"> </tt>
1601<a name="L1412"></a><tt class="py-lineno">1412</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">switch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLinks</tt><tt class="py-op">:</tt> </tt>
1602<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">Mininet1</tt><tt class="py-op">.</tt><tt id="link-383" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-383', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1603<a name="L1414"></a><tt class="py-lineno">1414</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1604<a name="L1415"></a><tt class="py-lineno">1415</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1605<a name="L1416"></a><tt class="py-lineno">1416</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"down"</tt><tt class="py-op">)</tt> </tt>
1606<a name="L1417"></a><tt class="py-lineno">1417</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1607<a name="L1418"></a><tt class="py-lineno">1418</tt> <tt class="py-line"> </tt>
1608<a name="L1419"></a><tt class="py-lineno">1419</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-384" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1609TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-384', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1610<a name="L1420"></a><tt class="py-lineno">1420</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-385" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1611TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-385', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1612<a name="L1421"></a><tt class="py-lineno">1421</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt>
1613<a name="L1422"></a><tt class="py-lineno">1422</tt> <tt class="py-line"> <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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">5</tt> <tt class="py-op">*</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1614<a name="L1423"></a><tt class="py-lineno">1423</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>
1615<a name="L1424"></a><tt class="py-lineno">1424</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>
1616<a name="L1425"></a><tt class="py-lineno">1425</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkDown</tt><tt class="py-op">,</tt> </tt>
1617<a name="L1426"></a><tt class="py-lineno">1426</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Down discovered properly"</tt><tt class="py-op">,</tt> </tt>
1618<a name="L1427"></a><tt class="py-lineno">1427</tt> <tt class="py-line"> <tt id="link-386" class="py-name"><a title="TestON.core.teston.TestON.onfail
1619TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-386', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link down was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1620<a name="L1428"></a><tt class="py-lineno">1428</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1621<a name="L1429"></a><tt class="py-lineno">1429</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1622<a name="L1430"></a><tt class="py-lineno">1430</tt> <tt class="py-line"> </tt>
1623<a name="L1431"></a><tt class="py-lineno">1431</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-387', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1624<a name="L1432"></a><tt class="py-lineno">1432</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1625<a name="L1433"></a><tt class="py-lineno">1433</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>
1626<a name="L1434"></a><tt class="py-lineno">1434</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</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-388" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-388', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1627<a name="L1435"></a><tt class="py-lineno">1435</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>
1628<a name="L1436"></a><tt class="py-lineno">1436</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1629<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 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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1630<a name="L1438"></a><tt class="py-lineno">1438</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1631<a name="L1439"></a><tt class="py-lineno">1439</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1632<a name="L1440"></a><tt class="py-lineno">1440</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1633<a name="L1441"></a><tt class="py-lineno">1441</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">pingResultLinkDown</tt><tt class="py-op">,</tt> </tt>
1634<a name="L1442"></a><tt class="py-lineno">1442</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1635<a name="L1443"></a><tt class="py-lineno">1443</tt> <tt class="py-line"> <tt id="link-390" class="py-name"><a title="TestON.core.teston.TestON.onfail
1636TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-390', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1637<a name="L1444"></a><tt class="py-lineno">1444</tt> <tt class="py-line"> </tt>
1638<a name="L1445"></a><tt class="py-lineno">1445</tt> <tt class="py-line"> <tt class="py-name">caseResult73</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResultLinkDown</tt> </tt>
1639<a name="L1446"></a><tt class="py-lineno">1446</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">caseResult73</tt><tt class="py-op">,</tt> </tt>
1640<a name="L1447"></a><tt class="py-lineno">1447</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test PASS"</tt><tt class="py-op">,</tt> </tt>
1641<a name="L1448"></a><tt class="py-lineno">1448</tt> <tt class="py-line"> <tt id="link-391" class="py-name"><a title="TestON.core.teston.TestON.onfail
1642TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-391', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1643</div><a name="L1449"></a><tt class="py-lineno">1449</tt> <tt class="py-line"> </tt>
1644<a name="CHOtest.CASE83"></a><div id="CHOtest.CASE83-def"><a name="L1450"></a><tt class="py-lineno">1450</tt> <a class="py-toggle" href="#" id="CHOtest.CASE83-toggle" onclick="return toggle('CHOtest.CASE83');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE83">CASE83</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>
1645</div><div id="CHOtest.CASE83-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE83-expanded"><a name="L1451"></a><tt class="py-lineno">1451</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1646<a name="L1452"></a><tt class="py-lineno">1452</tt> <tt class="py-line"><tt class="py-docstring"> Bring the core links up that are down and verify ping all ( Point Intents Chordal Topo )</tt> </tt>
1647<a name="L1453"></a><tt class="py-lineno">1453</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1648<a name="L1454"></a><tt class="py-lineno">1454</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1649<a name="L1455"></a><tt class="py-lineno">1455</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1650<a name="L1456"></a><tt class="py-lineno">1456</tt> <tt class="py-line"> </tt>
1651<a name="L1457"></a><tt class="py-lineno">1457</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-392" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-392', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1652<a name="L1458"></a><tt class="py-lineno">1458</tt> <tt class="py-line"> <tt class="py-string">"Bring the core links up that are down and verify ping all ( Point Intents-Chordal Topo"</tt> <tt class="py-op">)</tt> </tt>
1653<a name="L1459"></a><tt class="py-lineno">1459</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-393" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-393', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1654<a name="L1460"></a><tt class="py-lineno">1460</tt> <tt class="py-line"> <tt class="py-string">"__________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1655<a name="L1461"></a><tt class="py-lineno">1461</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-394" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-394', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
1656<a name="L1462"></a><tt class="py-lineno">1462</tt> <tt class="py-line"> <tt class="py-string">"Point intents - Bring the core links up that are down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1657<a name="L1463"></a><tt class="py-lineno">1463</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-395" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-395', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Bring randomly cut links on devices up"</tt> <tt class="py-op">)</tt> </tt>
1658<a name="L1464"></a><tt class="py-lineno">1464</tt> <tt class="py-line"> </tt>
1659<a name="L1465"></a><tt class="py-lineno">1465</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">switch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLinks</tt><tt class="py-op">:</tt> </tt>
1660<a name="L1466"></a><tt class="py-lineno">1466</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-396" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-396', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> </tt>
1661<a name="L1467"></a><tt class="py-lineno">1467</tt> <tt class="py-line"> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1662<a name="L1468"></a><tt class="py-lineno">1468</tt> <tt class="py-line"> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">switch</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
1663<a name="L1469"></a><tt class="py-lineno">1469</tt> <tt class="py-line"> <tt class="py-name">OPTION</tt><tt class="py-op">=</tt><tt class="py-string">"up"</tt><tt class="py-op">)</tt> </tt>
1664<a name="L1470"></a><tt class="py-lineno">1470</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1665<a name="L1471"></a><tt class="py-lineno">1471</tt> <tt class="py-line"> </tt>
1666<a name="L1472"></a><tt class="py-lineno">1472</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-397" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1667TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-397', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1668<a name="L1473"></a><tt class="py-lineno">1473</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-398" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1669TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-398', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1670<a name="L1474"></a><tt class="py-lineno">1474</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> </tt>
1671<a name="L1475"></a><tt class="py-lineno">1475</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> </tt>
1672<a name="L1476"></a><tt class="py-lineno">1476</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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1673<a name="L1477"></a><tt class="py-lineno">1477</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>
1674<a name="L1478"></a><tt class="py-lineno">1478</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>
1675<a name="L1479"></a><tt class="py-lineno">1479</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkUp</tt><tt class="py-op">,</tt> </tt>
1676<a name="L1480"></a><tt class="py-lineno">1480</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link up discovered properly"</tt><tt class="py-op">,</tt> </tt>
1677<a name="L1481"></a><tt class="py-lineno">1481</tt> <tt class="py-line"> <tt id="link-399" class="py-name"><a title="TestON.core.teston.TestON.onfail
1678TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-399', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link up was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1679<a name="L1482"></a><tt class="py-lineno">1482</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1680<a name="L1483"></a><tt class="py-lineno">1483</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1681<a name="L1484"></a><tt class="py-lineno">1484</tt> <tt class="py-line"> </tt>
1682<a name="L1485"></a><tt class="py-lineno">1485</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-400', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1683<a name="L1486"></a><tt class="py-lineno">1486</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1684<a name="L1487"></a><tt class="py-lineno">1487</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>
1685<a name="L1488"></a><tt class="py-lineno">1488</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</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-401" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-401', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1686<a name="L1489"></a><tt class="py-lineno">1489</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>
1687<a name="L1490"></a><tt class="py-lineno">1490</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1688<a name="L1491"></a><tt class="py-lineno">1491</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-402" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-402', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1689<a name="L1492"></a><tt class="py-lineno">1492</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1690<a name="L1493"></a><tt class="py-lineno">1493</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1691<a name="L1494"></a><tt class="py-lineno">1494</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1692<a name="L1495"></a><tt class="py-lineno">1495</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">pingResultLinkUp</tt><tt class="py-op">,</tt> </tt>
1693<a name="L1496"></a><tt class="py-lineno">1496</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1694<a name="L1497"></a><tt class="py-lineno">1497</tt> <tt class="py-line"> <tt id="link-403" class="py-name"><a title="TestON.core.teston.TestON.onfail
1695TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-403', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1696<a name="L1498"></a><tt class="py-lineno">1498</tt> <tt class="py-line"> </tt>
1697<a name="L1499"></a><tt class="py-lineno">1499</tt> <tt class="py-line"> <tt class="py-name">caseResult83</tt> <tt class="py-op">=</tt> <tt class="py-name">linkUp</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkUp</tt> </tt>
1698<a name="L1500"></a><tt class="py-lineno">1500</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">caseResult83</tt><tt class="py-op">,</tt> </tt>
1699<a name="L1501"></a><tt class="py-lineno">1501</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test PASS"</tt><tt class="py-op">,</tt> </tt>
1700<a name="L1502"></a><tt class="py-lineno">1502</tt> <tt class="py-line"> <tt id="link-404" class="py-name"><a title="TestON.core.teston.TestON.onfail
1701TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-404', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1702</div><a name="L1503"></a><tt class="py-lineno">1503</tt> <tt class="py-line"> </tt>
1703<a name="CHOtest.CASE74"></a><div id="CHOtest.CASE74-def"><a name="L1504"></a><tt class="py-lineno">1504</tt> <a class="py-toggle" href="#" id="CHOtest.CASE74-toggle" onclick="return toggle('CHOtest.CASE74');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE74">CASE74</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>
1704</div><div id="CHOtest.CASE74-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE74-expanded"><a name="L1505"></a><tt class="py-lineno">1505</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1705<a name="L1506"></a><tt class="py-lineno">1506</tt> <tt class="py-line"><tt class="py-docstring"> Randomly bring some core links down and verify ping all ( Host Intents-Spine Topo)</tt> </tt>
1706<a name="L1507"></a><tt class="py-lineno">1507</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1707<a name="L1508"></a><tt class="py-lineno">1508</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1708<a name="L1509"></a><tt class="py-lineno">1509</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink1</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1709<a name="L1510"></a><tt class="py-lineno">1510</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1710<a name="L1511"></a><tt class="py-lineno">1511</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1711<a name="L1512"></a><tt class="py-lineno">1512</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink4</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1712<a name="L1513"></a><tt class="py-lineno">1513</tt> <tt class="py-line"> <tt class="py-name">link1End1</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS9'</tt> <tt class="py-op">]</tt> </tt>
1713<a name="L1514"></a><tt class="py-lineno">1514</tt> <tt class="py-line"> <tt class="py-name">link1End2top</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS9top'</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>
1714<a name="L1515"></a><tt class="py-lineno">1515</tt> <tt class="py-line"> <tt class="py-name">link1End2bot</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS9bot'</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>
1715<a name="L1516"></a><tt class="py-lineno">1516</tt> <tt class="py-line"> <tt class="py-name">link2End1</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS10'</tt> <tt class="py-op">]</tt> </tt>
1716<a name="L1517"></a><tt class="py-lineno">1517</tt> <tt class="py-line"> <tt class="py-name">link2End2top</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS10top'</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>
1717<a name="L1518"></a><tt class="py-lineno">1518</tt> <tt class="py-line"> <tt class="py-name">link2End2bot</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS10bot'</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>
1718<a name="L1519"></a><tt class="py-lineno">1519</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1719<a name="L1520"></a><tt class="py-lineno">1520</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">400</tt> </tt>
1720<a name="L1521"></a><tt class="py-lineno">1521</tt> <tt class="py-line"> </tt>
1721<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-405" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-405', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Bring some core links down and verify ping all (Host Intents-Spine Topo)"</tt> <tt class="py-op">)</tt> </tt>
1722<a name="L1523"></a><tt class="py-lineno">1523</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-406', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1723<a name="L1524"></a><tt class="py-lineno">1524</tt> <tt class="py-line"> </tt>
1724<a name="L1525"></a><tt class="py-lineno">1525</tt> <tt class="py-line"> <tt class="py-name">linkIndex</tt> <tt class="py-op">=</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">4</tt><tt class="py-op">)</tt> </tt>
1725<a name="L1526"></a><tt class="py-lineno">1526</tt> <tt class="py-line"> <tt class="py-name">linkIndexS9</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt><tt class="py-name">linkIndex</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-number">0</tt><tt class="py-op">]</tt> </tt>
1726<a name="L1527"></a><tt class="py-lineno">1527</tt> <tt class="py-line"> <tt class="py-name">linkIndex</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt><tt class="py-name">linkIndexS9</tt><tt class="py-op">)</tt> </tt>
1727<a name="L1528"></a><tt class="py-lineno">1528</tt> <tt class="py-line"> <tt class="py-name">linkIndexS10</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt><tt class="py-name">linkIndex</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-number">0</tt><tt class="py-op">]</tt> </tt>
1728<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 class="py-name">randomLink1</tt> <tt class="py-op">=</tt> <tt class="py-name">link1End2top</tt><tt class="py-op">[</tt><tt class="py-name">linkIndexS9</tt><tt class="py-op">]</tt> </tt>
1729<a name="L1530"></a><tt class="py-lineno">1530</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink2</tt> <tt class="py-op">=</tt> <tt class="py-name">link2End2top</tt><tt class="py-op">[</tt><tt class="py-name">linkIndexS10</tt><tt class="py-op">]</tt> </tt>
1730<a name="L1531"></a><tt class="py-lineno">1531</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt><tt class="py-name">link1End2bot</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-number">0</tt><tt class="py-op">]</tt> </tt>
1731<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 class="py-name">randomLink4</tt> <tt class="py-op">=</tt> <tt class="py-name">random</tt><tt class="py-op">.</tt><tt class="py-name">sample</tt><tt class="py-op">(</tt><tt class="py-name">link2End2bot</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-number">0</tt><tt class="py-op">]</tt> </tt>
1732<a name="L1533"></a><tt class="py-lineno">1533</tt> <tt class="py-line"> </tt>
1733<a name="L1534"></a><tt class="py-lineno">1534</tt> <tt class="py-line"> <tt class="py-comment"># Work around for link state propagation delay. Added some sleep time.</tt> </tt>
1734<a name="L1535"></a><tt class="py-lineno">1535</tt> <tt class="py-line"> <tt class="py-comment"># main.Mininet1.link( END1=link1End1, END2=main.randomLink1, OPTION="down" )</tt> </tt>
1735<a name="L1536"></a><tt class="py-lineno">1536</tt> <tt class="py-line"> <tt class="py-comment"># main.Mininet1.link( END1=link2End1, END2=main.randomLink2, OPTION="down" )</tt> </tt>
1736<a name="L1537"></a><tt class="py-lineno">1537</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-407" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-407', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link1End1</tt><tt class="py-op">,</tt> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</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>
1737<a name="L1538"></a><tt class="py-lineno">1538</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1738<a name="L1539"></a><tt class="py-lineno">1539</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-408" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-408', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link2End1</tt><tt class="py-op">,</tt> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink4</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>
1739<a name="L1540"></a><tt class="py-lineno">1540</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1740<a name="L1541"></a><tt class="py-lineno">1541</tt> <tt class="py-line"> </tt>
1741<a name="L1542"></a><tt class="py-lineno">1542</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-409" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1742TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-409', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1743<a name="L1543"></a><tt class="py-lineno">1543</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-410" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1744TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-410', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1745<a name="L1544"></a><tt class="py-lineno">1544</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt>
1746<a name="L1545"></a><tt class="py-lineno">1545</tt> <tt class="py-line"> <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">numMNlinks</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>
1747<a name="L1546"></a><tt class="py-lineno">1546</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>
1748<a name="L1547"></a><tt class="py-lineno">1547</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>
1749<a name="L1548"></a><tt class="py-lineno">1548</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkDown</tt><tt class="py-op">,</tt> </tt>
1750<a name="L1549"></a><tt class="py-lineno">1549</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Down discovered properly"</tt><tt class="py-op">,</tt> </tt>
1751<a name="L1550"></a><tt class="py-lineno">1550</tt> <tt class="py-line"> <tt id="link-411" class="py-name"><a title="TestON.core.teston.TestON.onfail
1752TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-411', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link down was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1753<a name="L1551"></a><tt class="py-lineno">1551</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1754<a name="L1552"></a><tt class="py-lineno">1552</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1755<a name="L1553"></a><tt class="py-lineno">1553</tt> <tt class="py-line"> </tt>
1756<a name="L1554"></a><tt class="py-lineno">1554</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-412', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1757<a name="L1555"></a><tt class="py-lineno">1555</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1758<a name="L1556"></a><tt class="py-lineno">1556</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>
1759<a name="L1557"></a><tt class="py-lineno">1557</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkDown</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-413" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-413', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1760<a name="L1558"></a><tt class="py-lineno">1558</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>
1761<a name="L1559"></a><tt class="py-lineno">1559</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1762<a name="L1560"></a><tt class="py-lineno">1560</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1763<a name="L1561"></a><tt class="py-lineno">1561</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1764<a name="L1562"></a><tt class="py-lineno">1562</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1765<a name="L1563"></a><tt class="py-lineno">1563</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1766<a name="L1564"></a><tt class="py-lineno">1564</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">pingResultLinkDown</tt><tt class="py-op">,</tt> </tt>
1767<a name="L1565"></a><tt class="py-lineno">1565</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1768<a name="L1566"></a><tt class="py-lineno">1566</tt> <tt class="py-line"> <tt id="link-415" class="py-name"><a title="TestON.core.teston.TestON.onfail
1769TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-415', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1770<a name="L1567"></a><tt class="py-lineno">1567</tt> <tt class="py-line"> </tt>
1771<a name="L1568"></a><tt class="py-lineno">1568</tt> <tt class="py-line"> <tt class="py-name">caseResult74</tt> <tt class="py-op">=</tt> <tt class="py-name">linkDown</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkDown</tt> </tt>
1772<a name="L1569"></a><tt class="py-lineno">1569</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">caseResult74</tt><tt class="py-op">,</tt> </tt>
1773<a name="L1570"></a><tt class="py-lineno">1570</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test PASS"</tt><tt class="py-op">,</tt> </tt>
1774<a name="L1571"></a><tt class="py-lineno">1571</tt> <tt class="py-line"> <tt id="link-416" class="py-name"><a title="TestON.core.teston.TestON.onfail
1775TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-416', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Random Link cut Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1776</div><a name="L1572"></a><tt class="py-lineno">1572</tt> <tt class="py-line"> </tt>
1777<a name="CHOtest.CASE84"></a><div id="CHOtest.CASE84-def"><a name="L1573"></a><tt class="py-lineno">1573</tt> <a class="py-toggle" href="#" id="CHOtest.CASE84-toggle" onclick="return toggle('CHOtest.CASE84');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE84">CASE84</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>
1778</div><div id="CHOtest.CASE84-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE84-expanded"><a name="L1574"></a><tt class="py-lineno">1574</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1779<a name="L1575"></a><tt class="py-lineno">1575</tt> <tt class="py-line"><tt class="py-docstring"> Bring the core links up that are down and verify ping all ( Host Intents-Spine Topo )</tt> </tt>
1780<a name="L1576"></a><tt class="py-lineno">1576</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1781<a name="L1577"></a><tt class="py-lineno">1577</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">random</tt> </tt>
1782<a name="L1578"></a><tt class="py-lineno">1578</tt> <tt class="py-line"> <tt class="py-name">link1End1</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS9'</tt> <tt class="py-op">]</tt> </tt>
1783<a name="L1579"></a><tt class="py-lineno">1579</tt> <tt class="py-line"> <tt class="py-name">link2End1</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">'SPINECORELINKS'</tt> <tt class="py-op">]</tt><tt class="py-op">[</tt> <tt class="py-string">'linkS10'</tt> <tt class="py-op">]</tt> </tt>
1784<a name="L1580"></a><tt class="py-lineno">1580</tt> <tt class="py-line"> <tt class="py-name">link_sleep</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">'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>
1785<a name="L1581"></a><tt class="py-lineno">1581</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-417" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-417', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1786<a name="L1582"></a><tt class="py-lineno">1582</tt> <tt class="py-line"> <tt class="py-string">"Bring the core links up that are down and verify ping all (Host Intents-Spine Topo"</tt> <tt class="py-op">)</tt> </tt>
1787<a name="L1583"></a><tt class="py-lineno">1583</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-418', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1788<a name="L1584"></a><tt class="py-lineno">1584</tt> <tt class="py-line"> <tt class="py-string">"__________________________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
1789<a name="L1585"></a><tt class="py-lineno">1585</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.case" class="py-name" href="#" onclick="return doclink('link-419', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> </tt>
1790<a name="L1586"></a><tt class="py-lineno">1586</tt> <tt class="py-line"> <tt class="py-string">"Host intents - Bring the core links up that are down and verify ping all"</tt> <tt class="py-op">)</tt> </tt>
1791<a name="L1587"></a><tt class="py-lineno">1587</tt> <tt class="py-line"> </tt>
1792<a name="L1588"></a><tt class="py-lineno">1588</tt> <tt class="py-line"> <tt class="py-comment"># Work around for link state propagation delay. Added some sleep time.</tt> </tt>
1793<a name="L1589"></a><tt class="py-lineno">1589</tt> <tt class="py-line"> <tt class="py-comment"># main.Mininet1.link( END1=link1End1, END2=main.randomLink1, OPTION="up" )</tt> </tt>
1794<a name="L1590"></a><tt class="py-lineno">1590</tt> <tt class="py-line"> <tt class="py-comment"># main.Mininet1.link( END1=link2End1, END2=main.randomLink2, OPTION="up" )</tt> </tt>
1795<a name="L1591"></a><tt class="py-lineno">1591</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-420" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-420', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link1End1</tt><tt class="py-op">,</tt> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink3</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>
1796<a name="L1592"></a><tt class="py-lineno">1592</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1797<a name="L1593"></a><tt class="py-lineno">1593</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-421" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.link" class="py-name" href="#" onclick="return doclink('link-421', 'link', 'link-294');">link</a></tt><tt class="py-op">(</tt> <tt class="py-name">END1</tt><tt class="py-op">=</tt><tt class="py-name">link2End1</tt><tt class="py-op">,</tt> <tt class="py-name">END2</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">randomLink4</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>
1798<a name="L1594"></a><tt class="py-lineno">1594</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">link_sleep</tt> <tt class="py-op">)</tt> </tt>
1799<a name="L1595"></a><tt class="py-lineno">1595</tt> <tt class="py-line"> </tt>
1800<a name="L1596"></a><tt class="py-lineno">1596</tt> <tt class="py-line"> <tt class="py-name">topology_output</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-422" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology
1801TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-422', 'topology', 'link-62');">topology</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1802<a name="L1597"></a><tt class="py-lineno">1597</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">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-423" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkStatus
1803TestON.drivers.common.cli.onosdriver.OnosDriver.checkStatus" class="py-name" href="#" onclick="return doclink('link-423', 'checkStatus', 'link-298');">checkStatus</a></tt><tt class="py-op">(</tt> </tt>
1804<a name="L1598"></a><tt class="py-lineno">1598</tt> <tt class="py-line"> <tt class="py-name">topology_output</tt><tt class="py-op">,</tt> </tt>
1805<a name="L1599"></a><tt class="py-lineno">1599</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">numMNswitches</tt><tt class="py-op">,</tt> </tt>
1806<a name="L1600"></a><tt class="py-lineno">1600</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">numMNlinks</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1807<a name="L1601"></a><tt class="py-lineno">1601</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>
1808<a name="L1602"></a><tt class="py-lineno">1602</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>
1809<a name="L1603"></a><tt class="py-lineno">1603</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">linkUp</tt><tt class="py-op">,</tt> </tt>
1810<a name="L1604"></a><tt class="py-lineno">1604</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link up discovered properly"</tt><tt class="py-op">,</tt> </tt>
1811<a name="L1605"></a><tt class="py-lineno">1605</tt> <tt class="py-line"> <tt id="link-424" class="py-name"><a title="TestON.core.teston.TestON.onfail
1812TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-424', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link up was not discovered in "</tt> <tt class="py-op">+</tt> </tt>
1813<a name="L1606"></a><tt class="py-lineno">1606</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">link_sleep</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1814<a name="L1607"></a><tt class="py-lineno">1607</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1815<a name="L1608"></a><tt class="py-lineno">1608</tt> <tt class="py-line"> </tt>
1816<a name="L1609"></a><tt class="py-lineno">1609</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-425" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-425', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1817<a name="L1610"></a><tt class="py-lineno">1610</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
1818<a name="L1611"></a><tt class="py-lineno">1611</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>
1819<a name="L1612"></a><tt class="py-lineno">1612</tt> <tt class="py-line"> <tt class="py-name">pingResultLinkUp</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-426" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-426', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1820<a name="L1613"></a><tt class="py-lineno">1613</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>
1821<a name="L1614"></a><tt class="py-lineno">1614</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1822<a name="L1615"></a><tt class="py-lineno">1615</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-427', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1823<a name="L1616"></a><tt class="py-lineno">1616</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1824<a name="L1617"></a><tt class="py-lineno">1617</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1825<a name="L1618"></a><tt class="py-lineno">1618</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1826<a name="L1619"></a><tt class="py-lineno">1619</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">pingResultLinkUp</tt><tt class="py-op">,</tt> </tt>
1827<a name="L1620"></a><tt class="py-lineno">1620</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1828<a name="L1621"></a><tt class="py-lineno">1621</tt> <tt class="py-line"> <tt id="link-428" class="py-name"><a title="TestON.core.teston.TestON.onfail
1829TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-428', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1830<a name="L1622"></a><tt class="py-lineno">1622</tt> <tt class="py-line"> </tt>
1831<a name="L1623"></a><tt class="py-lineno">1623</tt> <tt class="py-line"> <tt class="py-name">caseResult84</tt> <tt class="py-op">=</tt> <tt class="py-name">linkUp</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResultLinkUp</tt> </tt>
1832<a name="L1624"></a><tt class="py-lineno">1624</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">caseResult84</tt><tt class="py-op">,</tt> </tt>
1833<a name="L1625"></a><tt class="py-lineno">1625</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test PASS"</tt><tt class="py-op">,</tt> </tt>
1834<a name="L1626"></a><tt class="py-lineno">1626</tt> <tt class="py-line"> <tt id="link-429" class="py-name"><a title="TestON.core.teston.TestON.onfail
1835TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-429', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Link Up Test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1836</div><a name="L1627"></a><tt class="py-lineno">1627</tt> <tt class="py-line"> </tt>
1837<a name="CHOtest.CASE90"></a><div id="CHOtest.CASE90-def"><a name="L1628"></a><tt class="py-lineno">1628</tt> <a class="py-toggle" href="#" id="CHOtest.CASE90-toggle" onclick="return toggle('CHOtest.CASE90');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE90">CASE90</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1838</div><div id="CHOtest.CASE90-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE90-expanded"><a name="L1629"></a><tt class="py-lineno">1629</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1839<a name="L1630"></a><tt class="py-lineno">1630</tt> <tt class="py-line"><tt class="py-docstring"> Install 600 point intents and verify ping all (Att Topology)</tt> </tt>
1840<a name="L1631"></a><tt class="py-lineno">1631</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1841<a name="L1632"></a><tt class="py-lineno">1632</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Add 600 point intents and verify pingall (Att Topology)"</tt> <tt class="py-op">)</tt> </tt>
1842<a name="L1633"></a><tt class="py-lineno">1633</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-431" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-431', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________________________"</tt> <tt class="py-op">)</tt> </tt>
1843<a name="L1634"></a><tt class="py-lineno">1634</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1844<a name="L1635"></a><tt class="py-lineno">1635</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
1845<a name="L1636"></a><tt class="py-lineno">1636</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-432', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install 600 point intents"</tt> <tt class="py-op">)</tt> </tt>
1846<a name="L1637"></a><tt class="py-lineno">1637</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-433" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-433', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add point Intents"</tt> <tt class="py-op">)</tt> </tt>
1847<a name="L1638"></a><tt class="py-lineno">1638</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1848<a name="L1639"></a><tt class="py-lineno">1639</tt> <tt class="py-line"> <tt class="py-name">deviceCombos</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt> <tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">permutations</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">,</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1849<a name="L1640"></a><tt class="py-lineno">1640</tt> <tt class="py-line"> </tt>
1850<a name="L1641"></a><tt class="py-lineno">1641</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1851<a name="L1642"></a><tt class="py-lineno">1642</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>
1852<a name="L1643"></a><tt class="py-lineno">1643</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">xrange</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 class="py-name">deviceCombos</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1853<a name="L1644"></a><tt class="py-lineno">1644</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1854<a name="L1645"></a><tt class="py-lineno">1645</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-434" class="py-name"><a title="TestON.bin.cli
1855TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-434', 'cli', 'link-106');">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>
1856<a name="L1646"></a><tt class="py-lineno">1646</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceCombos</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1857<a name="L1647"></a><tt class="py-lineno">1647</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
1858<a name="L1648"></a><tt class="py-lineno">1648</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-435" class="py-name"><a title="TestON.core.Thread
1859TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-435', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-436" class="py-name"><a title="TestON.bin.cli
1860TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-436', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-437" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addPointIntent()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#addPointIntent,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addPointIntent()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#addPointIntent"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addPointIntent
1861TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addPointIntent" class="py-name" href="#" onclick="return doclink('link-437', 'addPointIntent', 'link-437');">addPointIntent</a></tt><tt class="py-op">,</tt> </tt>
1862<a name="L1649"></a><tt class="py-lineno">1649</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
1863<a name="L1650"></a><tt class="py-lineno">1650</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addPointIntent"</tt><tt class="py-op">,</tt> </tt>
1864<a name="L1651"></a><tt class="py-lineno">1651</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">deviceCombos</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">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">deviceCombos</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 class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">,</tt><tt class="py-string">"IPV4"</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">deviceCombos</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">0</tt><tt class="py-op">]</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">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">deviceCombos</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 class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
1865<a name="L1652"></a><tt class="py-lineno">1652</tt> <tt class="py-line"> <tt class="py-name">pool</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>
1866<a name="L1653"></a><tt class="py-lineno">1653</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>
1867<a name="L1654"></a><tt class="py-lineno">1654</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1868<a name="L1655"></a><tt class="py-lineno">1655</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1869<a name="L1656"></a><tt class="py-lineno">1656</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
1870<a name="L1657"></a><tt class="py-lineno">1657</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1871<a name="L1658"></a><tt class="py-lineno">1658</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
1872<a name="L1659"></a><tt class="py-lineno">1659</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>
1873<a name="L1660"></a><tt class="py-lineno">1660</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-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
1874<a name="L1661"></a><tt class="py-lineno">1661</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1875<a name="L1662"></a><tt class="py-lineno">1662</tt> <tt class="py-line"> <tt class="py-name">intentsJson</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-439" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
1876TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-439', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1877<a name="L1663"></a><tt class="py-lineno">1663</tt> <tt class="py-line"> <tt class="py-name">getIntentStateResult</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-440" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState
1878TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState" class="py-name" href="#" onclick="return doclink('link-440', 'getIntentState', 'link-249');">getIntentState</a></tt><tt class="py-op">(</tt><tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt><tt class="py-op">,</tt> </tt>
1879<a name="L1664"></a><tt class="py-lineno">1664</tt> <tt class="py-line"> <tt class="py-name">intentsJson</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsJson</tt><tt class="py-op">)</tt> </tt>
1880<a name="L1665"></a><tt class="py-lineno">1665</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">getIntentStateResult</tt> </tt>
1881<a name="L1666"></a><tt class="py-lineno">1666</tt> <tt class="py-line"> <tt class="py-comment"># Takes awhile for all the onos to get the intents</tt> </tt>
1882<a name="L1667"></a><tt class="py-lineno">1667</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>
1883<a name="L1668"></a><tt class="py-lineno">1668</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-441" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-441', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1884<a name="L1669"></a><tt class="py-lineno">1669</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>
1885<a name="L1670"></a><tt class="py-lineno">1670</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>
1886<a name="L1671"></a><tt class="py-lineno">1671</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-442" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-442', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1887<a name="L1672"></a><tt class="py-lineno">1672</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>
1888<a name="L1673"></a><tt class="py-lineno">1673</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1889<a name="L1674"></a><tt class="py-lineno">1674</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-443" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-443', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1890<a name="L1675"></a><tt class="py-lineno">1675</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1891<a name="L1676"></a><tt class="py-lineno">1676</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1892<a name="L1677"></a><tt class="py-lineno">1677</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1893<a name="L1678"></a><tt class="py-lineno">1678</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">pingResult</tt><tt class="py-op">,</tt> </tt>
1894<a name="L1679"></a><tt class="py-lineno">1679</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING tALL PASS"</tt><tt class="py-op">,</tt> </tt>
1895<a name="L1680"></a><tt class="py-lineno">1680</tt> <tt class="py-line"> <tt id="link-444" class="py-name"><a title="TestON.core.teston.TestON.onfail
1896TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-444', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1897<a name="L1681"></a><tt class="py-lineno">1681</tt> <tt class="py-line"> </tt>
1898<a name="L1682"></a><tt class="py-lineno">1682</tt> <tt class="py-line"> <tt class="py-name">case90Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">intentResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResult</tt> <tt class="py-op">)</tt> </tt>
1899<a name="L1683"></a><tt class="py-lineno">1683</tt> <tt class="py-line"> </tt>
1900<a name="L1684"></a><tt class="py-lineno">1684</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>
1901<a name="L1685"></a><tt class="py-lineno">1685</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>
1902<a name="L1686"></a><tt class="py-lineno">1686</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case90Result</tt><tt class="py-op">,</tt> </tt>
1903<a name="L1687"></a><tt class="py-lineno">1687</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 600 point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
1904<a name="L1688"></a><tt class="py-lineno">1688</tt> <tt class="py-line"> <tt id="link-445" class="py-name"><a title="TestON.core.teston.TestON.onfail
1905TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-445', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 600 point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1906</div><a name="L1689"></a><tt class="py-lineno">1689</tt> <tt class="py-line"> </tt>
1907<a name="CHOtest.CASE91"></a><div id="CHOtest.CASE91-def"><a name="L1690"></a><tt class="py-lineno">1690</tt> <a class="py-toggle" href="#" id="CHOtest.CASE91-toggle" onclick="return toggle('CHOtest.CASE91');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE91">CASE91</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1908</div><div id="CHOtest.CASE91-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE91-expanded"><a name="L1691"></a><tt class="py-lineno">1691</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1909<a name="L1692"></a><tt class="py-lineno">1692</tt> <tt class="py-line"><tt class="py-docstring"> Install 600 point intents and verify ping all (Chordal Topology)</tt> </tt>
1910<a name="L1693"></a><tt class="py-lineno">1693</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1911<a name="L1694"></a><tt class="py-lineno">1694</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-446', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Add 600 point intents and verify pingall (Chordal Topology)"</tt> <tt class="py-op">)</tt> </tt>
1912<a name="L1695"></a><tt class="py-lineno">1695</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________________________"</tt> <tt class="py-op">)</tt> </tt>
1913<a name="L1696"></a><tt class="py-lineno">1696</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1914<a name="L1697"></a><tt class="py-lineno">1697</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
1915<a name="L1698"></a><tt class="py-lineno">1698</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-448', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install 600 point intents"</tt> <tt class="py-op">)</tt> </tt>
1916<a name="L1699"></a><tt class="py-lineno">1699</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-449" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-449', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add point Intents"</tt> <tt class="py-op">)</tt> </tt>
1917<a name="L1700"></a><tt class="py-lineno">1700</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1918<a name="L1701"></a><tt class="py-lineno">1701</tt> <tt class="py-line"> <tt class="py-name">deviceCombos</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt> <tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">permutations</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">,</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1919<a name="L1702"></a><tt class="py-lineno">1702</tt> <tt class="py-line"> </tt>
1920<a name="L1703"></a><tt class="py-lineno">1703</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1921<a name="L1704"></a><tt class="py-lineno">1704</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>
1922<a name="L1705"></a><tt class="py-lineno">1705</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">xrange</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 class="py-name">deviceCombos</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1923<a name="L1706"></a><tt class="py-lineno">1706</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1924<a name="L1707"></a><tt class="py-lineno">1707</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-450" class="py-name"><a title="TestON.bin.cli
1925TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-450', 'cli', 'link-106');">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>
1926<a name="L1708"></a><tt class="py-lineno">1708</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceCombos</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1927<a name="L1709"></a><tt class="py-lineno">1709</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
1928<a name="L1710"></a><tt class="py-lineno">1710</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-451" class="py-name"><a title="TestON.core.Thread
1929TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-451', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-452" class="py-name"><a title="TestON.bin.cli
1930TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-452', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-453" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addPointIntent
1931TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addPointIntent" class="py-name" href="#" onclick="return doclink('link-453', 'addPointIntent', 'link-437');">addPointIntent</a></tt><tt class="py-op">,</tt> </tt>
1932<a name="L1711"></a><tt class="py-lineno">1711</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
1933<a name="L1712"></a><tt class="py-lineno">1712</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addPointIntent"</tt><tt class="py-op">,</tt> </tt>
1934<a name="L1713"></a><tt class="py-lineno">1713</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">deviceCombos</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">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">deviceCombos</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 class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">,</tt><tt class="py-string">"IPV4"</tt><tt class="py-op">,</tt><tt class="py-string">""</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">deviceCombos</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 class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
1935<a name="L1714"></a><tt class="py-lineno">1714</tt> <tt class="py-line"> <tt class="py-name">pool</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>
1936<a name="L1715"></a><tt class="py-lineno">1715</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
1937<a name="L1716"></a><tt class="py-lineno">1716</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>
1938<a name="L1717"></a><tt class="py-lineno">1717</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1939<a name="L1718"></a><tt class="py-lineno">1718</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
1940<a name="L1719"></a><tt class="py-lineno">1719</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
1941<a name="L1720"></a><tt class="py-lineno">1720</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1942<a name="L1721"></a><tt class="py-lineno">1721</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
1943<a name="L1722"></a><tt class="py-lineno">1722</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>
1944<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-454" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-454', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
1945<a name="L1724"></a><tt class="py-lineno">1724</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1946<a name="L1725"></a><tt class="py-lineno">1725</tt> <tt class="py-line"> <tt class="py-name">intentsJson</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-455" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
1947TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-455', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
1948<a name="L1726"></a><tt class="py-lineno">1726</tt> <tt class="py-line"> <tt class="py-name">getIntentStateResult</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-456" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState
1949TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState" class="py-name" href="#" onclick="return doclink('link-456', 'getIntentState', 'link-249');">getIntentState</a></tt><tt class="py-op">(</tt><tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt><tt class="py-op">,</tt> </tt>
1950<a name="L1727"></a><tt class="py-lineno">1727</tt> <tt class="py-line"> <tt class="py-name">intentsJson</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsJson</tt><tt class="py-op">)</tt> </tt>
1951<a name="L1728"></a><tt class="py-lineno">1728</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">getIntentStateResult</tt> </tt>
1952<a name="L1729"></a><tt class="py-lineno">1729</tt> <tt class="py-line"> <tt class="py-comment"># Takes awhile for all the onos to get the intents</tt> </tt>
1953<a name="L1730"></a><tt class="py-lineno">1730</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>
1954<a name="L1731"></a><tt class="py-lineno">1731</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-457', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
1955<a name="L1732"></a><tt class="py-lineno">1732</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>
1956<a name="L1733"></a><tt class="py-lineno">1733</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>
1957<a name="L1734"></a><tt class="py-lineno">1734</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-458" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-458', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
1958<a name="L1735"></a><tt class="py-lineno">1735</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>
1959<a name="L1736"></a><tt class="py-lineno">1736</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
1960<a name="L1737"></a><tt class="py-lineno">1737</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
1961<a name="L1738"></a><tt class="py-lineno">1738</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
1962<a name="L1739"></a><tt class="py-lineno">1739</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
1963<a name="L1740"></a><tt class="py-lineno">1740</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
1964<a name="L1741"></a><tt class="py-lineno">1741</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">pingResult</tt><tt class="py-op">,</tt> </tt>
1965<a name="L1742"></a><tt class="py-lineno">1742</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
1966<a name="L1743"></a><tt class="py-lineno">1743</tt> <tt class="py-line"> <tt id="link-460" class="py-name"><a title="TestON.core.teston.TestON.onfail
1967TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-460', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
1968<a name="L1744"></a><tt class="py-lineno">1744</tt> <tt class="py-line"> </tt>
1969<a name="L1745"></a><tt class="py-lineno">1745</tt> <tt class="py-line"> <tt class="py-name">case91Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">intentResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResult</tt> <tt class="py-op">)</tt> </tt>
1970<a name="L1746"></a><tt class="py-lineno">1746</tt> <tt class="py-line"> </tt>
1971<a name="L1747"></a><tt class="py-lineno">1747</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>
1972<a name="L1748"></a><tt class="py-lineno">1748</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>
1973<a name="L1749"></a><tt class="py-lineno">1749</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case91Result</tt><tt class="py-op">,</tt> </tt>
1974<a name="L1750"></a><tt class="py-lineno">1750</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 600 point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
1975<a name="L1751"></a><tt class="py-lineno">1751</tt> <tt class="py-line"> <tt id="link-461" class="py-name"><a title="TestON.core.teston.TestON.onfail
1976TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-461', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 600 point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
1977</div><a name="L1752"></a><tt class="py-lineno">1752</tt> <tt class="py-line"> </tt>
1978<a name="CHOtest.CASE92"></a><div id="CHOtest.CASE92-def"><a name="L1753"></a><tt class="py-lineno">1753</tt> <a class="py-toggle" href="#" id="CHOtest.CASE92-toggle" onclick="return toggle('CHOtest.CASE92');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE92">CASE92</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1979</div><div id="CHOtest.CASE92-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE92-expanded"><a name="L1754"></a><tt class="py-lineno">1754</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
1980<a name="L1755"></a><tt class="py-lineno">1755</tt> <tt class="py-line"><tt class="py-docstring"> Install 4556 point intents and verify ping all (Spine Topology)</tt> </tt>
1981<a name="L1756"></a><tt class="py-lineno">1756</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
1982<a name="L1757"></a><tt class="py-lineno">1757</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Add 4556 point intents and verify pingall (Spine Topology)"</tt> <tt class="py-op">)</tt> </tt>
1983<a name="L1758"></a><tt class="py-lineno">1758</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_______________________________________"</tt> <tt class="py-op">)</tt> </tt>
1984<a name="L1759"></a><tt class="py-lineno">1759</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">itertools</tt> </tt>
1985<a name="L1760"></a><tt class="py-lineno">1760</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
1986<a name="L1761"></a><tt class="py-lineno">1761</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-464', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install 4556 point intents"</tt> <tt class="py-op">)</tt> </tt>
1987<a name="L1762"></a><tt class="py-lineno">1762</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-465" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-465', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Add point Intents"</tt> <tt class="py-op">)</tt> </tt>
1988<a name="L1763"></a><tt class="py-lineno">1763</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
1989<a name="L1764"></a><tt class="py-lineno">1764</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt> <tt class="py-op">=</tt> <tt class="py-number">600</tt> </tt>
1990<a name="L1765"></a><tt class="py-lineno">1765</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">hostMACs</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1991<a name="L1766"></a><tt class="py-lineno">1766</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">[</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</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-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</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">'/'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
1992<a name="L1767"></a><tt class="py-lineno">1767</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">MACsDict</tt> </tt>
1993<a name="L1768"></a><tt class="py-lineno">1768</tt> <tt class="py-line"> <tt class="py-name">deviceCombos</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt> <tt class="py-name">itertools</tt><tt class="py-op">.</tt><tt class="py-name">permutations</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</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-op">,</tt> <tt class="py-number">2</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
1994<a name="L1769"></a><tt class="py-lineno">1769</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1995<a name="L1770"></a><tt class="py-lineno">1770</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>
1996<a name="L1771"></a><tt class="py-lineno">1771</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">xrange</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 class="py-name">deviceCombos</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
1997<a name="L1772"></a><tt class="py-lineno">1772</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
1998<a name="L1773"></a><tt class="py-lineno">1773</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-466" class="py-name"><a title="TestON.bin.cli
1999TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-466', 'cli', 'link-106');">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>
2000<a name="L1774"></a><tt class="py-lineno">1774</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceCombos</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2001<a name="L1775"></a><tt class="py-lineno">1775</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2002<a name="L1776"></a><tt class="py-lineno">1776</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
2003TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-467', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-468" class="py-name"><a title="TestON.bin.cli
2004TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-468', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-469" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.addPointIntent
2005TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addPointIntent" class="py-name" href="#" onclick="return doclink('link-469', 'addPointIntent', 'link-437');">addPointIntent</a></tt><tt class="py-op">,</tt> </tt>
2006<a name="L1777"></a><tt class="py-lineno">1777</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2007<a name="L1778"></a><tt class="py-lineno">1778</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addPointIntent"</tt><tt class="py-op">,</tt> </tt>
2008<a name="L1779"></a><tt class="py-lineno">1779</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">deviceCombos</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">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">deviceCombos</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 class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">,</tt><tt class="py-string">"IPV4"</tt><tt class="py-op">,</tt><tt class="py-string">""</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">deviceCombos</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 class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2009<a name="L1780"></a><tt class="py-lineno">1780</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2010<a name="L1781"></a><tt class="py-lineno">1781</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
2011<a name="L1782"></a><tt class="py-lineno">1782</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>
2012<a name="L1783"></a><tt class="py-lineno">1783</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2013<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 class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2014<a name="L1785"></a><tt class="py-lineno">1785</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2015<a name="L1786"></a><tt class="py-lineno">1786</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2016<a name="L1787"></a><tt class="py-lineno">1787</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2017<a name="L1788"></a><tt class="py-lineno">1788</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>
2018<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-470" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-470', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2019<a name="L1790"></a><tt class="py-lineno">1790</tt> <tt class="py-line"> <tt class="py-name">intentResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2020<a name="L1791"></a><tt class="py-lineno">1791</tt> <tt class="py-line"> <tt class="py-name">intentsJson</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-471" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
2021TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-471', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2022<a name="L1792"></a><tt class="py-lineno">1792</tt> <tt class="py-line"> <tt class="py-name">getIntentStateResult</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-472" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.getIntentState
2023TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getIntentState" class="py-name" href="#" onclick="return doclink('link-472', 'getIntentState', 'link-249');">getIntentState</a></tt><tt class="py-op">(</tt><tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt><tt class="py-op">,</tt> </tt>
2024<a name="L1793"></a><tt class="py-lineno">1793</tt> <tt class="py-line"> <tt class="py-name">intentsJson</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsJson</tt><tt class="py-op">)</tt> </tt>
2025<a name="L1794"></a><tt class="py-lineno">1794</tt> <tt class="py-line"> <tt class="py-comment">#print getIntentStateResult</tt> </tt>
2026<a name="L1795"></a><tt class="py-lineno">1795</tt> <tt class="py-line"> <tt class="py-comment"># Takes awhile for all the onos to get the intents</tt> </tt>
2027<a name="L1796"></a><tt class="py-lineno">1796</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>
2028<a name="L1797"></a><tt class="py-lineno">1797</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-473', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
2029<a name="L1798"></a><tt class="py-lineno">1798</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>
2030<a name="L1799"></a><tt class="py-lineno">1799</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>
2031<a name="L1800"></a><tt class="py-lineno">1800</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-474" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-474', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
2032<a name="L1801"></a><tt class="py-lineno">1801</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>
2033<a name="L1802"></a><tt class="py-lineno">1802</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2034<a name="L1803"></a><tt class="py-lineno">1803</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-475" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-475', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2035<a name="L1804"></a><tt class="py-lineno">1804</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2036<a name="L1805"></a><tt class="py-lineno">1805</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2037<a name="L1806"></a><tt class="py-lineno">1806</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2038<a name="L1807"></a><tt class="py-lineno">1807</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">pingResult</tt><tt class="py-op">,</tt> </tt>
2039<a name="L1808"></a><tt class="py-lineno">1808</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL PASS"</tt><tt class="py-op">,</tt> </tt>
2040<a name="L1809"></a><tt class="py-lineno">1809</tt> <tt class="py-line"> <tt id="link-476" class="py-name"><a title="TestON.core.teston.TestON.onfail
2041TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-476', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"PING ALL FAIL"</tt> <tt class="py-op">)</tt> </tt>
2042<a name="L1810"></a><tt class="py-lineno">1810</tt> <tt class="py-line"> </tt>
2043<a name="L1811"></a><tt class="py-lineno">1811</tt> <tt class="py-line"> <tt class="py-name">case92Result</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">intentResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">pingResult</tt> <tt class="py-op">)</tt> </tt>
2044<a name="L1812"></a><tt class="py-lineno">1812</tt> <tt class="py-line"> </tt>
2045<a name="L1813"></a><tt class="py-lineno">1813</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>
2046<a name="L1814"></a><tt class="py-lineno">1814</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>
2047<a name="L1815"></a><tt class="py-lineno">1815</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case92Result</tt><tt class="py-op">,</tt> </tt>
2048<a name="L1816"></a><tt class="py-lineno">1816</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 4556 point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
2049<a name="L1817"></a><tt class="py-lineno">1817</tt> <tt class="py-line"> <tt id="link-477" class="py-name"><a title="TestON.core.teston.TestON.onfail
2050TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-477', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 4556 point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2051</div><a name="L1818"></a><tt class="py-lineno">1818</tt> <tt class="py-line"> </tt>
2052<a name="CHOtest.CASE93"></a><div id="CHOtest.CASE93-def"><a name="L1819"></a><tt class="py-lineno">1819</tt> <a class="py-toggle" href="#" id="CHOtest.CASE93-toggle" onclick="return toggle('CHOtest.CASE93');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE93">CASE93</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2053</div><div id="CHOtest.CASE93-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE93-expanded"><a name="L1820"></a><tt class="py-lineno">1820</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
2054<a name="L1821"></a><tt class="py-lineno">1821</tt> <tt class="py-line"><tt class="py-docstring"> Install multi-single point intents and verify Ping all works</tt> </tt>
2055<a name="L1822"></a><tt class="py-lineno">1822</tt> <tt class="py-line"><tt class="py-docstring"> for att topology</tt> </tt>
2056<a name="L1823"></a><tt class="py-lineno">1823</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
2057<a name="L1824"></a><tt class="py-lineno">1824</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
2058<a name="L1825"></a><tt class="py-lineno">1825</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
2059<a name="L1826"></a><tt class="py-lineno">1826</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-478" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-478', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Install multi-single point intents and verify Ping all"</tt> <tt class="py-op">)</tt> </tt>
2060<a name="L1827"></a><tt class="py-lineno">1827</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2061<a name="L1828"></a><tt class="py-lineno">1828</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.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-480', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install multi-single point intents and Ping all"</tt> <tt class="py-op">)</tt> </tt>
2062<a name="L1829"></a><tt class="py-lineno">1829</tt> <tt class="py-line"> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">)</tt> </tt>
2063<a name="L1830"></a><tt class="py-lineno">1830</tt> <tt class="py-line"> <tt class="py-name">portIngressList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'1'</tt><tt class="py-op">]</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">deviceDPIDsCopy</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
2064<a name="L1831"></a><tt class="py-lineno">1831</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2065<a name="L1832"></a><tt class="py-lineno">1832</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"MACsDict"</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt> </tt>
2066<a name="L1833"></a><tt class="py-lineno">1833</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>
2067<a name="L1834"></a><tt class="py-lineno">1834</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">xrange</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 class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2068<a name="L1835"></a><tt class="py-lineno">1835</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2069<a name="L1836"></a><tt class="py-lineno">1836</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-481" class="py-name"><a title="TestON.bin.cli
2070TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-481', 'cli', 'link-106');">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>
2071<a name="L1837"></a><tt class="py-lineno">1837</tt> <tt class="py-line"> <tt class="py-name">egressDevice</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
2072<a name="L1838"></a><tt class="py-lineno">1838</tt> <tt class="py-line"> <tt class="py-name">ingressDeviceList</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</tt> </tt>
2073<a name="L1839"></a><tt class="py-lineno">1839</tt> <tt class="py-line"> <tt class="py-name">ingressDeviceList</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt><tt class="py-name">egressDevice</tt><tt class="py-op">)</tt> </tt>
2074<a name="L1840"></a><tt class="py-lineno">1840</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2075<a name="L1841"></a><tt class="py-lineno">1841</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2076<a name="L1842"></a><tt class="py-lineno">1842</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-482" class="py-name"><a title="TestON.core.Thread
2077TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-482', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-483" class="py-name"><a title="TestON.bin.cli
2078TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-483', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-484" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addMultipointToSinglepointIntent()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#addMultipointToSinglepointIntent"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addMultipointToSinglepointIntent" class="py-name" href="#" onclick="return doclink('link-484', 'addMultipointToSinglepointIntent', 'link-484');">addMultipointToSinglepointIntent</a></tt><tt class="py-op">,</tt> </tt>
2079<a name="L1843"></a><tt class="py-lineno">1843</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2080<a name="L1844"></a><tt class="py-lineno">1844</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addMultipointToSinglepointIntent"</tt><tt class="py-op">,</tt> </tt>
2081<a name="L1845"></a><tt class="py-lineno">1845</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">ingressDeviceList</tt><tt class="py-op">,</tt><tt class="py-name">egressDevice</tt><tt class="py-op">,</tt><tt class="py-name">portIngressList</tt><tt class="py-op">,</tt><tt class="py-string">'1'</tt><tt class="py-op">,</tt><tt class="py-string">'IPV4'</tt><tt class="py-op">,</tt><tt class="py-string">''</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">egressDevice</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2082<a name="L1846"></a><tt class="py-lineno">1846</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2083<a name="L1847"></a><tt class="py-lineno">1847</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
2084<a name="L1848"></a><tt class="py-lineno">1848</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>
2085<a name="L1849"></a><tt class="py-lineno">1849</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2086<a name="L1850"></a><tt class="py-lineno">1850</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2087<a name="L1851"></a><tt class="py-lineno">1851</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2088<a name="L1852"></a><tt class="py-lineno">1852</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2089<a name="L1853"></a><tt class="py-lineno">1853</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2090<a name="L1854"></a><tt class="py-lineno">1854</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>
2091<a name="L1855"></a><tt class="py-lineno">1855</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-485" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-485', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2092<a name="L1856"></a><tt class="py-lineno">1856</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>
2093<a name="L1857"></a><tt class="py-lineno">1857</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"getting all intents ID"</tt> </tt>
2094<a name="L1858"></a><tt class="py-lineno">1858</tt> <tt class="py-line"> <tt class="py-name">intentIdTemp</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-486" 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-486', 'getAllIntentsId', 'link-486');">getAllIntentsId</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2095<a name="L1859"></a><tt class="py-lineno">1859</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">intentIdTemp</tt> </tt>
2096<a name="L1860"></a><tt class="py-lineno">1860</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">intentIdList</tt><tt class="py-op">)</tt> </tt>
2097<a name="L1861"></a><tt class="py-lineno">1861</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">intentIdList</tt> </tt>
2098<a name="L1862"></a><tt class="py-lineno">1862</tt> <tt class="py-line"> <tt class="py-name">checkIntentStateResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2099<a name="L1863"></a><tt class="py-lineno">1863</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Checking intents state"</tt> </tt>
2100<a name="L1864"></a><tt class="py-lineno">1864</tt> <tt class="py-line"> <tt class="py-name">checkIntentStateResult</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-487" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkIntentState()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#checkIntentState,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkIntentState()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#checkIntentState"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkIntentState
2101TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkIntentState" class="py-name" href="#" onclick="return doclink('link-487', 'checkIntentState', 'link-487');">checkIntentState</a></tt><tt class="py-op">(</tt> <tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt> <tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">checkIntentStateResult</tt> </tt>
2102<a name="L1865"></a><tt class="py-lineno">1865</tt> <tt class="py-line"> <tt class="py-name">checkIntentStateResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli2</tt><tt class="py-op">.</tt><tt id="link-488" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkIntentState
2103TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkIntentState" class="py-name" href="#" onclick="return doclink('link-488', 'checkIntentState', 'link-487');">checkIntentState</a></tt><tt class="py-op">(</tt> <tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt> <tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">checkIntentStateResult</tt> </tt>
2104<a name="L1866"></a><tt class="py-lineno">1866</tt> <tt class="py-line"> <tt class="py-name">checkIntentStateResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli3</tt><tt class="py-op">.</tt><tt id="link-489" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkIntentState
2105TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkIntentState" class="py-name" href="#" onclick="return doclink('link-489', 'checkIntentState', 'link-487');">checkIntentState</a></tt><tt class="py-op">(</tt> <tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt> <tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">checkIntentStateResult</tt> </tt>
2106<a name="L1867"></a><tt class="py-lineno">1867</tt> <tt class="py-line"> <tt class="py-name">checkIntentStateResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli4</tt><tt class="py-op">.</tt><tt id="link-490" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkIntentState
2107TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkIntentState" class="py-name" href="#" onclick="return doclink('link-490', 'checkIntentState', 'link-487');">checkIntentState</a></tt><tt class="py-op">(</tt> <tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt> <tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">checkIntentStateResult</tt> </tt>
2108<a name="L1868"></a><tt class="py-lineno">1868</tt> <tt class="py-line"> <tt class="py-name">checkIntentStateResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli5</tt><tt class="py-op">.</tt><tt id="link-491" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkIntentState
2109TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkIntentState" class="py-name" href="#" onclick="return doclink('link-491', 'checkIntentState', 'link-487');">checkIntentState</a></tt><tt class="py-op">(</tt> <tt class="py-name">intentsId</tt> <tt class="py-op">=</tt> <tt class="py-name">intentIdList</tt> <tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">checkIntentStateResult</tt> </tt>
2110<a name="L1869"></a><tt class="py-lineno">1869</tt> <tt class="py-line"> </tt>
2111<a name="L1870"></a><tt class="py-lineno">1870</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">checkIntentStateResult</tt><tt class="py-op">:</tt> </tt>
2112<a name="L1871"></a><tt class="py-lineno">1871</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-492" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-492', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"All intents are installed correctly "</tt> <tt class="py-op">)</tt> </tt>
2113<a name="L1872"></a><tt class="py-lineno">1872</tt> <tt class="py-line"> </tt>
2114<a name="L1873"></a><tt class="py-lineno">1873</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Checking flows state "</tt> </tt>
2115<a name="L1874"></a><tt class="py-lineno">1874</tt> <tt class="py-line"> <tt id="link-493" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkFlowsState()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#checkFlowsState,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkFlowsState()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#checkFlowsState"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkFlowsState
2116TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkFlowsState" class="py-name" href="#" onclick="return doclink('link-493', 'checkFlowsState', 'link-493');">checkFlowsState</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-494" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkFlowsState
2117TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkFlowsState" class="py-name" href="#" onclick="return doclink('link-494', 'checkFlowsState', 'link-493');">checkFlowsState</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2118<a name="L1875"></a><tt class="py-lineno">1875</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">50</tt><tt class="py-op">)</tt> </tt>
2119<a name="L1876"></a><tt class="py-lineno">1876</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-495" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-495', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
2120<a name="L1877"></a><tt class="py-lineno">1877</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>
2121<a name="L1878"></a><tt class="py-lineno">1878</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>
2122<a name="L1879"></a><tt class="py-lineno">1879</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-496" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-496', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
2123<a name="L1880"></a><tt class="py-lineno">1880</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>
2124<a name="L1881"></a><tt class="py-lineno">1881</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2125<a name="L1882"></a><tt class="py-lineno">1882</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-497" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-497', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2126<a name="L1883"></a><tt class="py-lineno">1883</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2127<a name="L1884"></a><tt class="py-lineno">1884</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2128<a name="L1885"></a><tt class="py-lineno">1885</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2129<a name="L1886"></a><tt class="py-lineno">1886</tt> <tt class="py-line"> <tt id="link-498" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkFlowsState
2130TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkFlowsState" class="py-name" href="#" onclick="return doclink('link-498', 'checkFlowsState', 'link-493');">checkFlowsState</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-499" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.checkFlowsState
2131TestON.drivers.common.cli.onosclidriver.OnosCliDriver.checkFlowsState" class="py-name" href="#" onclick="return doclink('link-499', 'checkFlowsState', 'link-493');">checkFlowsState</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2132<a name="L1887"></a><tt class="py-lineno">1887</tt> <tt class="py-line"> <tt class="py-name">case93Result</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResult</tt> </tt>
2133<a name="L1888"></a><tt class="py-lineno">1888</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>
2134<a name="L1889"></a><tt class="py-lineno">1889</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>
2135<a name="L1890"></a><tt class="py-lineno">1890</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case93Result</tt><tt class="py-op">,</tt> </tt>
2136<a name="L1891"></a><tt class="py-lineno">1891</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 multi to single point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
2137<a name="L1892"></a><tt class="py-lineno">1892</tt> <tt class="py-line"> <tt id="link-500" class="py-name"><a title="TestON.core.teston.TestON.onfail
2138TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-500', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 multi to single point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2139</div><a name="L1893"></a><tt class="py-lineno">1893</tt> <tt class="py-line"> </tt>
2140<a name="CHOtest.CASE94"></a><div id="CHOtest.CASE94-def"><a name="L1894"></a><tt class="py-lineno">1894</tt> <a class="py-toggle" href="#" id="CHOtest.CASE94-toggle" onclick="return toggle('CHOtest.CASE94');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE94">CASE94</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2141</div><div id="CHOtest.CASE94-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE94-expanded"><a name="L1895"></a><tt class="py-lineno">1895</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
2142<a name="L1896"></a><tt class="py-lineno">1896</tt> <tt class="py-line"><tt class="py-docstring"> Install multi-single point intents and verify Ping all works</tt> </tt>
2143<a name="L1897"></a><tt class="py-lineno">1897</tt> <tt class="py-line"><tt class="py-docstring"> for Chordal topology</tt> </tt>
2144<a name="L1898"></a><tt class="py-lineno">1898</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
2145<a name="L1899"></a><tt class="py-lineno">1899</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
2146<a name="L1900"></a><tt class="py-lineno">1900</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
2147<a name="L1901"></a><tt class="py-lineno">1901</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-501" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-501', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Install multi-single point intents and verify Ping all"</tt> <tt class="py-op">)</tt> </tt>
2148<a name="L1902"></a><tt class="py-lineno">1902</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-502" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-502', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2149<a name="L1903"></a><tt class="py-lineno">1903</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-503" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-503', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install multi-single point intents and Ping all"</tt> <tt class="py-op">)</tt> </tt>
2150<a name="L1904"></a><tt class="py-lineno">1904</tt> <tt class="py-line"> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">)</tt> </tt>
2151<a name="L1905"></a><tt class="py-lineno">1905</tt> <tt class="py-line"> <tt class="py-name">portIngressList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'1'</tt><tt class="py-op">]</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">deviceDPIDsCopy</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
2152<a name="L1906"></a><tt class="py-lineno">1906</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2153<a name="L1907"></a><tt class="py-lineno">1907</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"MACsDict"</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt> </tt>
2154<a name="L1908"></a><tt class="py-lineno">1908</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>
2155<a name="L1909"></a><tt class="py-lineno">1909</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">xrange</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 class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2156<a name="L1910"></a><tt class="py-lineno">1910</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2157<a name="L1911"></a><tt class="py-lineno">1911</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-504" class="py-name"><a title="TestON.bin.cli
2158TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-504', 'cli', 'link-106');">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>
2159<a name="L1912"></a><tt class="py-lineno">1912</tt> <tt class="py-line"> <tt class="py-name">egressDevice</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
2160<a name="L1913"></a><tt class="py-lineno">1913</tt> <tt class="py-line"> <tt class="py-name">ingressDeviceList</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</tt> </tt>
2161<a name="L1914"></a><tt class="py-lineno">1914</tt> <tt class="py-line"> <tt class="py-name">ingressDeviceList</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt><tt class="py-name">egressDevice</tt><tt class="py-op">)</tt> </tt>
2162<a name="L1915"></a><tt class="py-lineno">1915</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2163<a name="L1916"></a><tt class="py-lineno">1916</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2164<a name="L1917"></a><tt class="py-lineno">1917</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
2165TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-505', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-506" class="py-name"><a title="TestON.bin.cli
2166TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-506', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-507" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addMultipointToSinglepointIntent" class="py-name" href="#" onclick="return doclink('link-507', 'addMultipointToSinglepointIntent', 'link-484');">addMultipointToSinglepointIntent</a></tt><tt class="py-op">,</tt> </tt>
2167<a name="L1918"></a><tt class="py-lineno">1918</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2168<a name="L1919"></a><tt class="py-lineno">1919</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addMultipointToSinglepointIntent"</tt><tt class="py-op">,</tt> </tt>
2169<a name="L1920"></a><tt class="py-lineno">1920</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">ingressDeviceList</tt><tt class="py-op">,</tt><tt class="py-name">egressDevice</tt><tt class="py-op">,</tt><tt class="py-name">portIngressList</tt><tt class="py-op">,</tt><tt class="py-string">'1'</tt><tt class="py-op">,</tt><tt class="py-string">'IPV4'</tt><tt class="py-op">,</tt><tt class="py-string">''</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">egressDevice</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2170<a name="L1921"></a><tt class="py-lineno">1921</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2171<a name="L1922"></a><tt class="py-lineno">1922</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
2172<a name="L1923"></a><tt class="py-lineno">1923</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>
2173<a name="L1924"></a><tt class="py-lineno">1924</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2174<a name="L1925"></a><tt class="py-lineno">1925</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2175<a name="L1926"></a><tt class="py-lineno">1926</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2176<a name="L1927"></a><tt class="py-lineno">1927</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2177<a name="L1928"></a><tt class="py-lineno">1928</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2178<a name="L1929"></a><tt class="py-lineno">1929</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>
2179<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-508" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-508', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2180<a name="L1931"></a><tt class="py-lineno">1931</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>
2181<a name="L1932"></a><tt class="py-lineno">1932</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-509" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-509', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
2182<a name="L1933"></a><tt class="py-lineno">1933</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>
2183<a name="L1934"></a><tt class="py-lineno">1934</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>
2184<a name="L1935"></a><tt class="py-lineno">1935</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-510" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-510', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
2185<a name="L1936"></a><tt class="py-lineno">1936</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>
2186<a name="L1937"></a><tt class="py-lineno">1937</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2187<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-511" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-511', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2188<a name="L1939"></a><tt class="py-lineno">1939</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2189<a name="L1940"></a><tt class="py-lineno">1940</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2190<a name="L1941"></a><tt class="py-lineno">1941</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2191<a name="L1942"></a><tt class="py-lineno">1942</tt> <tt class="py-line"> </tt>
2192<a name="L1943"></a><tt class="py-lineno">1943</tt> <tt class="py-line"> <tt class="py-name">case94Result</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResult</tt> </tt>
2193<a name="L1944"></a><tt class="py-lineno">1944</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>
2194<a name="L1945"></a><tt class="py-lineno">1945</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>
2195<a name="L1946"></a><tt class="py-lineno">1946</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case94Result</tt><tt class="py-op">,</tt> </tt>
2196<a name="L1947"></a><tt class="py-lineno">1947</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 multi to single point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
2197<a name="L1948"></a><tt class="py-lineno">1948</tt> <tt class="py-line"> <tt id="link-512" class="py-name"><a title="TestON.core.teston.TestON.onfail
2198TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-512', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 multi to single point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2199</div><a name="L1949"></a><tt class="py-lineno">1949</tt> <tt class="py-line"> </tt>
2200<a name="L1950"></a><tt class="py-lineno">1950</tt> <tt class="py-line"> <tt class="py-comment">#def CASE95 multi-single point intent for Spine</tt> </tt>
2201<a name="L1951"></a><tt class="py-lineno">1951</tt> <tt class="py-line"> </tt>
2202<a name="CHOtest.CASE96"></a><div id="CHOtest.CASE96-def"><a name="L1952"></a><tt class="py-lineno">1952</tt> <a class="py-toggle" href="#" id="CHOtest.CASE96-toggle" onclick="return toggle('CHOtest.CASE96');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE96">CASE96</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2203</div><div id="CHOtest.CASE96-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE96-expanded"><a name="L1953"></a><tt class="py-lineno">1953</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
2204<a name="L1954"></a><tt class="py-lineno">1954</tt> <tt class="py-line"><tt class="py-docstring"> Install single-multi point intents and verify Ping all works</tt> </tt>
2205<a name="L1955"></a><tt class="py-lineno">1955</tt> <tt class="py-line"><tt class="py-docstring"> for att topology</tt> </tt>
2206<a name="L1956"></a><tt class="py-lineno">1956</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
2207<a name="L1957"></a><tt class="py-lineno">1957</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
2208<a name="L1958"></a><tt class="py-lineno">1958</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-513" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-513', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Install single-multi point intents and verify Ping all"</tt> <tt class="py-op">)</tt> </tt>
2209<a name="L1959"></a><tt class="py-lineno">1959</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-514" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-514', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2210<a name="L1960"></a><tt class="py-lineno">1960</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-515" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-515', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install single-multi point intents and Ping all"</tt> <tt class="py-op">)</tt> </tt>
2211<a name="L1961"></a><tt class="py-lineno">1961</tt> <tt class="py-line"> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">)</tt> </tt>
2212<a name="L1962"></a><tt class="py-lineno">1962</tt> <tt class="py-line"> <tt class="py-name">portEgressList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'1'</tt><tt class="py-op">]</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">deviceDPIDsCopy</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
2213<a name="L1963"></a><tt class="py-lineno">1963</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2214<a name="L1964"></a><tt class="py-lineno">1964</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"MACsDict"</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt> </tt>
2215<a name="L1965"></a><tt class="py-lineno">1965</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>
2216<a name="L1966"></a><tt class="py-lineno">1966</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">xrange</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 class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2217<a name="L1967"></a><tt class="py-lineno">1967</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2218<a name="L1968"></a><tt class="py-lineno">1968</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-516" class="py-name"><a title="TestON.bin.cli
2219TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-516', 'cli', 'link-106');">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>
2220<a name="L1969"></a><tt class="py-lineno">1969</tt> <tt class="py-line"> <tt class="py-name">ingressDevice</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
2221<a name="L1970"></a><tt class="py-lineno">1970</tt> <tt class="py-line"> <tt class="py-name">egressDeviceList</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</tt> </tt>
2222<a name="L1971"></a><tt class="py-lineno">1971</tt> <tt class="py-line"> <tt class="py-name">egressDeviceList</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt><tt class="py-name">ingressDevice</tt><tt class="py-op">)</tt> </tt>
2223<a name="L1972"></a><tt class="py-lineno">1972</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2224<a name="L1973"></a><tt class="py-lineno">1973</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2225<a name="L1974"></a><tt class="py-lineno">1974</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-517" class="py-name"><a title="TestON.core.Thread
2226TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-517', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-518" class="py-name"><a title="TestON.bin.cli
2227TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-518', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-519" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addSinglepointToMultipointIntent()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#addSinglepointToMultipointIntent"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addSinglepointToMultipointIntent" class="py-name" href="#" onclick="return doclink('link-519', 'addSinglepointToMultipointIntent', 'link-519');">addSinglepointToMultipointIntent</a></tt><tt class="py-op">,</tt> </tt>
2228<a name="L1975"></a><tt class="py-lineno">1975</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2229<a name="L1976"></a><tt class="py-lineno">1976</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addSinglepointToMultipointIntent"</tt><tt class="py-op">,</tt> </tt>
2230<a name="L1977"></a><tt class="py-lineno">1977</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">ingressDevice</tt><tt class="py-op">,</tt><tt class="py-name">egressDeviceList</tt><tt class="py-op">,</tt><tt class="py-string">'1'</tt><tt class="py-op">,</tt><tt class="py-name">portEgressList</tt><tt class="py-op">,</tt><tt class="py-string">'IPV4'</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">ingressDevice</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2231<a name="L1978"></a><tt class="py-lineno">1978</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2232<a name="L1979"></a><tt class="py-lineno">1979</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
2233<a name="L1980"></a><tt class="py-lineno">1980</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>
2234<a name="L1981"></a><tt class="py-lineno">1981</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2235<a name="L1982"></a><tt class="py-lineno">1982</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2236<a name="L1983"></a><tt class="py-lineno">1983</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2237<a name="L1984"></a><tt class="py-lineno">1984</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2238<a name="L1985"></a><tt class="py-lineno">1985</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2239<a name="L1986"></a><tt class="py-lineno">1986</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>
2240<a name="L1987"></a><tt class="py-lineno">1987</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-520" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-520', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2241<a name="L1988"></a><tt class="py-lineno">1988</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>
2242<a name="L1989"></a><tt class="py-lineno">1989</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-521" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-521', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
2243<a name="L1990"></a><tt class="py-lineno">1990</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>
2244<a name="L1991"></a><tt class="py-lineno">1991</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>
2245<a name="L1992"></a><tt class="py-lineno">1992</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-522" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-522', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
2246<a name="L1993"></a><tt class="py-lineno">1993</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>
2247<a name="L1994"></a><tt class="py-lineno">1994</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2248<a name="L1995"></a><tt class="py-lineno">1995</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-523" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-523', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2249<a name="L1996"></a><tt class="py-lineno">1996</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2250<a name="L1997"></a><tt class="py-lineno">1997</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2251<a name="L1998"></a><tt class="py-lineno">1998</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2252<a name="L1999"></a><tt class="py-lineno">1999</tt> <tt class="py-line"> </tt>
2253<a name="L2000"></a><tt class="py-lineno">2000</tt> <tt class="py-line"> <tt class="py-name">case96Result</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResult</tt> </tt>
2254<a name="L2001"></a><tt class="py-lineno">2001</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>
2255<a name="L2002"></a><tt class="py-lineno">2002</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>
2256<a name="L2003"></a><tt class="py-lineno">2003</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case96Result</tt><tt class="py-op">,</tt> </tt>
2257<a name="L2004"></a><tt class="py-lineno">2004</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 single to multi point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
2258<a name="L2005"></a><tt class="py-lineno">2005</tt> <tt class="py-line"> <tt id="link-524" class="py-name"><a title="TestON.core.teston.TestON.onfail
2259TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-524', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 single to multi point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2260</div><a name="L2006"></a><tt class="py-lineno">2006</tt> <tt class="py-line"> </tt>
2261<a name="CHOtest.CASE97"></a><div id="CHOtest.CASE97-def"><a name="L2007"></a><tt class="py-lineno">2007</tt> <a class="py-toggle" href="#" id="CHOtest.CASE97-toggle" onclick="return toggle('CHOtest.CASE97');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE97">CASE97</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2262</div><div id="CHOtest.CASE97-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE97-expanded"><a name="L2008"></a><tt class="py-lineno">2008</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
2263<a name="L2009"></a><tt class="py-lineno">2009</tt> <tt class="py-line"><tt class="py-docstring"> Install single-multi point intents and verify Ping all works</tt> </tt>
2264<a name="L2010"></a><tt class="py-lineno">2010</tt> <tt class="py-line"><tt class="py-docstring"> for Chordal topology</tt> </tt>
2265<a name="L2011"></a><tt class="py-lineno">2011</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
2266<a name="L2012"></a><tt class="py-lineno">2012</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
2267<a name="L2013"></a><tt class="py-lineno">2013</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-525" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-525', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Install single-multi point intents and verify Ping all"</tt> <tt class="py-op">)</tt> </tt>
2268<a name="L2014"></a><tt class="py-lineno">2014</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-526" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-526', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2269<a name="L2015"></a><tt class="py-lineno">2015</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-527" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-527', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install single-multi point intents and Ping all"</tt> <tt class="py-op">)</tt> </tt>
2270<a name="L2016"></a><tt class="py-lineno">2016</tt> <tt class="py-line"> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt><tt class="py-op">)</tt> </tt>
2271<a name="L2017"></a><tt class="py-lineno">2017</tt> <tt class="py-line"> <tt class="py-name">portEgressList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'1'</tt><tt class="py-op">]</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">deviceDPIDsCopy</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
2272<a name="L2018"></a><tt class="py-lineno">2018</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2273<a name="L2019"></a><tt class="py-lineno">2019</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"MACsDict"</tt><tt class="py-op">,</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt> </tt>
2274<a name="L2020"></a><tt class="py-lineno">2020</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>
2275<a name="L2021"></a><tt class="py-lineno">2021</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">xrange</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 class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2276<a name="L2022"></a><tt class="py-lineno">2022</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2277<a name="L2023"></a><tt class="py-lineno">2023</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-528" class="py-name"><a title="TestON.bin.cli
2278TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-528', 'cli', 'link-106');">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>
2279<a name="L2024"></a><tt class="py-lineno">2024</tt> <tt class="py-line"> <tt class="py-name">ingressDevice</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
2280<a name="L2025"></a><tt class="py-lineno">2025</tt> <tt class="py-line"> <tt class="py-name">egressDeviceList</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</tt> </tt>
2281<a name="L2026"></a><tt class="py-lineno">2026</tt> <tt class="py-line"> <tt class="py-name">egressDeviceList</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt><tt class="py-name">ingressDevice</tt><tt class="py-op">)</tt> </tt>
2282<a name="L2027"></a><tt class="py-lineno">2027</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2283<a name="L2028"></a><tt class="py-lineno">2028</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2284<a name="L2029"></a><tt class="py-lineno">2029</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-529" class="py-name"><a title="TestON.core.Thread
2285TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-529', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-530" class="py-name"><a title="TestON.bin.cli
2286TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-530', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-531" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addSinglepointToMultipointIntent" class="py-name" href="#" onclick="return doclink('link-531', 'addSinglepointToMultipointIntent', 'link-519');">addSinglepointToMultipointIntent</a></tt><tt class="py-op">,</tt> </tt>
2287<a name="L2030"></a><tt class="py-lineno">2030</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2288<a name="L2031"></a><tt class="py-lineno">2031</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addSinglepointToMultipointIntent"</tt><tt class="py-op">,</tt> </tt>
2289<a name="L2032"></a><tt class="py-lineno">2032</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">ingressDevice</tt><tt class="py-op">,</tt><tt class="py-name">egressDeviceList</tt><tt class="py-op">,</tt><tt class="py-string">'1'</tt><tt class="py-op">,</tt><tt class="py-name">portEgressList</tt><tt class="py-op">,</tt><tt class="py-string">'IPV4'</tt><tt class="py-op">,</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">MACsDict</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">ingressDevice</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-string">''</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2290<a name="L2033"></a><tt class="py-lineno">2033</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2291<a name="L2034"></a><tt class="py-lineno">2034</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
2292<a name="L2035"></a><tt class="py-lineno">2035</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>
2293<a name="L2036"></a><tt class="py-lineno">2036</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2294<a name="L2037"></a><tt class="py-lineno">2037</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2295<a name="L2038"></a><tt class="py-lineno">2038</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2296<a name="L2039"></a><tt class="py-lineno">2039</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2297<a name="L2040"></a><tt class="py-lineno">2040</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2298<a name="L2041"></a><tt class="py-lineno">2041</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>
2299<a name="L2042"></a><tt class="py-lineno">2042</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-532" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-532', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2300<a name="L2043"></a><tt class="py-lineno">2043</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>
2301<a name="L2044"></a><tt class="py-lineno">2044</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.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-533', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
2302<a name="L2045"></a><tt class="py-lineno">2045</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>
2303<a name="L2046"></a><tt class="py-lineno">2046</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>
2304<a name="L2047"></a><tt class="py-lineno">2047</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-534" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-534', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
2305<a name="L2048"></a><tt class="py-lineno">2048</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>
2306<a name="L2049"></a><tt class="py-lineno">2049</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2307<a name="L2050"></a><tt class="py-lineno">2050</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-535" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-535', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2308<a name="L2051"></a><tt class="py-lineno">2051</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2309<a name="L2052"></a><tt class="py-lineno">2052</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2310<a name="L2053"></a><tt class="py-lineno">2053</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2311<a name="L2054"></a><tt class="py-lineno">2054</tt> <tt class="py-line"> </tt>
2312<a name="L2055"></a><tt class="py-lineno">2055</tt> <tt class="py-line"> <tt class="py-name">case97Result</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResult</tt> </tt>
2313<a name="L2056"></a><tt class="py-lineno">2056</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>
2314<a name="L2057"></a><tt class="py-lineno">2057</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>
2315<a name="L2058"></a><tt class="py-lineno">2058</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case97Result</tt><tt class="py-op">,</tt> </tt>
2316<a name="L2059"></a><tt class="py-lineno">2059</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 single to multi point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
2317<a name="L2060"></a><tt class="py-lineno">2060</tt> <tt class="py-line"> <tt id="link-536" class="py-name"><a title="TestON.core.teston.TestON.onfail
2318TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-536', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 single to multi point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2319</div><a name="L2061"></a><tt class="py-lineno">2061</tt> <tt class="py-line"> </tt>
2320<a name="CHOtest.CASE98"></a><div id="CHOtest.CASE98-def"><a name="L2062"></a><tt class="py-lineno">2062</tt> <a class="py-toggle" href="#" id="CHOtest.CASE98-toggle" onclick="return toggle('CHOtest.CASE98');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE98">CASE98</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2321</div><div id="CHOtest.CASE98-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE98-expanded"><a name="L2063"></a><tt class="py-lineno">2063</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
2322<a name="L2064"></a><tt class="py-lineno">2064</tt> <tt class="py-line"><tt class="py-docstring"> Install single-multi point intents and verify Ping all works</tt> </tt>
2323<a name="L2065"></a><tt class="py-lineno">2065</tt> <tt class="py-line"><tt class="py-docstring"> for Spine topology</tt> </tt>
2324<a name="L2066"></a><tt class="py-lineno">2066</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
2325<a name="L2067"></a><tt class="py-lineno">2067</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
2326<a name="L2068"></a><tt class="py-lineno">2068</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-537" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-537', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Install single-multi point intents and verify Ping all"</tt> <tt class="py-op">)</tt> </tt>
2327<a name="L2069"></a><tt class="py-lineno">2069</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"___________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2328<a name="L2070"></a><tt class="py-lineno">2070</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-539" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-539', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Install single-multi point intents and Ping all"</tt> <tt class="py-op">)</tt> </tt>
2329<a name="L2071"></a><tt class="py-lineno">2071</tt> <tt class="py-line"> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">deviceDPIDs</tt> <tt class="py-op">)</tt> </tt>
2330<a name="L2072"></a><tt class="py-lineno">2072</tt> <tt class="py-line"> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">[</tt> <tt class="py-number">10</tt><tt class="py-op">:</tt> <tt class="py-op">]</tt> </tt>
2331<a name="L2073"></a><tt class="py-lineno">2073</tt> <tt class="py-line"> <tt class="py-name">portEgressList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-string">'1'</tt> <tt class="py-op">]</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">deviceDPIDsCopy</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
2332<a name="L2074"></a><tt class="py-lineno">2074</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2333<a name="L2075"></a><tt class="py-lineno">2075</tt> <tt class="py-line"> <tt class="py-name">MACsDictCopy</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
2334<a name="L2076"></a><tt class="py-lineno">2076</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">deviceDPIDsCopy</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2335<a name="L2077"></a><tt class="py-lineno">2077</tt> <tt class="py-line"> <tt class="py-name">MACsDictCopy</tt><tt class="py-op">[</tt> <tt class="py-name">deviceDPIDsCopy</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">main</tt><tt class="py-op">.</tt><tt class="py-name">hostMACs</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">'/'</tt> <tt class="py-op">)</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> </tt>
2336<a name="L2078"></a><tt class="py-lineno">2078</tt> <tt class="py-line"> </tt>
2337<a name="L2079"></a><tt class="py-lineno">2079</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"deviceDPIDsCopy"</tt><tt class="py-op">,</tt> <tt class="py-name">deviceDPIDsCopy</tt> </tt>
2338<a name="L2080"></a><tt class="py-lineno">2080</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">""</tt> </tt>
2339<a name="L2081"></a><tt class="py-lineno">2081</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"MACsDictCopy"</tt><tt class="py-op">,</tt> <tt class="py-name">MACsDictCopy</tt> </tt>
2340<a name="L2082"></a><tt class="py-lineno">2082</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>
2341<a name="L2083"></a><tt class="py-lineno">2083</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">xrange</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 class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2342<a name="L2084"></a><tt class="py-lineno">2084</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2343<a name="L2085"></a><tt class="py-lineno">2085</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-540" class="py-name"><a title="TestON.bin.cli
2344TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-540', 'cli', 'link-106');">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>
2345<a name="L2086"></a><tt class="py-lineno">2086</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">deviceDPIDsCopy</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2346<a name="L2087"></a><tt class="py-lineno">2087</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2347<a name="L2088"></a><tt class="py-lineno">2088</tt> <tt class="py-line"> <tt class="py-name">ingressDevice</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
2348<a name="L2089"></a><tt class="py-lineno">2089</tt> <tt class="py-line"> <tt class="py-name">egressDeviceList</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">deviceDPIDsCopy</tt><tt class="py-op">)</tt> </tt>
2349<a name="L2090"></a><tt class="py-lineno">2090</tt> <tt class="py-line"> <tt class="py-name">egressDeviceList</tt><tt class="py-op">.</tt><tt class="py-name">remove</tt><tt class="py-op">(</tt><tt class="py-name">ingressDevice</tt><tt class="py-op">)</tt> </tt>
2350<a name="L2091"></a><tt class="py-lineno">2091</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-541" class="py-name"><a title="TestON.core.Thread
2351TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-541', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-542" class="py-name"><a title="TestON.bin.cli
2352TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-542', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-543" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.addSinglepointToMultipointIntent" class="py-name" href="#" onclick="return doclink('link-543', 'addSinglepointToMultipointIntent', 'link-519');">addSinglepointToMultipointIntent</a></tt><tt class="py-op">,</tt> </tt>
2353<a name="L2092"></a><tt class="py-lineno">2092</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2354<a name="L2093"></a><tt class="py-lineno">2093</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"addSinglepointToMultipointIntent"</tt><tt class="py-op">,</tt> </tt>
2355<a name="L2094"></a><tt class="py-lineno">2094</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">ingressDevice</tt><tt class="py-op">,</tt><tt class="py-name">egressDeviceList</tt><tt class="py-op">,</tt><tt class="py-string">'1'</tt><tt class="py-op">,</tt><tt class="py-name">portEgressList</tt><tt class="py-op">,</tt><tt class="py-string">'IPV4'</tt><tt class="py-op">,</tt><tt class="py-name">MACsDictCopy</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">ingressDevice</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-string">''</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2356<a name="L2095"></a><tt class="py-lineno">2095</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2357<a name="L2096"></a><tt class="py-lineno">2096</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(1)</tt> </tt>
2358<a name="L2097"></a><tt class="py-lineno">2097</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>
2359<a name="L2098"></a><tt class="py-lineno">2098</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2360<a name="L2099"></a><tt class="py-lineno">2099</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2361<a name="L2100"></a><tt class="py-lineno">2100</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2362<a name="L2101"></a><tt class="py-lineno">2101</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2363<a name="L2102"></a><tt class="py-lineno">2102</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2364<a name="L2103"></a><tt class="py-lineno">2103</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>
2365<a name="L2104"></a><tt class="py-lineno">2104</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-544" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-544', 'log', 'link-2');">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 adding point intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2366<a name="L2105"></a><tt class="py-lineno">2105</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>
2367<a name="L2106"></a><tt class="py-lineno">2106</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-545" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-545', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Ping across all hosts"</tt> <tt class="py-op">)</tt> </tt>
2368<a name="L2107"></a><tt class="py-lineno">2107</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>
2369<a name="L2108"></a><tt class="py-lineno">2108</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>
2370<a name="L2109"></a><tt class="py-lineno">2109</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-546" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-546', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">pingTimeout</tt><tt class="py-op">,</tt><tt class="py-name">shortCircuit</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">acceptableFailed</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">)</tt> </tt>
2371<a name="L2110"></a><tt class="py-lineno">2110</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>
2372<a name="L2111"></a><tt class="py-lineno">2111</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2373<a name="L2112"></a><tt class="py-lineno">2112</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-547" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-547', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2374<a name="L2113"></a><tt class="py-lineno">2113</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2375<a name="L2114"></a><tt class="py-lineno">2114</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2376<a name="L2115"></a><tt class="py-lineno">2115</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2377<a name="L2116"></a><tt class="py-lineno">2116</tt> <tt class="py-line"> </tt>
2378<a name="L2117"></a><tt class="py-lineno">2117</tt> <tt class="py-line"> <tt class="py-name">case98Result</tt> <tt class="py-op">=</tt> <tt class="py-name">pingResult</tt> </tt>
2379<a name="L2118"></a><tt class="py-lineno">2118</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>
2380<a name="L2119"></a><tt class="py-lineno">2119</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>
2381<a name="L2120"></a><tt class="py-lineno">2120</tt> <tt class="py-line"> <tt class="py-name">actual</tt><tt class="py-op">=</tt><tt class="py-name">case98Result</tt><tt class="py-op">,</tt> </tt>
2382<a name="L2121"></a><tt class="py-lineno">2121</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 single to multi point Intents and Ping All test PASS"</tt><tt class="py-op">,</tt> </tt>
2383<a name="L2122"></a><tt class="py-lineno">2122</tt> <tt class="py-line"> <tt id="link-548" class="py-name"><a title="TestON.core.teston.TestON.onfail
2384TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-548', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Install 25 single to multi point Intents and Ping All test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2385</div><a name="L2123"></a><tt class="py-lineno">2123</tt> <tt class="py-line"> </tt>
2386<a name="CHOtest.CASE10"></a><div id="CHOtest.CASE10-def"><a name="L2124"></a><tt class="py-lineno">2124</tt> <a class="py-toggle" href="#" id="CHOtest.CASE10-toggle" onclick="return toggle('CHOtest.CASE10');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-class.html#CASE10">CASE10</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2387</div><div id="CHOtest.CASE10-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE10-expanded"><a name="L2125"></a><tt class="py-lineno">2125</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
2388<a name="L2126"></a><tt class="py-lineno">2126</tt> <tt class="py-line"> <tt class="py-string">"""</tt> </tt>
2389<a name="L2127"></a><tt class="py-lineno">2127</tt> <tt class="py-line"><tt class="py-string"> Remove all Intents</tt> </tt>
2390<a name="L2128"></a><tt class="py-lineno">2128</tt> <tt class="py-line"><tt class="py-string"> """</tt> </tt>
2391<a name="L2129"></a><tt class="py-lineno">2129</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-549" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-549', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Remove all intents that were installed previously"</tt> <tt class="py-op">)</tt> </tt>
2392<a name="L2130"></a><tt class="py-lineno">2130</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-550" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-550', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"______________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2393<a name="L2131"></a><tt class="py-lineno">2131</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-551', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Remove all intents"</tt> <tt class="py-op">)</tt> </tt>
2394<a name="L2132"></a><tt class="py-lineno">2132</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-552" class="py-name"><a title="TestON.core.teston.TestON.case" class="py-name" href="#" onclick="return doclink('link-552', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Removing intents"</tt> <tt class="py-op">)</tt> </tt>
2395<a name="L2133"></a><tt class="py-lineno">2133</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-553" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-553', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Obtain the intent id's first"</tt> <tt class="py-op">)</tt> </tt>
2396<a name="L2134"></a><tt class="py-lineno">2134</tt> <tt class="py-line"> <tt class="py-name">intentsList</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-554" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentIds()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#getAllIntentIds"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentIds" class="py-name" href="#" onclick="return doclink('link-554', 'getAllIntentIds', 'link-554');">getAllIntentIds</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2397<a name="L2135"></a><tt class="py-lineno">2135</tt> <tt class="py-line"> <tt class="py-name">ansi_escape</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt> <tt class="py-string">r'\x1b[^m]*m'</tt> <tt class="py-op">)</tt> </tt>
2398<a name="L2136"></a><tt class="py-lineno">2136</tt> <tt class="py-line"> <tt class="py-name">intentsList</tt> <tt class="py-op">=</tt> <tt class="py-name">ansi_escape</tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt> <tt class="py-string">''</tt><tt class="py-op">,</tt> <tt class="py-name">intentsList</tt> <tt class="py-op">)</tt> </tt>
2399<a name="L2137"></a><tt class="py-lineno">2137</tt> <tt class="py-line"> <tt class="py-name">intentsList</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsList</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> </tt>
2400<a name="L2138"></a><tt class="py-lineno">2138</tt> <tt class="py-line"> <tt class="py-string">" onos:intents | grep id="</tt><tt class="py-op">,</tt> </tt>
2401<a name="L2139"></a><tt class="py-lineno">2139</tt> <tt class="py-line"> <tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> </tt>
2402<a name="L2140"></a><tt class="py-lineno">2140</tt> <tt class="py-line"> <tt class="py-string">"id="</tt><tt class="py-op">,</tt> </tt>
2403<a name="L2141"></a><tt class="py-lineno">2141</tt> <tt class="py-line"> <tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> </tt>
2404<a name="L2142"></a><tt class="py-lineno">2142</tt> <tt class="py-line"> <tt class="py-string">"\r\r"</tt><tt class="py-op">,</tt> </tt>
2405<a name="L2143"></a><tt class="py-lineno">2143</tt> <tt class="py-line"> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt>
2406<a name="L2144"></a><tt class="py-lineno">2144</tt> <tt class="py-line"> <tt class="py-name">intentsList</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsList</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2407<a name="L2145"></a><tt class="py-lineno">2145</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2408<a name="L2146"></a><tt class="py-lineno">2146</tt> <tt class="py-line"> <tt class="py-name">step1Result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2409<a name="L2147"></a><tt class="py-lineno">2147</tt> <tt class="py-line"> <tt class="py-name">moreIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2410<a name="L2148"></a><tt class="py-lineno">2148</tt> <tt class="py-line"> <tt class="py-name">removeIntentCount</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
2411<a name="L2149"></a><tt class="py-lineno">2149</tt> <tt class="py-line"> <tt class="py-name">intentsCount</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">intentsList</tt><tt class="py-op">)</tt> </tt>
2412<a name="L2150"></a><tt class="py-lineno">2150</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-555" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-555', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> <tt class="py-string">"Current number of intents: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">intentsCount</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
2413<a name="L2151"></a><tt class="py-lineno">2151</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">intentsList</tt> <tt class="py-op">)</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2414<a name="L2152"></a><tt class="py-lineno">2152</tt> <tt class="py-line"> <tt class="py-name">results</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2415<a name="L2153"></a><tt class="py-lineno">2153</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-556" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-556', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Removing intent..."</tt><tt class="py-op">)</tt> </tt>
2416<a name="L2154"></a><tt class="py-lineno">2154</tt> <tt class="py-line"> <tt class="py-keyword">while</tt> <tt class="py-name">moreIntents</tt><tt class="py-op">:</tt> </tt>
2417<a name="L2155"></a><tt class="py-lineno">2155</tt> <tt class="py-line"> <tt class="py-comment"># This is a work around only: cycle through intents removal for up to 5 times.</tt> </tt>
2418<a name="L2156"></a><tt class="py-lineno">2156</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">removeIntentCount</tt> <tt class="py-op">==</tt> <tt class="py-number">5</tt><tt class="py-op">:</tt> </tt>
2419<a name="L2157"></a><tt class="py-lineno">2157</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2420<a name="L2158"></a><tt class="py-lineno">2158</tt> <tt class="py-line"> <tt class="py-name">removeIntentCount</tt> <tt class="py-op">=</tt> <tt class="py-name">removeIntentCount</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2421<a name="L2159"></a><tt class="py-lineno">2159</tt> <tt class="py-line"> <tt class="py-name">intentsList1</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-557" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.getAllIntentIds" class="py-name" href="#" onclick="return doclink('link-557', 'getAllIntentIds', 'link-554');">getAllIntentIds</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2422<a name="L2160"></a><tt class="py-lineno">2160</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">intentsList1</tt> <tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
2423<a name="L2161"></a><tt class="py-lineno">2161</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2424<a name="L2162"></a><tt class="py-lineno">2162</tt> <tt class="py-line"> <tt class="py-name">ansi_escape</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt> <tt class="py-string">r'\x1b[^m]*m'</tt> <tt class="py-op">)</tt> </tt>
2425<a name="L2163"></a><tt class="py-lineno">2163</tt> <tt class="py-line"> <tt class="py-name">intentsList1</tt> <tt class="py-op">=</tt> <tt class="py-name">ansi_escape</tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt> <tt class="py-string">''</tt><tt class="py-op">,</tt> <tt class="py-name">intentsList1</tt> <tt class="py-op">)</tt> </tt>
2426<a name="L2164"></a><tt class="py-lineno">2164</tt> <tt class="py-line"> <tt class="py-name">intentsList1</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsList1</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> </tt>
2427<a name="L2165"></a><tt class="py-lineno">2165</tt> <tt class="py-line"> <tt class="py-string">" onos:intents | grep id="</tt><tt class="py-op">,</tt> </tt>
2428<a name="L2166"></a><tt class="py-lineno">2166</tt> <tt class="py-line"> <tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> </tt>
2429<a name="L2167"></a><tt class="py-lineno">2167</tt> <tt class="py-line"> <tt class="py-string">" state="</tt><tt class="py-op">,</tt> </tt>
2430<a name="L2168"></a><tt class="py-lineno">2168</tt> <tt class="py-line"> <tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> </tt>
2431<a name="L2169"></a><tt class="py-lineno">2169</tt> <tt class="py-line"> <tt class="py-string">"\r\r"</tt><tt class="py-op">,</tt> </tt>
2432<a name="L2170"></a><tt class="py-lineno">2170</tt> <tt class="py-line"> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt>
2433<a name="L2171"></a><tt class="py-lineno">2171</tt> <tt class="py-line"> <tt class="py-name">intentsList1</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsList1</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2434<a name="L2172"></a><tt class="py-lineno">2172</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-558" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-558', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> <tt class="py-string">"Round %d intents to remove: "</tt> <tt class="py-op">%</tt><tt class="py-op">(</tt><tt class="py-name">removeIntentCount</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
2435<a name="L2173"></a><tt class="py-lineno">2173</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">intentsList1</tt> </tt>
2436<a name="L2174"></a><tt class="py-lineno">2174</tt> <tt class="py-line"> <tt class="py-name">intentIdList1</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2437<a name="L2175"></a><tt class="py-lineno">2175</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">intentsList1</tt> <tt class="py-op">)</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">0</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2438<a name="L2176"></a><tt class="py-lineno">2176</tt> <tt class="py-line"> <tt class="py-name">moreIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2439<a name="L2177"></a><tt class="py-lineno">2177</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">intentsList1</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2440<a name="L2178"></a><tt class="py-lineno">2178</tt> <tt class="py-line"> <tt class="py-name">intentsTemp1</tt> <tt class="py-op">=</tt> <tt class="py-name">intentsList1</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">','</tt> <tt class="py-op">)</tt> </tt>
2441<a name="L2179"></a><tt class="py-lineno">2179</tt> <tt class="py-line"> <tt class="py-name">intentIdList1</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-name">intentsTemp1</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">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 class="py-op">)</tt> </tt>
2442<a name="L2180"></a><tt class="py-lineno">2180</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-559" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-559', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> <tt class="py-string">"Leftover Intent IDs: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">intentIdList1</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
2443<a name="L2181"></a><tt class="py-lineno">2181</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-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt> <tt class="py-op">(</tt> <tt class="py-string">"Length of Leftover Intents list: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">intentIdList1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt>
2444<a name="L2182"></a><tt class="py-lineno">2182</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>
2445<a name="L2183"></a><tt class="py-lineno">2183</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">xrange</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 class="py-name">intentIdList1</tt> <tt class="py-op">)</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">numCtrls</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2446<a name="L2184"></a><tt class="py-lineno">2184</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2447<a name="L2185"></a><tt class="py-lineno">2185</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-561" class="py-name"><a title="TestON.bin.cli
2448TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-561', 'cli', 'link-106');">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>
2449<a name="L2186"></a><tt class="py-lineno">2186</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">&gt;=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">intentIdList1</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2450<a name="L2187"></a><tt class="py-lineno">2187</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2451<a name="L2188"></a><tt class="py-lineno">2188</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-562" class="py-name"><a title="TestON.core.Thread
2452TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-562', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt> <tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-563" class="py-name"><a title="TestON.bin.cli
2453TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-563', 'cli', 'link-106');">cli</a></tt><tt class="py-op">.</tt><tt id="link-564" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.removeIntent()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#removeIntent,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.removeIntent()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#removeIntent"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.removeIntent
2454TestON.drivers.common.cli.onosclidriver.OnosCliDriver.removeIntent" class="py-name" href="#" onclick="return doclink('link-564', 'removeIntent', 'link-564');">removeIntent</a></tt><tt class="py-op">,</tt> </tt>
2455<a name="L2189"></a><tt class="py-lineno">2189</tt> <tt class="py-line"> <tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2456<a name="L2190"></a><tt class="py-lineno">2190</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"removeIntent"</tt><tt class="py-op">,</tt> </tt>
2457<a name="L2191"></a><tt class="py-lineno">2191</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">intentIdList1</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">'org.onosproject.cli'</tt><tt class="py-op">,</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">False</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2458<a name="L2192"></a><tt class="py-lineno">2192</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2459<a name="L2193"></a><tt class="py-lineno">2193</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>
2460<a name="L2194"></a><tt class="py-lineno">2194</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2461<a name="L2195"></a><tt class="py-lineno">2195</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2462<a name="L2196"></a><tt class="py-lineno">2196</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2463<a name="L2197"></a><tt class="py-lineno">2197</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2464<a name="L2198"></a><tt class="py-lineno">2198</tt> <tt class="py-line"> <tt class="py-name">intentIdList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2465<a name="L2199"></a><tt class="py-lineno">2199</tt> <tt class="py-line"> <tt class="py-comment">#time.sleep(2)</tt> </tt>
2466<a name="L2200"></a><tt class="py-lineno">2200</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>
2467<a name="L2201"></a><tt class="py-lineno">2201</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-565" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-565', 'log', 'link-2');">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 removing host intents: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2468<a name="L2202"></a><tt class="py-lineno">2202</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>
2469<a name="L2203"></a><tt class="py-lineno">2203</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-566" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-566', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Purging WITHDRAWN Intents"</tt><tt class="py-op">)</tt> </tt>
2470<a name="L2204"></a><tt class="py-lineno">2204</tt> <tt class="py-line"> <tt class="py-name">purgeResult</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-567" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.purgeWithdrawnIntents()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#purgeWithdrawnIntents"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.purgeWithdrawnIntents" class="py-name" href="#" onclick="return doclink('link-567', 'purgeWithdrawnIntents', 'link-567');">purgeWithdrawnIntents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2471<a name="L2205"></a><tt class="py-lineno">2205</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
2472<a name="L2206"></a><tt class="py-lineno">2206</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>
2473<a name="L2207"></a><tt class="py-lineno">2207</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">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-568" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
2474TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-568', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2475<a name="L2208"></a><tt class="py-lineno">2208</tt> <tt class="py-line"> <tt class="py-keyword">continue</tt> </tt>
2476<a name="L2209"></a><tt class="py-lineno">2209</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt>
2477<a name="L2210"></a><tt class="py-lineno">2210</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>
2478<a name="L2211"></a><tt class="py-lineno">2211</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
2479<a name="L2212"></a><tt class="py-lineno">2212</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Removed %d intents"</tt> <tt class="py-op">%</tt><tt class="py-op">(</tt><tt class="py-name">intentsCount</tt><tt class="py-op">)</tt> </tt>
2480<a name="L2213"></a><tt class="py-lineno">2213</tt> <tt class="py-line"> <tt class="py-name">step1Result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2481<a name="L2214"></a><tt class="py-lineno">2214</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
2482<a name="L2215"></a><tt class="py-lineno">2215</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"No Intent IDs found in Intents list: "</tt><tt class="py-op">,</tt> <tt class="py-name">intentsList</tt> </tt>
2483<a name="L2216"></a><tt class="py-lineno">2216</tt> <tt class="py-line"> <tt class="py-name">step1Result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
2484<a name="L2217"></a><tt class="py-lineno">2217</tt> <tt class="py-line"> </tt>
2485<a name="L2218"></a><tt class="py-lineno">2218</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">ONOScli1</tt><tt class="py-op">.</tt><tt id="link-569" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.intents
2486TestON.drivers.common.cli.onosclidriver.OnosCliDriver.intents" class="py-name" href="#" onclick="return doclink('link-569', 'intents', 'link-248');">intents</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2487<a name="L2219"></a><tt class="py-lineno">2219</tt> <tt class="py-line"> <tt class="py-name">caseResult10</tt> <tt class="py-op">=</tt> <tt class="py-name">step1Result</tt> </tt>
2488<a name="L2220"></a><tt class="py-lineno">2220</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">caseResult10</tt><tt class="py-op">,</tt> </tt>
2489<a name="L2221"></a><tt class="py-lineno">2221</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intent removal test successful"</tt><tt class="py-op">,</tt> </tt>
2490<a name="L2222"></a><tt class="py-lineno">2222</tt> <tt class="py-line"> <tt id="link-570" class="py-name"><a title="TestON.core.teston.TestON.onfail
2491TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-570', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Intent removal test failed"</tt> <tt class="py-op">)</tt> </tt>
2492</div><a name="L2223"></a><tt class="py-lineno">2223</tt> <tt class="py-line"> </tt>
2493<a name="CHOtest.CASE12"></a><div id="CHOtest.CASE12-def"><a name="L2224"></a><tt class="py-lineno">2224</tt> <a class="py-toggle" href="#" id="CHOtest.CASE12-toggle" onclick="return toggle('CHOtest.CASE12');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.tests.CHOtest.CHOtest.CHOtest-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>
2494</div><div id="CHOtest.CASE12-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CHOtest.CASE12-expanded"><a name="L2225"></a><tt class="py-lineno">2225</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt>
2495<a name="L2226"></a><tt class="py-lineno">2226</tt> <tt class="py-line"><tt class="py-docstring"> Enable onos-app-ifwd, Verify Intent based Reactive forwarding through ping all and Disable it</tt> </tt>
2496<a name="L2227"></a><tt class="py-lineno">2227</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt>
2497<a name="L2228"></a><tt class="py-lineno">2228</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
2498<a name="L2229"></a><tt class="py-lineno">2229</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
2499<a name="L2230"></a><tt class="py-lineno">2230</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt>
2500<a name="L2231"></a><tt class="py-lineno">2231</tt> <tt class="py-line"> </tt>
2501<a name="L2232"></a><tt class="py-lineno">2232</tt> <tt class="py-line"> <tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
2502<a name="L2233"></a><tt class="py-lineno">2233</tt> <tt class="py-line"> </tt>
2503<a name="L2234"></a><tt class="py-lineno">2234</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-571" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-571', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Intent based Reactive forwarding and Verify ping all"</tt> <tt class="py-op">)</tt> </tt>
2504<a name="L2235"></a><tt class="py-lineno">2235</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-572" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-572', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"_____________________________________________________"</tt> <tt class="py-op">)</tt> </tt>
2505<a name="L2236"></a><tt class="py-lineno">2236</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.case" class="py-name" href="#" onclick="return doclink('link-573', 'case', 'link-1');">case</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable Intent based Reactive forwarding and Verify ping all"</tt> <tt class="py-op">)</tt> </tt>
2506<a name="L2237"></a><tt class="py-lineno">2237</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-574" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-574', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Enable intent based Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
2507<a name="L2238"></a><tt class="py-lineno">2238</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt>
2508<a name="L2239"></a><tt class="py-lineno">2239</tt> <tt class="py-line"> <tt class="py-name">feature</tt> <tt class="py-op">=</tt> <tt class="py-string">"onos-app-ifwd"</tt> </tt>
2509<a name="L2240"></a><tt class="py-lineno">2240</tt> <tt class="py-line"> </tt>
2510<a name="L2241"></a><tt class="py-lineno">2241</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2511<a name="L2242"></a><tt class="py-lineno">2242</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>
2512<a name="L2243"></a><tt class="py-lineno">2243</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-575" class="py-name"><a title="TestON.bin.cli
2513TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-575', 'cli', 'link-106');">cli</a></tt><tt class="py-op">,</tt><tt class="py-name">feature</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>
2514<a name="L2244"></a><tt class="py-lineno">2244</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-576" class="py-name"><a title="TestON.core.Thread
2515TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-576', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt><tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-577" class="py-name"><a title="TestON.bin.cli
2516TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-577', 'cli', 'link-106');">cli</a></tt><tt class="py-op">,</tt><tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2517<a name="L2245"></a><tt class="py-lineno">2245</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"featureInstall"</tt><tt class="py-op">,</tt><tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-name">feature</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2518<a name="L2246"></a><tt class="py-lineno">2246</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2519<a name="L2247"></a><tt class="py-lineno">2247</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>
2520<a name="L2248"></a><tt class="py-lineno">2248</tt> <tt class="py-line"> <tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2521<a name="L2249"></a><tt class="py-lineno">2249</tt> <tt class="py-line"> </tt>
2522<a name="L2250"></a><tt class="py-lineno">2250</tt> <tt class="py-line"> <tt class="py-name">results</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2523<a name="L2251"></a><tt class="py-lineno">2251</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2524<a name="L2252"></a><tt class="py-lineno">2252</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2525<a name="L2253"></a><tt class="py-lineno">2253</tt> <tt class="py-line"> <tt class="py-name">results</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2526<a name="L2254"></a><tt class="py-lineno">2254</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>
2527<a name="L2255"></a><tt class="py-lineno">2255</tt> <tt class="py-line"> </tt>
2528<a name="L2256"></a><tt class="py-lineno">2256</tt> <tt class="py-line"> <tt class="py-keyword">if</tt><tt class="py-op">(</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt><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 class="py-keyword">for</tt> <tt class="py-name">result</tt> <tt class="py-keyword">in</tt> <tt class="py-name">results</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2529<a name="L2257"></a><tt class="py-lineno">2257</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-578" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-578', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Did not install onos-app-ifwd feature properly"</tt><tt class="py-op">)</tt> </tt>
2530<a name="L2258"></a><tt class="py-lineno">2258</tt> <tt class="py-line"> <tt class="py-comment">#main.cleanup()</tt> </tt>
2531<a name="L2259"></a><tt class="py-lineno">2259</tt> <tt class="py-line"> <tt class="py-comment">#main.exit()</tt> </tt>
2532<a name="L2260"></a><tt class="py-lineno">2260</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
2533<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-579" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-579', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Successful feature:install onos-app-ifwd"</tt><tt class="py-op">)</tt> </tt>
2534<a name="L2262"></a><tt class="py-lineno">2262</tt> <tt class="py-line"> <tt class="py-name">installResult</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt>
2535<a name="L2263"></a><tt class="py-lineno">2263</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-580" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-580', 'log', 'link-2');">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 feature:install onos-app-ifwd: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2536<a name="L2264"></a><tt class="py-lineno">2264</tt> <tt class="py-line"> </tt>
2537<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-581" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-581', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Verify Pingall"</tt> <tt class="py-op">)</tt> </tt>
2538<a name="L2266"></a><tt class="py-lineno">2266</tt> <tt class="py-line"> <tt class="py-name">ping_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>
2539<a name="L2267"></a><tt class="py-lineno">2267</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>
2540<a name="L2268"></a><tt class="py-lineno">2268</tt> <tt class="py-line"> <tt class="py-name">ping_result</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-582" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.pingall" class="py-name" href="#" onclick="return doclink('link-582', 'pingall', 'link-138');">pingall</a></tt><tt class="py-op">(</tt><tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">600</tt><tt class="py-op">)</tt> </tt>
2541<a name="L2269"></a><tt class="py-lineno">2269</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>
2542<a name="L2270"></a><tt class="py-lineno">2270</tt> <tt class="py-line"> <tt class="py-name">timeDiff</tt> <tt class="py-op">=</tt> <tt class="py-name">round</tt><tt class="py-op">(</tt> <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 class="py-number">2</tt> <tt class="py-op">)</tt> </tt>
2543<a name="L2271"></a><tt class="py-lineno">2271</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-583" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-583', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> </tt>
2544<a name="L2272"></a><tt class="py-lineno">2272</tt> <tt class="py-line"> <tt class="py-string">"Time taken for Ping All: "</tt> <tt class="py-op">+</tt> </tt>
2545<a name="L2273"></a><tt class="py-lineno">2273</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">timeDiff</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt>
2546<a name="L2274"></a><tt class="py-lineno">2274</tt> <tt class="py-line"> <tt class="py-string">" seconds"</tt> <tt class="py-op">)</tt> </tt>
2547<a name="L2275"></a><tt class="py-lineno">2275</tt> <tt class="py-line"> </tt>
2548<a name="L2276"></a><tt class="py-lineno">2276</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">ping_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 class="py-op">:</tt> </tt>
2549<a name="L2277"></a><tt class="py-lineno">2277</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-584" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-584', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode successful"</tt> <tt class="py-op">)</tt> </tt>
2550<a name="L2278"></a><tt class="py-lineno">2278</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
2551<a name="L2279"></a><tt class="py-lineno">2279</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-585" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-585', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt class="py-string">"Pingall Test in Reactive mode failed"</tt> <tt class="py-op">)</tt> </tt>
2552<a name="L2280"></a><tt class="py-lineno">2280</tt> <tt class="py-line"> </tt>
2553<a name="L2281"></a><tt class="py-lineno">2281</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-586" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-586', 'step', 'link-4');">step</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Disable Intent based Reactive forwarding"</tt> <tt class="py-op">)</tt> </tt>
2554<a name="L2282"></a><tt class="py-lineno">2282</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">FALSE</tt> </tt>
2555<a name="L2283"></a><tt class="py-lineno">2283</tt> <tt class="py-line"> </tt>
2556<a name="L2284"></a><tt class="py-lineno">2284</tt> <tt class="py-line"> <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2557<a name="L2285"></a><tt class="py-lineno">2285</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>
2558<a name="L2286"></a><tt class="py-lineno">2286</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt id="link-587" class="py-name"><a title="TestON.bin.cli
2559TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-587', 'cli', 'link-106');">cli</a></tt><tt class="py-op">,</tt><tt class="py-name">feature</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>
2560<a name="L2287"></a><tt class="py-lineno">2287</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-588" class="py-name"><a title="TestON.core.Thread
2561TestON.core.Thread.Thread" class="py-name" href="#" onclick="return doclink('link-588', 'Thread', 'link-40');">Thread</a></tt><tt class="py-op">(</tt><tt class="py-name">target</tt><tt class="py-op">=</tt><tt id="link-589" class="py-name"><a title="TestON.bin.cli
2562TestON.drivers.common.cli" class="py-name" href="#" onclick="return doclink('link-589', 'cli', 'link-106');">cli</a></tt><tt class="py-op">,</tt><tt class="py-name">threadID</tt><tt class="py-op">=</tt><tt class="py-name">threadID</tt><tt class="py-op">,</tt> </tt>
2563<a name="L2288"></a><tt class="py-lineno">2288</tt> <tt class="py-line"> <tt class="py-name">name</tt><tt class="py-op">=</tt><tt class="py-string">"featureUninstall"</tt><tt class="py-op">,</tt><tt class="py-name">args</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-name">feature</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
2564<a name="L2289"></a><tt class="py-lineno">2289</tt> <tt class="py-line"> <tt class="py-name">pool</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>
2565<a name="L2290"></a><tt class="py-lineno">2290</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>
2566<a name="L2291"></a><tt class="py-lineno">2291</tt> <tt class="py-line"> <tt class="py-name">threadID</tt> <tt class="py-op">=</tt> <tt class="py-name">threadID</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
2567<a name="L2292"></a><tt class="py-lineno">2292</tt> <tt class="py-line"> </tt>
2568<a name="L2293"></a><tt class="py-lineno">2293</tt> <tt class="py-line"> <tt class="py-name">results</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
2569<a name="L2294"></a><tt class="py-lineno">2294</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">thread</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pool</tt><tt class="py-op">:</tt> </tt>
2570<a name="L2295"></a><tt class="py-lineno">2295</tt> <tt class="py-line"> <tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
2571<a name="L2296"></a><tt class="py-lineno">2296</tt> <tt class="py-line"> <tt class="py-name">results</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">thread</tt><tt class="py-op">.</tt><tt class="py-name">result</tt><tt class="py-op">)</tt> </tt>
2572<a name="L2297"></a><tt class="py-lineno">2297</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>
2573<a name="L2298"></a><tt class="py-lineno">2298</tt> <tt class="py-line"> </tt>
2574<a name="L2299"></a><tt class="py-lineno">2299</tt> <tt class="py-line"> <tt class="py-keyword">if</tt><tt class="py-op">(</tt> <tt class="py-name">all</tt><tt class="py-op">(</tt><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 class="py-keyword">for</tt> <tt class="py-name">result</tt> <tt class="py-keyword">in</tt> <tt class="py-name">results</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
2575<a name="L2300"></a><tt class="py-lineno">2300</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-590" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-590', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Did not uninstall onos-app-ifwd feature properly"</tt><tt class="py-op">)</tt> </tt>
2576<a name="L2301"></a><tt class="py-lineno">2301</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">FALSE</tt> </tt>
2577<a name="L2302"></a><tt class="py-lineno">2302</tt> <tt class="py-line"> <tt class="py-comment">#main.cleanup()</tt> </tt>
2578<a name="L2303"></a><tt class="py-lineno">2303</tt> <tt class="py-line"> <tt class="py-comment">#main.exit()</tt> </tt>
2579<a name="L2304"></a><tt class="py-lineno">2304</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
2580<a name="L2305"></a><tt class="py-lineno">2305</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-591" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-591', 'log', 'link-2');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Successful feature:uninstall onos-app-ifwd"</tt><tt class="py-op">)</tt> </tt>
2581<a name="L2306"></a><tt class="py-lineno">2306</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">TRUE</tt> </tt>
2582<a name="L2307"></a><tt class="py-lineno">2307</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-592" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-592', 'log', 'link-2');">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 feature:uninstall onos-app-ifwd: %2f seconds"</tt> <tt class="py-op">%</tt><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>
2583<a name="L2308"></a><tt class="py-lineno">2308</tt> <tt class="py-line"> </tt>
2584<a name="L2309"></a><tt class="py-lineno">2309</tt> <tt class="py-line"> <tt class="py-comment"># Waiting for reative flows to be cleared.</tt> </tt>
2585<a name="L2310"></a><tt class="py-lineno">2310</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>
2586<a name="L2311"></a><tt class="py-lineno">2311</tt> <tt class="py-line"> </tt>
2587<a name="L2312"></a><tt class="py-lineno">2312</tt> <tt class="py-line"> <tt class="py-name">case11Result</tt> <tt class="py-op">=</tt> <tt class="py-name">installResult</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ping_result</tt> <tt class="py-keyword">and</tt> <tt class="py-name">uninstallResult</tt> </tt>
2588<a name="L2313"></a><tt class="py-lineno">2313</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">case11Result</tt><tt class="py-op">,</tt> </tt>
2589<a name="L2314"></a><tt class="py-lineno">2314</tt> <tt class="py-line"> <tt class="py-name">onpass</tt><tt class="py-op">=</tt><tt class="py-string">"Intent based Reactive forwarding Pingall test PASS"</tt><tt class="py-op">,</tt> </tt>
2590<a name="L2315"></a><tt class="py-lineno">2315</tt> <tt class="py-line"> <tt id="link-593" class="py-name"><a title="TestON.core.teston.TestON.onfail
2591TestON.drivers.common.clidriver.CLI.onfail" class="py-name" href="#" onclick="return doclink('link-593', 'onfail', 'link-6');">onfail</a></tt><tt class="py-op">=</tt><tt class="py-string">"Intent based Reactive forwarding Pingall test FAIL"</tt> <tt class="py-op">)</tt> </tt>
2592</div></div><a name="L2316"></a><tt class="py-lineno">2316</tt> <tt class="py-line"> </tt><script type="text/javascript">
2593<!--
2594expandto(location.href);
2595// -->
2596</script>
2597</pre>
2598<br />
2599<!-- ==================== NAVIGATION BAR ==================== -->
2600<table class="navbar" border="0" width="100%" cellpadding="0"
2601 bgcolor="#a0c0ff" cellspacing="0">
2602 <tr valign="middle">
2603 <!-- Home link -->
2604 <th>&nbsp;&nbsp;&nbsp;<a
2605 href="TestON-module.html">Home</a>&nbsp;&nbsp;&nbsp;</th>
2606
2607 <!-- Tree link -->
2608 <th>&nbsp;&nbsp;&nbsp;<a
2609 href="module-tree.html">Trees</a>&nbsp;&nbsp;&nbsp;</th>
2610
2611 <!-- Index link -->
2612 <th>&nbsp;&nbsp;&nbsp;<a
2613 href="identifier-index.html">Indices</a>&nbsp;&nbsp;&nbsp;</th>
2614
2615 <!-- Help link -->
2616 <th>&nbsp;&nbsp;&nbsp;<a
2617 href="help.html">Help</a>&nbsp;&nbsp;&nbsp;</th>
2618
2619 <!-- Project homepage -->
2620 <th class="navbar" align="right" width="100%">
2621 <table border="0" cellpadding="0" cellspacing="0">
2622 <tr><th class="navbar" align="center"
2623 >TestON</th>
2624 </tr></table></th>
2625 </tr>
2626</table>
2627<table border="0" cellpadding="0" cellspacing="0" width="100%%">
2628 <tr>
2629 <td align="left" class="footer">
2630 Generated by Epydoc 3.0.1 on Mon Aug 10 11:12:39 2015
2631 </td>
2632 <td align="right" class="footer">
2633 <a target="mainFrame" href="http://epydoc.sourceforge.net"
2634 >http://epydoc.sourceforge.net</a>
2635 </td>
2636 </tr>
2637</table>
2638
2639<script type="text/javascript">
2640 <!--
2641 // Private objects are initially displayed (because if
2642 // javascript is turned off then we want them to be
2643 // visible); but by default, we want to hide them. So hide
2644 // them unless we have a cookie that says to show them.
2645 checkCookie();
2646 // -->
2647</script>
2648</body>
2649</html>