Jon Hall | a1cdd89 | 2015-08-10 13:36:28 -0700 | [diff] [blame] | 1 | <?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.drivers.common.cli.onosdriver</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> <a |
| 19 | href="TestON-module.html">Home</a> </th> |
| 20 | |
| 21 | <!-- Tree link --> |
| 22 | <th> <a |
| 23 | href="module-tree.html">Trees</a> </th> |
| 24 | |
| 25 | <!-- Index link --> |
| 26 | <th> <a |
| 27 | href="identifier-index.html">Indices</a> </th> |
| 28 | |
| 29 | <!-- Help link --> |
| 30 | <th> <a |
| 31 | href="help.html">Help</a> </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 TestON</a> :: |
| 46 | <a href="TestON.drivers-module.html">Package drivers</a> :: |
| 47 | <a href="TestON.drivers.common-module.html">Package common</a> :: |
| 48 | <a href="TestON.drivers.common.cli-module.html">Package cli</a> :: |
| 49 | Module onosdriver |
| 50 | </span> |
| 51 | </td> |
| 52 | <td> |
| 53 | <table cellpadding="0" cellspacing="0"> |
| 54 | <!-- hide/show private --> |
| 55 | <tr><td align="right"><span class="options">[<a href="javascript:void(0);" class="privatelink" |
| 56 | onclick="toggle_private();">hide private</a>]</span></td></tr> |
| 57 | <tr><td align="right"><span class="options" |
| 58 | >[<a href="frames.html" target="_top">frames</a |
| 59 | >] | <a href="TestON.drivers.common.cli.onosdriver-pysrc.html" |
| 60 | target="_top">no frames</a>]</span></td></tr> |
| 61 | </table> |
| 62 | </td> |
| 63 | </tr> |
| 64 | </table> |
| 65 | <h1 class="epydoc">Source Code for <a href="TestON.drivers.common.cli.onosdriver-module.html">Module TestON.drivers.common.cli.onosdriver</a></h1> |
| 66 | <pre class="py-src"> |
| 67 | <a name="L1"></a><tt class="py-lineno"> 1</tt> <tt class="py-line"><tt class="py-comment">#!/usr/bin/env python</tt> </tt> |
| 68 | <a name="L2"></a><tt class="py-lineno"> 2</tt> <tt class="py-line"> </tt> |
| 69 | <a name="L3"></a><tt class="py-lineno"> 3</tt> <tt class="py-line"><tt class="py-docstring">"""</tt> </tt> |
| 70 | <a name="L4"></a><tt class="py-lineno"> 4</tt> <tt class="py-line"><tt class="py-docstring">This driver interacts with ONOS bench, the OSGi platform</tt> </tt> |
| 71 | <a name="L5"></a><tt class="py-lineno"> 5</tt> <tt class="py-line"><tt class="py-docstring">that configures the ONOS nodes. ( aka ONOS-next )</tt> </tt> |
| 72 | <a name="L6"></a><tt class="py-lineno"> 6</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 73 | <a name="L7"></a><tt class="py-lineno"> 7</tt> <tt class="py-line"><tt class="py-docstring">Please follow the coding style demonstrated by existing</tt> </tt> |
| 74 | <a name="L8"></a><tt class="py-lineno"> 8</tt> <tt class="py-line"><tt class="py-docstring">functions and document properly.</tt> </tt> |
| 75 | <a name="L9"></a><tt class="py-lineno"> 9</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 76 | <a name="L10"></a><tt class="py-lineno"> 10</tt> <tt class="py-line"><tt class="py-docstring">If you are a contributor to the driver, please</tt> </tt> |
| 77 | <a name="L11"></a><tt class="py-lineno"> 11</tt> <tt class="py-line"><tt class="py-docstring">list your email here for future contact:</tt> </tt> |
| 78 | <a name="L12"></a><tt class="py-lineno"> 12</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 79 | <a name="L13"></a><tt class="py-lineno"> 13</tt> <tt class="py-line"><tt class="py-docstring">jhall@onlab.us</tt> </tt> |
| 80 | <a name="L14"></a><tt class="py-lineno"> 14</tt> <tt class="py-line"><tt class="py-docstring">andrew@onlab.us</tt> </tt> |
| 81 | <a name="L15"></a><tt class="py-lineno"> 15</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 82 | <a name="L16"></a><tt class="py-lineno"> 16</tt> <tt class="py-line"><tt class="py-docstring">OCT 9 2014</tt> </tt> |
| 83 | <a name="L17"></a><tt class="py-lineno"> 17</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 84 | <a name="L18"></a><tt class="py-lineno"> 18</tt> <tt class="py-line"><tt class="py-docstring">"""</tt> </tt> |
| 85 | <a name="L19"></a><tt class="py-lineno"> 19</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt> |
| 86 | <a name="L20"></a><tt class="py-lineno"> 20</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">types</tt> </tt> |
| 87 | <a name="L21"></a><tt class="py-lineno"> 21</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">pexpect</tt> </tt> |
| 88 | <a name="L22"></a><tt class="py-lineno"> 22</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">os</tt> </tt> |
| 89 | <a name="L23"></a><tt class="py-lineno"> 23</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt id="link-0" class="py-name" targets="Variable TestON.bin.cli.path=TestON.bin.cli-module.html#path,Variable TestON.core.teston.path=TestON.core.teston-module.html#path"><a title="TestON.bin.cli.path |
| 90 | TestON.core.teston.path" class="py-name" href="#" onclick="return doclink('link-0', 'path', 'link-0');">path</a></tt> </tt> |
| 91 | <a name="L24"></a><tt class="py-lineno"> 24</tt> <tt class="py-line"><tt class="py-keyword">from</tt> <tt class="py-name">requests</tt><tt class="py-op">.</tt><tt class="py-name">models</tt> <tt class="py-keyword">import</tt> <tt class="py-name">Response</tt> </tt> |
| 92 | <a name="L25"></a><tt class="py-lineno"> 25</tt> <tt class="py-line"><tt class="py-keyword">from</tt> <tt id="link-1" class="py-name" targets="Package TestON.drivers=TestON.drivers-module.html"><a title="TestON.drivers" class="py-name" href="#" onclick="return doclink('link-1', 'drivers', 'link-1');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-2" class="py-name" targets="Package TestON.drivers.common=TestON.drivers.common-module.html"><a title="TestON.drivers.common" class="py-name" href="#" onclick="return doclink('link-2', 'common', 'link-2');">common</a></tt><tt class="py-op">.</tt><tt id="link-3" class="py-name" targets="Module TestON.drivers.common.clidriver=TestON.drivers.common.clidriver-module.html"><a title="TestON.drivers.common.clidriver" class="py-name" href="#" onclick="return doclink('link-3', 'clidriver', 'link-3');">clidriver</a></tt> <tt class="py-keyword">import</tt> <tt id="link-4" class="py-name" targets="Class TestON.bin.cli.CLI=TestON.bin.cli.CLI-class.html,Class TestON.drivers.common.clidriver.CLI=TestON.drivers.common.clidriver.CLI-class.html"><a title="TestON.bin.cli.CLI |
| 93 | TestON.drivers.common.clidriver.CLI" class="py-name" href="#" onclick="return doclink('link-4', 'CLI', 'link-4');">CLI</a></tt> </tt> |
| 94 | <a name="L26"></a><tt class="py-lineno"> 26</tt> <tt class="py-line"> </tt> |
| 95 | <a name="L27"></a><tt class="py-lineno"> 27</tt> <tt class="py-line"> </tt> |
| 96 | <a name="OnosDriver"></a><div id="OnosDriver-def"><a name="L28"></a><tt class="py-lineno"> 28</tt> <a class="py-toggle" href="#" id="OnosDriver-toggle" onclick="return toggle('OnosDriver');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html">OnosDriver</a><tt class="py-op">(</tt> <tt class="py-base-class">CLI</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 97 | </div><div id="OnosDriver-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="OnosDriver-expanded"><a name="L29"></a><tt class="py-lineno"> 29</tt> <tt class="py-line"> </tt> |
| 98 | <a name="OnosDriver.__init__"></a><div id="OnosDriver.__init__-def"><a name="L30"></a><tt class="py-lineno"> 30</tt> <a class="py-toggle" href="#" id="OnosDriver.__init__-toggle" onclick="return toggle('OnosDriver.__init__');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-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> |
| 99 | </div><div id="OnosDriver.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.__init__-expanded"><a name="L31"></a><tt class="py-lineno"> 31</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 100 | <a name="L32"></a><tt class="py-lineno"> 32</tt> <tt class="py-line"><tt class="py-docstring"> Initialize client</tt> </tt> |
| 101 | <a name="L33"></a><tt class="py-lineno"> 33</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 102 | <a name="L34"></a><tt class="py-lineno"> 34</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> |
| 103 | <a name="L35"></a><tt class="py-lineno"> 35</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> |
| 104 | <a name="L36"></a><tt class="py-lineno"> 36</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> |
| 105 | <a name="L37"></a><tt class="py-lineno"> 37</tt> <tt class="py-line"> <tt class="py-name">super</tt><tt class="py-op">(</tt> <tt id="link-5" class="py-name"><a title="TestON.bin.cli.CLI |
| 106 | TestON.drivers.common.clidriver.CLI" class="py-name" href="#" onclick="return doclink('link-5', 'CLI', 'link-4');">CLI</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-6" class="py-name" targets="Method TestON.bin.cli.CLI.__init__()=TestON.bin.cli.CLI-class.html#__init__,Method TestON.bin.cli.TestThread.__init__()=TestON.bin.cli.TestThread-class.html#__init__,Method TestON.bin.generatedriver.GenerateDriver.__init__()=TestON.bin.generatedriver.GenerateDriver-class.html#__init__,Method TestON.bin.nec.NEC.__init__()=TestON.bin.nec.NEC-class.html#__init__,Method TestON.bin.updatedriver.UpdateDriver.__init__()=TestON.bin.updatedriver.UpdateDriver-class.html#__init__,Method TestON.bin.vyatta.Vyatta.__init__()=TestON.bin.vyatta.Vyatta-class.html#__init__,Method TestON.core.Thread.Thread.__init__()=TestON.core.Thread.Thread-class.html#__init__,Method TestON.core.dicttoobject.DictToObject.__init__()=TestON.core.dicttoobject.DictToObject-class.html#__init__,Method TestON.core.iniparser.iniparser.__init__()=TestON.core.iniparser.iniparser-class.html#__init__,Method TestON.core.jsonparser.JsonParser.__init__()=TestON.core.jsonparser.JsonParser-class.html#__init__,Method TestON.core.openspeak.OpenSpeak.__init__()=TestON.core.openspeak.OpenSpeak-class.html#__init__,Method TestON.core.teston.TestON.__init__()=TestON.core.teston.TestON-class.html#__init__,Method TestON.core.testparser.TestParser.__init__()=TestON.core.testparser.TestParser-class.html#__init__,Method TestON.core.xmlparser.xmlparser.__init__()=TestON.core.xmlparser.xmlparser-class.html#__init__,Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.__init__()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#__init__,Method TestON.drivers.common.api.controllerdriver.Controller.__init__()=TestON.drivers.common.api.controllerdriver.Controller-class.html#__init__,Method TestON.drivers.common.api.fvtapidriver.FvtApiDriver.__init__()=TestON.drivers.common.api.fvtapidriver.FvtApiDriver-class.html#__init__,Method TestON.drivers.common.apidriver.API.__init__()=TestON.drivers.common.apidriver.API-class.html#__init__,Method TestON.drivers.common.cli.dpclidriver.DPCliDriver.__init__()=TestON.drivers.common.cli.dpclidriver.DPCliDriver-class.html#__init__,Method TestON.drivers.common.cli.emulator.flowvisordriver.FlowVisorDriver.__init__()=TestON.drivers.common.cli.emulator.flowvisordriver.FlowVisorDriver-class.html#__init__,Method TestON.drivers.common.cli.emulator.lincoedriver.LincOEDriver.__init__()=TestON.drivers.common.cli.emulator.lincoedriver.LincOEDriver-class.html#__init__,Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.__init__()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#__init__,Method TestON.drivers.common.cli.emulator.poxclidriver.PoxCliDriver.__init__()=TestON.drivers.common.cli.emulator.poxclidriver.PoxCliDriver-class.html#__init__,Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.__init__()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#__init__,Method TestON.drivers.common.cli.emulatordriver.Emulator.__init__()=TestON.drivers.common.cli.emulatordriver.Emulator-class.html#__init__,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.__init__()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#__init__,Method TestON.drivers.common.cli.onosdriver.OnosDriver.__init__()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#__init__,Method TestON.drivers.common.cli.quaggaclidriver.QuaggaCliDriver.__init__()=TestON.drivers.common.cli.quaggaclidriver.QuaggaCliDriver-class.html#__init__,Method TestON.drivers.common.cli.remotesysdriver.RemoteSysDriver.__init__()=TestON.drivers.common.cli.remotesysdriver.RemoteSysDriver-class.html#__init__,Method TestON.drivers.common.cli.remotetestbed.floodlightclidriver.FloodLightCliDriver.__init__()=TestON.drivers.common.cli.remotetestbed.floodlightclidriver.FloodLightCliDriver-class.html#__init__,Method TestON.drivers.common.cli.remotetestbed.necswitchdriver.NEC.__init__()=TestON.drivers.common.cli.remotetestbed.necswitchdriver.NEC-class.html#__init__,Method TestON.drivers.common.cli.remotetestbed.remotepoxdriver.RemotePoxDriver.__init__()=TestON.drivers.common.cli.remotetestbed.remotepoxdriver.RemotePoxDriver-class.html#__init__,Method TestON.drivers.common.cli.remotetestbed.remotevmdriver.RemoteVMDriver.__init__()=TestON.drivers.common.cli.remotetestbed.remotevmdriver.RemoteVMDriver-class.html#__init__,Method TestON.drivers.common.cli.remotetestbeddriver.RemoteTestBedDriver.__init__()=TestON.drivers.common.cli.remotetestbeddriver.RemoteTestBedDriver-class.html#__init__,Method TestON.drivers.common.cli.tool.dpctlclidriver.DpctlCliDriver.__init__()=TestON.drivers.common.cli.tool.dpctlclidriver.DpctlCliDriver-class.html#__init__,Method TestON.drivers.common.cli.toolsdriver.Tools.__init__()=TestON.drivers.common.cli.toolsdriver.Tools-class.html#__init__,Method TestON.drivers.common.clidriver.CLI.__init__()=TestON.drivers.common.clidriver.CLI-class.html#__init__,Method TestON.examples.Assert.Assert.Assert.__init__()=TestON.examples.Assert.Assert.Assert-class.html#__init__,Method TestON.examples.CaseParams.CaseParams.CaseParams.__init__()=TestON.examples.CaseParams.CaseParams.CaseParams-class.html#__init__,Method TestON.examples.ExperimentTest.ExperimentTest.ExperimentTest.__init__()=TestON.examples.ExperimentTest.ExperimentTest.ExperimentTest-class.html#__init__,Method TestON.examples.StepParams.StepParams.StepParams.__init__()=TestON.examples.StepParams.StepParams.StepParams-class.html#__init__,Method TestON.examples.Topology.Topology.Topology.__init__()=TestON.examples.Topology.Topology.Topology-class.html#__init__,Method TestON.tests.CHOtest.CHOtest.CHOtest.__init__()=TestON.tests.CHOtest.CHOtest.CHOtest-class.html#__init__,Method TestON.tests.FUNCintent.FUNCintent.FUNCintent.__init__()=TestON.tests.FUNCintent.FUNCintent.FUNCintent-class.html#__init__,Method TestON.tests.HAclusterRestart.HAclusterRestart.HAclusterRestart.__init__()=TestON.tests.HAclusterRestart.HAclusterRestart.HAclusterRestart-class.html#__init__,Function TestON.tests.HAclusterRestart.dependencies.Counters.__init__()=TestON.tests.HAclusterRestart.dependencies.Counters-module.html#__init__,Method TestON.tests.HAclusterRestart.dependencies.obelisk.ObeliskTopo.__init__()=TestON.tests.HAclusterRestart.dependencies.obelisk.ObeliskTopo-class.html#__init__,Method TestON.tests.HAminorityRestart.HAminorityRestart.HAminorityRestart.__init__()=TestON.tests.HAminorityRestart.HAminorityRestart.HAminorityRestart-class.html#__init__,Function TestON.tests.HAminorityRestart.dependencies.Counters.__init__()=TestON.tests.HAminorityRestart.dependencies.Counters-module.html#__init__,Method TestON.tests.HAminorityRestart.dependencies.obelisk.ObeliskTopo.__init__()=TestON.tests.HAminorityRestart.dependencies.obelisk.ObeliskTopo-class.html#__init__,Method TestON.tests.HAsanity.HAsanity.HAsanity.__init__()=TestON.tests.HAsanity.HAsanity.HAsanity-class.html#__init__,Function TestON.tests.HAsanity.dependencies.Counters.__init__()=TestON.tests.HAsanity.dependencies.Counters-module.html#__init__,Method TestON.tests.HAsanity.dependencies.obelisk.ObeliskTopo.__init__()=TestON.tests.HAsanity.dependencies.obelisk.ObeliskTopo-class.html#__init__,Method TestON.tests.HAsingleInstanceRestart.HAsingleInstanceRestart.HAsingleInstanceRestart.__init__()=TestON.tests.HAsingleInstanceRestart.HAsingleInstanceRestart.HAsingleInstanceRestart-class.html#__init__,Function TestON.tests.HAsingleInstanceRestart.dependencies.Counters.__init__()=TestON.tests.HAsingleInstanceRestart.dependencies.Counters-module.html#__init__,Method TestON.tests.HAsingleInstanceRestart.dependencies.obelisk.ObeliskTopo.__init__()=TestON.tests.HAsingleInstanceRestart.dependencies.obelisk.ObeliskTopo-class.html#__init__,Method TestON.tests.SAMPscaleTopo.SAMPscaleTopo.SAMPscaleTopo.__init__()=TestON.tests.SAMPscaleTopo.SAMPscaleTopo.SAMPscaleTopo-class.html#__init__,Method TestON.tests.SAMPstartTemplate.SAMPstartTemplate.SAMPstartTemplate.__init__()=TestON.tests.SAMPstartTemplate.SAMPstartTemplate.SAMPstartTemplate-class.html#__init__,Method TestON.tests.SCPFcbench.SCPFcbench.SCPFcbench.__init__()=TestON.tests.SCPFcbench.SCPFcbench.SCPFcbench-class.html#__init__,Method TestON.tests.SCPFflowTp1g.SCPFflowTp1g.SCPFflowTp1g.__init__()=TestON.tests.SCPFflowTp1g.SCPFflowTp1g.SCPFflowTp1g-class.html#__init__,Method TestON.tests.SCPFintentEventTp.SCPFintentEventTp.SCPFintentEventTp.__init__()=TestON.tests.SCPFintentEventTp.SCPFintentEventTp.SCPFintentEventTp-class.html#__init__,Method TestON.tests.SCPFintentInstallWithdrawLat.SCPFintentInstallWithdrawLat.SCPFintentInstallWithdrawLat.__init__()=TestON.tests.SCPFintentInstallWithdrawLat.SCPFintentInstallWithdrawLat.SCPFintentInstallWithdrawLat-class.html#__init__,Method TestON.tests.SCPFintentRerouteLat.SCPFintentRerouteLat.SCPFintentRerouteLat.__init__()=TestON.tests.SCPFintentRerouteLat.SCPFintentRerouteLat.SCPFintentRerouteLat-class.html#__init__,Method TestON.tests.SCPFportLat.SCPFportLat.SCPFportLat.__init__()=TestON.tests.SCPFportLat.SCPFportLat.SCPFportLat-class.html#__init__,Method TestON.tests.SCPFswitchLat.SCPFswitchLat.SCPFswitchLat.__init__()=TestON.tests.SCPFswitchLat.SCPFswitchLat.SCPFswitchLat-class.html#__init__"><a title="TestON.bin.cli.CLI.__init__ |
| 107 | TestON.bin.cli.TestThread.__init__ |
| 108 | TestON.bin.generatedriver.GenerateDriver.__init__ |
| 109 | TestON.bin.nec.NEC.__init__ |
| 110 | TestON.bin.updatedriver.UpdateDriver.__init__ |
| 111 | TestON.bin.vyatta.Vyatta.__init__ |
| 112 | TestON.core.Thread.Thread.__init__ |
| 113 | TestON.core.dicttoobject.DictToObject.__init__ |
| 114 | TestON.core.iniparser.iniparser.__init__ |
| 115 | TestON.core.jsonparser.JsonParser.__init__ |
| 116 | TestON.core.openspeak.OpenSpeak.__init__ |
| 117 | TestON.core.teston.TestON.__init__ |
| 118 | TestON.core.testparser.TestParser.__init__ |
| 119 | TestON.core.xmlparser.xmlparser.__init__ |
| 120 | TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.__init__ |
| 121 | TestON.drivers.common.api.controllerdriver.Controller.__init__ |
| 122 | TestON.drivers.common.api.fvtapidriver.FvtApiDriver.__init__ |
| 123 | TestON.drivers.common.apidriver.API.__init__ |
| 124 | TestON.drivers.common.cli.dpclidriver.DPCliDriver.__init__ |
| 125 | TestON.drivers.common.cli.emulator.flowvisordriver.FlowVisorDriver.__init__ |
| 126 | TestON.drivers.common.cli.emulator.lincoedriver.LincOEDriver.__init__ |
| 127 | TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.__init__ |
| 128 | TestON.drivers.common.cli.emulator.poxclidriver.PoxCliDriver.__init__ |
| 129 | TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.__init__ |
| 130 | TestON.drivers.common.cli.emulatordriver.Emulator.__init__ |
| 131 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.__init__ |
| 132 | TestON.drivers.common.cli.onosdriver.OnosDriver.__init__ |
| 133 | TestON.drivers.common.cli.quaggaclidriver.QuaggaCliDriver.__init__ |
| 134 | TestON.drivers.common.cli.remotesysdriver.RemoteSysDriver.__init__ |
| 135 | TestON.drivers.common.cli.remotetestbed.floodlightclidriver.FloodLightCliDriver.__init__ |
| 136 | TestON.drivers.common.cli.remotetestbed.necswitchdriver.NEC.__init__ |
| 137 | TestON.drivers.common.cli.remotetestbed.remotepoxdriver.RemotePoxDriver.__init__ |
| 138 | TestON.drivers.common.cli.remotetestbed.remotevmdriver.RemoteVMDriver.__init__ |
| 139 | TestON.drivers.common.cli.remotetestbeddriver.RemoteTestBedDriver.__init__ |
| 140 | TestON.drivers.common.cli.tool.dpctlclidriver.DpctlCliDriver.__init__ |
| 141 | TestON.drivers.common.cli.toolsdriver.Tools.__init__ |
| 142 | TestON.drivers.common.clidriver.CLI.__init__ |
| 143 | TestON.examples.Assert.Assert.Assert.__init__ |
| 144 | TestON.examples.CaseParams.CaseParams.CaseParams.__init__ |
| 145 | TestON.examples.ExperimentTest.ExperimentTest.ExperimentTest.__init__ |
| 146 | TestON.examples.StepParams.StepParams.StepParams.__init__ |
| 147 | TestON.examples.Topology.Topology.Topology.__init__ |
| 148 | TestON.tests.CHOtest.CHOtest.CHOtest.__init__ |
| 149 | TestON.tests.FUNCintent.FUNCintent.FUNCintent.__init__ |
| 150 | TestON.tests.HAclusterRestart.HAclusterRestart.HAclusterRestart.__init__ |
| 151 | TestON.tests.HAclusterRestart.dependencies.Counters.__init__ |
| 152 | TestON.tests.HAclusterRestart.dependencies.obelisk.ObeliskTopo.__init__ |
| 153 | TestON.tests.HAminorityRestart.HAminorityRestart.HAminorityRestart.__init__ |
| 154 | TestON.tests.HAminorityRestart.dependencies.Counters.__init__ |
| 155 | TestON.tests.HAminorityRestart.dependencies.obelisk.ObeliskTopo.__init__ |
| 156 | TestON.tests.HAsanity.HAsanity.HAsanity.__init__ |
| 157 | TestON.tests.HAsanity.dependencies.Counters.__init__ |
| 158 | TestON.tests.HAsanity.dependencies.obelisk.ObeliskTopo.__init__ |
| 159 | TestON.tests.HAsingleInstanceRestart.HAsingleInstanceRestart.HAsingleInstanceRestart.__init__ |
| 160 | TestON.tests.HAsingleInstanceRestart.dependencies.Counters.__init__ |
| 161 | TestON.tests.HAsingleInstanceRestart.dependencies.obelisk.ObeliskTopo.__init__ |
| 162 | TestON.tests.SAMPscaleTopo.SAMPscaleTopo.SAMPscaleTopo.__init__ |
| 163 | TestON.tests.SAMPstartTemplate.SAMPstartTemplate.SAMPstartTemplate.__init__ |
| 164 | TestON.tests.SCPFcbench.SCPFcbench.SCPFcbench.__init__ |
| 165 | TestON.tests.SCPFflowTp1g.SCPFflowTp1g.SCPFflowTp1g.__init__ |
| 166 | TestON.tests.SCPFintentEventTp.SCPFintentEventTp.SCPFintentEventTp.__init__ |
| 167 | TestON.tests.SCPFintentInstallWithdrawLat.SCPFintentInstallWithdrawLat.SCPFintentInstallWithdrawLat.__init__ |
| 168 | TestON.tests.SCPFintentRerouteLat.SCPFintentRerouteLat.SCPFintentRerouteLat.__init__ |
| 169 | TestON.tests.SCPFportLat.SCPFportLat.SCPFportLat.__init__ |
| 170 | TestON.tests.SCPFswitchLat.SCPFswitchLat.SCPFswitchLat.__init__" class="py-name" href="#" onclick="return doclink('link-6', '__init__', 'link-6');">__init__</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 171 | </div><a name="L38"></a><tt class="py-lineno"> 38</tt> <tt class="py-line"> </tt> |
| 172 | <a name="OnosDriver.connect"></a><div id="OnosDriver.connect-def"><a name="L39"></a><tt class="py-lineno"> 39</tt> <a class="py-toggle" href="#" id="OnosDriver.connect-toggle" onclick="return toggle('OnosDriver.connect');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#connect">connect</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">connectargs</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 173 | </div><div id="OnosDriver.connect-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.connect-expanded"><a name="L40"></a><tt class="py-lineno"> 40</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 174 | <a name="L41"></a><tt class="py-lineno"> 41</tt> <tt class="py-line"><tt class="py-docstring"> Creates ssh handle for ONOS "bench".</tt> </tt> |
| 175 | <a name="L42"></a><tt class="py-lineno"> 42</tt> <tt class="py-line"><tt class="py-docstring"> NOTE:</tt> </tt> |
| 176 | <a name="L43"></a><tt class="py-lineno"> 43</tt> <tt class="py-line"><tt class="py-docstring"> The ip_address would come from the topo file using the host tag, the</tt> </tt> |
| 177 | <a name="L44"></a><tt class="py-lineno"> 44</tt> <tt class="py-line"><tt class="py-docstring"> value can be an environment variable as well as a "localhost" to get</tt> </tt> |
| 178 | <a name="L45"></a><tt class="py-lineno"> 45</tt> <tt class="py-line"><tt class="py-docstring"> the ip address needed to ssh to the "bench"</tt> </tt> |
| 179 | <a name="L46"></a><tt class="py-lineno"> 46</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 180 | <a name="L47"></a><tt class="py-lineno"> 47</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 181 | <a name="L48"></a><tt class="py-lineno"> 48</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">connectargs</tt><tt class="py-op">:</tt> </tt> |
| 182 | <a name="L49"></a><tt class="py-lineno"> 49</tt> <tt class="py-line"> <tt class="py-name">vars</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt> <tt class="py-op">)</tt><tt class="py-op">[</tt> <tt class="py-name">key</tt> <tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">connectargs</tt><tt class="py-op">[</tt> <tt class="py-name">key</tt> <tt class="py-op">]</tt> </tt> |
| 183 | <a name="L50"></a><tt class="py-lineno"> 50</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">=</tt> <tt class="py-string">"~/onos"</tt> </tt> |
| 184 | <a name="L51"></a><tt class="py-lineno"> 51</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">options</tt><tt class="py-op">:</tt> </tt> |
| 185 | <a name="L52"></a><tt class="py-lineno"> 52</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-op">==</tt> <tt class="py-string">"home"</tt><tt class="py-op">:</tt> </tt> |
| 186 | <a name="L53"></a><tt class="py-lineno"> 53</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">options</tt><tt class="py-op">[</tt> <tt class="py-string">'home'</tt> <tt class="py-op">]</tt> </tt> |
| 187 | <a name="L54"></a><tt class="py-lineno"> 54</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt> |
| 188 | <a name="L55"></a><tt class="py-lineno"> 55</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">==</tt> <tt class="py-string">""</tt><tt class="py-op">:</tt> </tt> |
| 189 | <a name="L56"></a><tt class="py-lineno"> 56</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">=</tt> <tt class="py-string">"~/onos"</tt> </tt> |
| 190 | <a name="L57"></a><tt class="py-lineno"> 57</tt> <tt class="py-line"> </tt> |
| 191 | <a name="L58"></a><tt class="py-lineno"> 58</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">options</tt><tt class="py-op">[</tt> <tt class="py-string">'name'</tt> <tt class="py-op">]</tt> </tt> |
| 192 | <a name="L59"></a><tt class="py-lineno"> 59</tt> <tt class="py-line"> </tt> |
| 193 | <a name="L60"></a><tt class="py-lineno"> 60</tt> <tt class="py-line"> <tt class="py-comment"># The 'nodes' tag is optional and it is not required in .topo file</tt> </tt> |
| 194 | <a name="L61"></a><tt class="py-lineno"> 61</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">options</tt><tt class="py-op">:</tt> </tt> |
| 195 | <a name="L62"></a><tt class="py-lineno"> 62</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-op">==</tt> <tt class="py-string">"nodes"</tt><tt class="py-op">:</tt> </tt> |
| 196 | <a name="L63"></a><tt class="py-lineno"> 63</tt> <tt class="py-line"> <tt class="py-comment"># Maximum number of ONOS nodes to run, if there is any</tt> </tt> |
| 197 | <a name="L64"></a><tt class="py-lineno"> 64</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">options</tt><tt class="py-op">[</tt> <tt class="py-string">'nodes'</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt> |
| 198 | <a name="L65"></a><tt class="py-lineno"> 65</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt> |
| 199 | <a name="L66"></a><tt class="py-lineno"> 66</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> |
| 200 | <a name="L67"></a><tt class="py-lineno"> 67</tt> <tt class="py-line"> </tt> |
| 201 | <a name="L68"></a><tt class="py-lineno"> 68</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">==</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">==</tt> <tt class="py-string">""</tt><tt class="py-op">:</tt> </tt> |
| 202 | <a name="L69"></a><tt class="py-lineno"> 69</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">=</tt> <tt class="py-number">100</tt> </tt> |
| 203 | <a name="L70"></a><tt class="py-lineno"> 70</tt> <tt class="py-line"> </tt> |
| 204 | <a name="L71"></a><tt class="py-lineno"> 71</tt> <tt class="py-line"> </tt> |
| 205 | <a name="L72"></a><tt class="py-lineno"> 72</tt> <tt class="py-line"> <tt class="py-comment"># Grabs all OC environment variables based on max number of nodes</tt> </tt> |
| 206 | <a name="L73"></a><tt class="py-lineno"> 73</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">onosIps</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> <tt class="py-comment"># Dictionary of all possible ONOS ip</tt> </tt> |
| 207 | <a name="L74"></a><tt class="py-lineno"> 74</tt> <tt class="py-line"> </tt> |
| 208 | <a name="L75"></a><tt class="py-lineno"> 75</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 209 | <a name="L76"></a><tt class="py-lineno"> 76</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt><tt class="py-op">:</tt> </tt> |
| 210 | <a name="L77"></a><tt class="py-lineno"> 77</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">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 211 | <a name="L78"></a><tt class="py-lineno"> 78</tt> <tt class="py-line"> <tt class="py-name">envString</tt> <tt class="py-op">=</tt> <tt class="py-string">"OC"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> <tt class="py-op">)</tt> </tt> |
| 212 | <a name="L79"></a><tt class="py-lineno"> 79</tt> <tt class="py-line"> <tt class="py-comment"># If there is no more OC# then break the loop</tt> </tt> |
| 213 | <a name="L80"></a><tt class="py-lineno"> 80</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">getenv</tt><tt class="py-op">(</tt> <tt class="py-name">envString</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 214 | <a name="L81"></a><tt class="py-lineno"> 81</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">onosIps</tt><tt class="py-op">[</tt> <tt class="py-name">envString</tt> <tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">getenv</tt><tt class="py-op">(</tt> <tt class="py-name">envString</tt> <tt class="py-op">)</tt> </tt> |
| 215 | <a name="L82"></a><tt class="py-lineno"> 82</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 216 | <a name="L83"></a><tt class="py-lineno"> 83</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">onosIps</tt> <tt class="py-op">)</tt> </tt> |
| 217 | <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-7" 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-7', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 218 | <a name="L85"></a><tt class="py-lineno"> 85</tt> <tt class="py-line"> <tt class="py-string">": Created cluster data with "</tt> <tt class="py-op">+</tt> </tt> |
| 219 | <a name="L86"></a><tt class="py-lineno"> 86</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 220 | <a name="L87"></a><tt class="py-lineno"> 87</tt> <tt class="py-line"> <tt class="py-string">" maximum number"</tt> <tt class="py-op">+</tt> </tt> |
| 221 | <a name="L88"></a><tt class="py-lineno"> 88</tt> <tt class="py-line"> <tt class="py-string">" of nodes"</tt> <tt class="py-op">)</tt> </tt> |
| 222 | <a name="L89"></a><tt class="py-lineno"> 89</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt> |
| 223 | <a name="L90"></a><tt class="py-lineno"> 90</tt> <tt class="py-line"> </tt> |
| 224 | <a name="L91"></a><tt class="py-lineno"> 91</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">onosIps</tt><tt class="py-op">:</tt> </tt> |
| 225 | <a name="L92"></a><tt class="py-lineno"> 92</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-8" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-8', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Could not read any environment variable"</tt> </tt> |
| 226 | <a name="L93"></a><tt class="py-lineno"> 93</tt> <tt class="py-line"> <tt class="py-op">+</tt> <tt class="py-string">" please load a cell file with all"</tt> <tt class="py-op">+</tt> </tt> |
| 227 | <a name="L94"></a><tt class="py-lineno"> 94</tt> <tt class="py-line"> <tt class="py-string">" onos IP"</tt> <tt class="py-op">)</tt> </tt> |
| 228 | <a name="L95"></a><tt class="py-lineno"> 95</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">maxNodes</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> |
| 229 | <a name="L96"></a><tt class="py-lineno"> 96</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 230 | <a name="L97"></a><tt class="py-lineno"> 97</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-9" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-9', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Found "</tt> <tt class="py-op">+</tt> </tt> |
| 231 | <a name="L98"></a><tt class="py-lineno"> 98</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">onosIps</tt><tt class="py-op">.</tt><tt class="py-name">values</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 232 | <a name="L99"></a><tt class="py-lineno"> 99</tt> <tt class="py-line"> <tt class="py-string">" ONOS IPs"</tt> <tt class="py-op">)</tt> </tt> |
| 233 | <a name="L100"></a><tt class="py-lineno"> 100</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">KeyError</tt><tt class="py-op">:</tt> </tt> |
| 234 | <a name="L101"></a><tt class="py-lineno"> 101</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-10" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-10', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Invalid environment variable"</tt> <tt class="py-op">)</tt> </tt> |
| 235 | <a name="L102"></a><tt class="py-lineno"> 102</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt> <tt class="py-keyword">as</tt> <tt class="py-name">inst</tt><tt class="py-op">:</tt> </tt> |
| 236 | <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-11" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-11', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-12" 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-12', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Uncaught exception: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">inst</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 237 | <a name="L104"></a><tt class="py-lineno"> 104</tt> <tt class="py-line"> </tt> |
| 238 | <a name="L105"></a><tt class="py-lineno"> 105</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 239 | <a name="L106"></a><tt class="py-lineno"> 106</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">getenv</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">!=</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt> |
| 240 | <a name="L107"></a><tt class="py-lineno"> 107</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">getenv</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 241 | <a name="L108"></a><tt class="py-lineno"> 108</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 242 | <a name="L109"></a><tt class="py-lineno"> 109</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-13" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-13', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 243 | <a name="L110"></a><tt class="py-lineno"> 110</tt> <tt class="py-line"> <tt class="py-string">": Trying to connect to "</tt> <tt class="py-op">+</tt> </tt> |
| 244 | <a name="L111"></a><tt class="py-lineno"> 111</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">)</tt> </tt> |
| 245 | <a name="L112"></a><tt class="py-lineno"> 112</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">KeyError</tt><tt class="py-op">:</tt> </tt> |
| 246 | <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-14" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-14', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Invalid host name,"</tt> <tt class="py-op">+</tt> </tt> |
| 247 | <a name="L114"></a><tt class="py-lineno"> 114</tt> <tt class="py-line"> <tt class="py-string">" connecting to local host instead"</tt> <tt class="py-op">)</tt> </tt> |
| 248 | <a name="L115"></a><tt class="py-lineno"> 115</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">=</tt> <tt class="py-string">'localhost'</tt> </tt> |
| 249 | <a name="L116"></a><tt class="py-lineno"> 116</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt> <tt class="py-keyword">as</tt> <tt class="py-name">inst</tt><tt class="py-op">:</tt> </tt> |
| 250 | <a name="L117"></a><tt class="py-lineno"> 117</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-16" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-16', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Uncaught exception: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">inst</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 251 | <a name="L118"></a><tt class="py-lineno"> 118</tt> <tt class="py-line"> </tt> |
| 252 | <a name="L119"></a><tt class="py-lineno"> 119</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt> <tt class="py-op">=</tt> <tt class="py-name">super</tt><tt class="py-op">(</tt> <tt id="link-17" class="py-name" targets="Class TestON.drivers.common.cli.onosdriver.OnosDriver=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver" class="py-name" href="#" onclick="return doclink('link-17', 'OnosDriver', 'link-17');">OnosDriver</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt> <tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-18" class="py-name" targets="Method TestON.bin.generatedriver.GenerateDriver.connect()=TestON.bin.generatedriver.GenerateDriver-class.html#connect,Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.connect()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#connect,Method TestON.drivers.common.api.fvtapidriver.FvtApiDriver.connect()=TestON.drivers.common.api.fvtapidriver.FvtApiDriver-class.html#connect,Method TestON.drivers.common.apidriver.API.connect()=TestON.drivers.common.apidriver.API-class.html#connect,Method TestON.drivers.common.cli.dpclidriver.DPCliDriver.connect()=TestON.drivers.common.cli.dpclidriver.DPCliDriver-class.html#connect,Method TestON.drivers.common.cli.emulator.flowvisordriver.FlowVisorDriver.connect()=TestON.drivers.common.cli.emulator.flowvisordriver.FlowVisorDriver-class.html#connect,Method TestON.drivers.common.cli.emulator.lincoedriver.LincOEDriver.connect()=TestON.drivers.common.cli.emulator.lincoedriver.LincOEDriver-class.html#connect,Method TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.connect()=TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver-class.html#connect,Method TestON.drivers.common.cli.emulator.poxclidriver.PoxCliDriver.connect()=TestON.drivers.common.cli.emulator.poxclidriver.PoxCliDriver-class.html#connect,Method TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.connect()=TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver-class.html#connect,Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.connect()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#connect,Method TestON.drivers.common.cli.onosdriver.OnosDriver.connect()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#connect,Method TestON.drivers.common.cli.quaggaclidriver.QuaggaCliDriver.connect()=TestON.drivers.common.cli.quaggaclidriver.QuaggaCliDriver-class.html#connect,Method TestON.drivers.common.cli.remotesysdriver.RemoteSysDriver.connect()=TestON.drivers.common.cli.remotesysdriver.RemoteSysDriver-class.html#connect,Method TestON.drivers.common.cli.remotetestbed.floodlightclidriver.FloodLightCliDriver.connect()=TestON.drivers.common.cli.remotetestbed.floodlightclidriver.FloodLightCliDriver-class.html#connect,Method TestON.drivers.common.cli.remotetestbed.remotepoxdriver.RemotePoxDriver.connect()=TestON.drivers.common.cli.remotetestbed.remotepoxdriver.RemotePoxDriver-class.html#connect,Method TestON.drivers.common.cli.remotetestbed.remotevmdriver.RemoteVMDriver.connect()=TestON.drivers.common.cli.remotetestbed.remotevmdriver.RemoteVMDriver-class.html#connect,Method TestON.drivers.common.cli.remotetestbeddriver.RemoteTestBedDriver.connect()=TestON.drivers.common.cli.remotetestbeddriver.RemoteTestBedDriver-class.html#connect,Method TestON.drivers.common.cli.tool.dpctlclidriver.DpctlCliDriver.connect()=TestON.drivers.common.cli.tool.dpctlclidriver.DpctlCliDriver-class.html#connect,Method TestON.drivers.common.clidriver.CLI.connect()=TestON.drivers.common.clidriver.CLI-class.html#connect"><a title="TestON.bin.generatedriver.GenerateDriver.connect |
| 253 | TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.connect |
| 254 | TestON.drivers.common.api.fvtapidriver.FvtApiDriver.connect |
| 255 | TestON.drivers.common.apidriver.API.connect |
| 256 | TestON.drivers.common.cli.dpclidriver.DPCliDriver.connect |
| 257 | TestON.drivers.common.cli.emulator.flowvisordriver.FlowVisorDriver.connect |
| 258 | TestON.drivers.common.cli.emulator.lincoedriver.LincOEDriver.connect |
| 259 | TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.connect |
| 260 | TestON.drivers.common.cli.emulator.poxclidriver.PoxCliDriver.connect |
| 261 | TestON.drivers.common.cli.emulator.remotemininetdriver.RemoteMininetDriver.connect |
| 262 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.connect |
| 263 | TestON.drivers.common.cli.onosdriver.OnosDriver.connect |
| 264 | TestON.drivers.common.cli.quaggaclidriver.QuaggaCliDriver.connect |
| 265 | TestON.drivers.common.cli.remotesysdriver.RemoteSysDriver.connect |
| 266 | TestON.drivers.common.cli.remotetestbed.floodlightclidriver.FloodLightCliDriver.connect |
| 267 | TestON.drivers.common.cli.remotetestbed.remotepoxdriver.RemotePoxDriver.connect |
| 268 | TestON.drivers.common.cli.remotetestbed.remotevmdriver.RemoteVMDriver.connect |
| 269 | TestON.drivers.common.cli.remotetestbeddriver.RemoteTestBedDriver.connect |
| 270 | TestON.drivers.common.cli.tool.dpctlclidriver.DpctlCliDriver.connect |
| 271 | TestON.drivers.common.clidriver.CLI.connect" class="py-name" href="#" onclick="return doclink('link-18', 'connect', 'link-18');">connect</a></tt><tt class="py-op">(</tt> </tt> |
| 272 | <a name="L120"></a><tt class="py-lineno"> 120</tt> <tt class="py-line"> <tt class="py-name">user_name</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">user_name</tt><tt class="py-op">,</tt> </tt> |
| 273 | <a name="L121"></a><tt class="py-lineno"> 121</tt> <tt class="py-line"> <tt class="py-name">ip_address</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt><tt class="py-op">,</tt> </tt> |
| 274 | <a name="L122"></a><tt class="py-lineno"> 122</tt> <tt class="py-line"> <tt class="py-name">port</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">port</tt><tt class="py-op">,</tt> </tt> |
| 275 | <a name="L123"></a><tt class="py-lineno"> 123</tt> <tt class="py-line"> <tt class="py-name">pwd</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pwd</tt><tt class="py-op">,</tt> </tt> |
| 276 | <a name="L124"></a><tt class="py-lineno"> 124</tt> <tt class="py-line"> <tt class="py-name">home</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 277 | <a name="L125"></a><tt class="py-lineno"> 125</tt> <tt class="py-line"> </tt> |
| 278 | <a name="L126"></a><tt class="py-lineno"> 126</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">:</tt> </tt> |
| 279 | <a name="L127"></a><tt class="py-lineno"> 127</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-19" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#sendline"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-19', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 280 | <a name="L128"></a><tt class="py-lineno"> 128</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 281 | <a name="L129"></a><tt class="py-lineno"> 129</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt> </tt> |
| 282 | <a name="L130"></a><tt class="py-lineno"> 130</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 283 | <a name="L131"></a><tt class="py-lineno"> 131</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Failed to create ONOS handle"</tt> <tt class="py-op">)</tt> </tt> |
| 284 | <a name="L132"></a><tt class="py-lineno"> 132</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 285 | <a name="L133"></a><tt class="py-lineno"> 133</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 286 | <a name="L134"></a><tt class="py-lineno"> 134</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-21" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-21', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-22" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-22', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 287 | <a name="L135"></a><tt class="py-lineno"> 135</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-23" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-23', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-24" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-24', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 288 | <a name="L136"></a><tt class="py-lineno"> 136</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-25" 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-25', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 289 | <a name="L137"></a><tt class="py-lineno"> 137</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-26" 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-26', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 290 | <a name="L138"></a><tt class="py-lineno"> 138</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 291 | <a name="L139"></a><tt class="py-lineno"> 139</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-27" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-27', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 292 | <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-28" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-28', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 293 | <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-29" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-29', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 294 | </div><a name="L142"></a><tt class="py-lineno"> 142</tt> <tt class="py-line"> </tt> |
| 295 | <a name="OnosDriver.disconnect"></a><div id="OnosDriver.disconnect-def"><a name="L143"></a><tt class="py-lineno"> 143</tt> <a class="py-toggle" href="#" id="OnosDriver.disconnect-toggle" onclick="return toggle('OnosDriver.disconnect');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#disconnect">disconnect</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 296 | </div><div id="OnosDriver.disconnect-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.disconnect-expanded"><a name="L144"></a><tt class="py-lineno"> 144</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 297 | <a name="L145"></a><tt class="py-lineno"> 145</tt> <tt class="py-line"><tt class="py-docstring"> Called when Test is complete to disconnect the ONOS handle.</tt> </tt> |
| 298 | <a name="L146"></a><tt class="py-lineno"> 146</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 299 | <a name="L147"></a><tt class="py-lineno"> 147</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">TRUE</tt> </tt> |
| 300 | <a name="L148"></a><tt class="py-lineno"> 148</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 301 | <a name="L149"></a><tt class="py-lineno"> 149</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">:</tt> </tt> |
| 302 | <a name="L150"></a><tt class="py-lineno"> 150</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-30" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-30', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 303 | <a name="L151"></a><tt class="py-lineno"> 151</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 304 | <a name="L152"></a><tt class="py-lineno"> 152</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-31" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-31', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"exit"</tt> <tt class="py-op">)</tt> </tt> |
| 305 | <a name="L153"></a><tt class="py-lineno"> 153</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"closed"</tt> <tt class="py-op">)</tt> </tt> |
| 306 | <a name="L154"></a><tt class="py-lineno"> 154</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 307 | <a name="L155"></a><tt class="py-lineno"> 155</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-32" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-32', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-33" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-33', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 308 | <a name="L156"></a><tt class="py-lineno"> 156</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-35" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-35', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 309 | <a name="L157"></a><tt class="py-lineno"> 157</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">ValueError</tt><tt class="py-op">:</tt> </tt> |
| 310 | <a name="L158"></a><tt class="py-lineno"> 158</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-36" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-36', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Exception in disconnect of "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> </tt> |
| 311 | <a name="L159"></a><tt class="py-lineno"> 159</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">TRUE</tt> </tt> |
| 312 | <a name="L160"></a><tt class="py-lineno"> 160</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 313 | <a name="L161"></a><tt class="py-lineno"> 161</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-37" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-37', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Connection failed to the host"</tt> <tt class="py-op">)</tt> </tt> |
| 314 | <a name="L162"></a><tt class="py-lineno"> 162</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">FALSE</tt> </tt> |
| 315 | <a name="L163"></a><tt class="py-lineno"> 163</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">response</tt> </tt> |
| 316 | </div><a name="L164"></a><tt class="py-lineno"> 164</tt> <tt class="py-line"> </tt> |
| 317 | <a name="OnosDriver.getEpochMs"></a><div id="OnosDriver.getEpochMs-def"><a name="L165"></a><tt class="py-lineno"> 165</tt> <a class="py-toggle" href="#" id="OnosDriver.getEpochMs-toggle" onclick="return toggle('OnosDriver.getEpochMs');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getEpochMs">getEpochMs</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 318 | </div><div id="OnosDriver.getEpochMs-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.getEpochMs-expanded"><a name="L166"></a><tt class="py-lineno"> 166</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 319 | <a name="L167"></a><tt class="py-lineno"> 167</tt> <tt class="py-line"><tt class="py-docstring"> Returns milliseconds since epoch</tt> </tt> |
| 320 | <a name="L168"></a><tt class="py-lineno"> 168</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 321 | <a name="L169"></a><tt class="py-lineno"> 169</tt> <tt class="py-line"><tt class="py-docstring"> When checking multiple nodes in a for loop,</tt> </tt> |
| 322 | <a name="L170"></a><tt class="py-lineno"> 170</tt> <tt class="py-line"><tt class="py-docstring"> around a hundred milliseconds of difference (ascending) is</tt> </tt> |
| 323 | <a name="L171"></a><tt class="py-lineno"> 171</tt> <tt class="py-line"><tt class="py-docstring"> generally acceptable due to calltime of the function.</tt> </tt> |
| 324 | <a name="L172"></a><tt class="py-lineno"> 172</tt> <tt class="py-line"><tt class="py-docstring"> Few seconds, however, is not and it means clocks</tt> </tt> |
| 325 | <a name="L173"></a><tt class="py-lineno"> 173</tt> <tt class="py-line"><tt class="py-docstring"> are off sync.</tt> </tt> |
| 326 | <a name="L174"></a><tt class="py-lineno"> 174</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 327 | <a name="L175"></a><tt class="py-lineno"> 175</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 328 | <a name="L176"></a><tt class="py-lineno"> 176</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-38" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-38', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">'date +%s.%N'</tt> <tt class="py-op">)</tt> </tt> |
| 329 | <a name="L177"></a><tt class="py-lineno"> 177</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">'date \+\%s\.\%N'</tt> <tt class="py-op">)</tt> </tt> |
| 330 | <a name="L178"></a><tt class="py-lineno"> 178</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">'\$'</tt> <tt class="py-op">)</tt> </tt> |
| 331 | <a name="L179"></a><tt class="py-lineno"> 179</tt> <tt class="py-line"> <tt class="py-name">epochMs</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 332 | <a name="L180"></a><tt class="py-lineno"> 180</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">epochMs</tt> </tt> |
| 333 | <a name="L181"></a><tt class="py-lineno"> 181</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 334 | <a name="L182"></a><tt class="py-lineno"> 182</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-39" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-39', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">'Uncaught exception getting epoch time'</tt> <tt class="py-op">)</tt> </tt> |
| 335 | <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 id="link-40" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-40', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 336 | <a name="L184"></a><tt class="py-lineno"> 184</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-41" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-41', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 337 | </div><a name="L185"></a><tt class="py-lineno"> 185</tt> <tt class="py-line"> </tt> |
| 338 | <a name="OnosDriver.onosPackage"></a><div id="OnosDriver.onosPackage-def"><a name="L186"></a><tt class="py-lineno"> 186</tt> <a class="py-toggle" href="#" id="OnosDriver.onosPackage-toggle" onclick="return toggle('OnosDriver.onosPackage');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosPackage">onosPackage</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">opTimeout</tt><tt class="py-op">=</tt><tt class="py-number">30</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 339 | </div><div id="OnosDriver.onosPackage-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosPackage-expanded"><a name="L187"></a><tt class="py-lineno"> 187</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 340 | <a name="L188"></a><tt class="py-lineno"> 188</tt> <tt class="py-line"><tt class="py-docstring"> Produce a self-contained tar.gz file that can be deployed</tt> </tt> |
| 341 | <a name="L189"></a><tt class="py-lineno"> 189</tt> <tt class="py-line"><tt class="py-docstring"> and executed on any platform with Java 7 JRE.</tt> </tt> |
| 342 | <a name="L190"></a><tt class="py-lineno"> 190</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 343 | <a name="L191"></a><tt class="py-lineno"> 191</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 344 | <a name="L192"></a><tt class="py-lineno"> 192</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-42" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-42', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-package"</tt> <tt class="py-op">)</tt> </tt> |
| 345 | <a name="L193"></a><tt class="py-lineno"> 193</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"onos-package"</tt> <tt class="py-op">)</tt> </tt> |
| 346 | <a name="L194"></a><tt class="py-lineno"> 194</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"tar.gz"</tt><tt class="py-op">,</tt> <tt class="py-name">opTimeout</tt> <tt class="py-op">)</tt> </tt> |
| 347 | <a name="L195"></a><tt class="py-lineno"> 195</tt> <tt class="py-line"> <tt class="py-name">handle</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 348 | <a name="L196"></a><tt class="py-lineno"> 196</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-43" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-43', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"onos-package command returned: "</tt> <tt class="py-op">+</tt> </tt> |
| 349 | <a name="L197"></a><tt class="py-lineno"> 197</tt> <tt class="py-line"> <tt class="py-name">handle</tt> <tt class="py-op">)</tt> </tt> |
| 350 | <a name="L198"></a><tt class="py-lineno"> 198</tt> <tt class="py-line"> <tt class="py-comment"># As long as the sendline does not time out,</tt> </tt> |
| 351 | <a name="L199"></a><tt class="py-lineno"> 199</tt> <tt class="py-line"> <tt class="py-comment"># return true. However, be careful to interpret</tt> </tt> |
| 352 | <a name="L200"></a><tt class="py-lineno"> 200</tt> <tt class="py-line"> <tt class="py-comment"># the results of the onos-package command return</tt> </tt> |
| 353 | <a name="L201"></a><tt class="py-lineno"> 201</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 354 | <a name="L202"></a><tt class="py-lineno"> 202</tt> <tt class="py-line"> </tt> |
| 355 | <a name="L203"></a><tt class="py-lineno"> 203</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 356 | <a name="L204"></a><tt class="py-lineno"> 204</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-44', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-45" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-45', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 357 | <a name="L205"></a><tt class="py-lineno"> 205</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-47" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-47', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 358 | <a name="L206"></a><tt class="py-lineno"> 206</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 359 | <a name="L207"></a><tt class="py-lineno"> 207</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Failed to package ONOS"</tt> <tt class="py-op">)</tt> </tt> |
| 360 | <a name="L208"></a><tt class="py-lineno"> 208</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-49', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 361 | <a name="L209"></a><tt class="py-lineno"> 209</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.exit" class="py-name" href="#" onclick="return doclink('link-50', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 362 | </div><a name="L210"></a><tt class="py-lineno"> 210</tt> <tt class="py-line"> </tt> |
| 363 | <a name="OnosDriver.onosBuild"></a><div id="OnosDriver.onosBuild-def"><a name="L211"></a><tt class="py-lineno"> 211</tt> <a class="py-toggle" href="#" id="OnosDriver.onosBuild-toggle" onclick="return toggle('OnosDriver.onosBuild');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosBuild">onosBuild</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 364 | </div><div id="OnosDriver.onosBuild-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosBuild-expanded"><a name="L212"></a><tt class="py-lineno"> 212</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 365 | <a name="L213"></a><tt class="py-lineno"> 213</tt> <tt class="py-line"><tt class="py-docstring"> Use the pre defined script to build onos via mvn</tt> </tt> |
| 366 | <a name="L214"></a><tt class="py-lineno"> 214</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 367 | <a name="L215"></a><tt class="py-lineno"> 215</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 368 | <a name="L216"></a><tt class="py-lineno"> 216</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-51" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-51', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-build"</tt> <tt class="py-op">)</tt> </tt> |
| 369 | <a name="L217"></a><tt class="py-lineno"> 217</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"onos-build"</tt> <tt class="py-op">)</tt> </tt> |
| 370 | <a name="L218"></a><tt class="py-lineno"> 218</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 371 | <a name="L219"></a><tt class="py-lineno"> 219</tt> <tt class="py-line"> <tt class="py-string">"BUILD SUCCESS"</tt><tt class="py-op">,</tt> </tt> |
| 372 | <a name="L220"></a><tt class="py-lineno"> 220</tt> <tt class="py-line"> <tt class="py-string">"ERROR"</tt><tt class="py-op">,</tt> </tt> |
| 373 | <a name="L221"></a><tt class="py-lineno"> 221</tt> <tt class="py-line"> <tt class="py-string">"BUILD FAILED"</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt> |
| 374 | <a name="L222"></a><tt class="py-lineno"> 222</tt> <tt class="py-line"> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">120</tt> <tt class="py-op">)</tt> </tt> |
| 375 | <a name="L223"></a><tt class="py-lineno"> 223</tt> <tt class="py-line"> <tt class="py-name">handle</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 376 | <a name="L224"></a><tt class="py-lineno"> 224</tt> <tt class="py-line"> </tt> |
| 377 | <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 id="link-52" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-52', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"onos-build command returned: "</tt> <tt class="py-op">+</tt> </tt> |
| 378 | <a name="L226"></a><tt class="py-lineno"> 226</tt> <tt class="py-line"> <tt class="py-name">handle</tt> <tt class="py-op">)</tt> </tt> |
| 379 | <a name="L227"></a><tt class="py-lineno"> 227</tt> <tt class="py-line"> </tt> |
| 380 | <a name="L228"></a><tt class="py-lineno"> 228</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 381 | <a name="L229"></a><tt class="py-lineno"> 229</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 382 | <a name="L230"></a><tt class="py-lineno"> 230</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 383 | <a name="L231"></a><tt class="py-lineno"> 231</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">handle</tt> </tt> |
| 384 | <a name="L232"></a><tt class="py-lineno"> 232</tt> <tt class="py-line"> </tt> |
| 385 | <a name="L233"></a><tt class="py-lineno"> 233</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 386 | <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-53" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-53', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-54" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-54', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 387 | <a name="L235"></a><tt class="py-lineno"> 235</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-55', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-56" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-56', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 388 | <a name="L236"></a><tt class="py-lineno"> 236</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 389 | <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-57" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-57', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Failed to build ONOS"</tt> <tt class="py-op">)</tt> </tt> |
| 390 | <a name="L238"></a><tt class="py-lineno"> 238</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-58', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 391 | <a name="L239"></a><tt class="py-lineno"> 239</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-59', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 392 | </div><a name="L240"></a><tt class="py-lineno"> 240</tt> <tt class="py-line"> </tt> |
| 393 | <a name="OnosDriver.cleanInstall"></a><div id="OnosDriver.cleanInstall-def"><a name="L241"></a><tt class="py-lineno"> 241</tt> <a class="py-toggle" href="#" id="OnosDriver.cleanInstall-toggle" onclick="return toggle('OnosDriver.cleanInstall');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#cleanInstall">cleanInstall</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">skipTest</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> <tt class="py-param">mciTimeout</tt><tt class="py-op">=</tt><tt class="py-number">600</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 394 | </div><div id="OnosDriver.cleanInstall-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.cleanInstall-expanded"><a name="L242"></a><tt class="py-lineno"> 242</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 395 | <a name="L243"></a><tt class="py-lineno"> 243</tt> <tt class="py-line"><tt class="py-docstring"> Runs mvn clean install in the root of the ONOS directory.</tt> </tt> |
| 396 | <a name="L244"></a><tt class="py-lineno"> 244</tt> <tt class="py-line"><tt class="py-docstring"> This will clean all ONOS artifacts then compile each module</tt> </tt> |
| 397 | <a name="L245"></a><tt class="py-lineno"> 245</tt> <tt class="py-line"><tt class="py-docstring"> Optional:</tt> </tt> |
| 398 | <a name="L246"></a><tt class="py-lineno"> 246</tt> <tt class="py-line"><tt class="py-docstring"> skipTest - Does "-DskipTests -Dcheckstyle.skip -U -T 1C" which</tt> </tt> |
| 399 | <a name="L247"></a><tt class="py-lineno"> 247</tt> <tt class="py-line"><tt class="py-docstring"> skip the test. This will make the building faster.</tt> </tt> |
| 400 | <a name="L248"></a><tt class="py-lineno"> 248</tt> <tt class="py-line"><tt class="py-docstring"> Disregarding the credibility of the build</tt> </tt> |
| 401 | <a name="L249"></a><tt class="py-lineno"> 249</tt> <tt class="py-line"><tt class="py-docstring"> Returns: main.TRUE on success</tt> </tt> |
| 402 | <a name="L250"></a><tt class="py-lineno"> 250</tt> <tt class="py-line"><tt class="py-docstring"> On Failure, exits the test</tt> </tt> |
| 403 | <a name="L251"></a><tt class="py-lineno"> 251</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 404 | <a name="L252"></a><tt class="py-lineno"> 252</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 405 | <a name="L253"></a><tt class="py-lineno"> 253</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-60', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Running 'mvn clean install' on "</tt> <tt class="py-op">+</tt> </tt> |
| 406 | <a name="L254"></a><tt class="py-lineno"> 254</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 407 | <a name="L255"></a><tt class="py-lineno"> 255</tt> <tt class="py-line"> <tt class="py-string">". This may take some time."</tt> <tt class="py-op">)</tt> </tt> |
| 408 | <a name="L256"></a><tt class="py-lineno"> 256</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-61" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-61', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 409 | <a name="L257"></a><tt class="py-lineno"> 257</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 410 | <a name="L258"></a><tt class="py-lineno"> 258</tt> <tt class="py-line"> </tt> |
| 411 | <a name="L259"></a><tt class="py-lineno"> 259</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-62" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-62', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 412 | <a name="L260"></a><tt class="py-lineno"> 260</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 413 | <a name="L261"></a><tt class="py-lineno"> 261</tt> <tt class="py-line"> </tt> |
| 414 | <a name="L262"></a><tt class="py-lineno"> 262</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">skipTest</tt><tt class="py-op">:</tt> </tt> |
| 415 | <a name="L263"></a><tt class="py-lineno"> 263</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-63" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-63', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"mvn clean install"</tt> <tt class="py-op">)</tt> </tt> |
| 416 | <a name="L264"></a><tt class="py-lineno"> 264</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"mvn clean install"</tt> <tt class="py-op">)</tt> </tt> |
| 417 | <a name="L265"></a><tt class="py-lineno"> 265</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 418 | <a name="L266"></a><tt class="py-lineno"> 266</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-64" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-64', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"mvn clean install -DskipTests"</tt> <tt class="py-op">+</tt> </tt> |
| 419 | <a name="L267"></a><tt class="py-lineno"> 267</tt> <tt class="py-line"> <tt class="py-string">" -Dcheckstyle.skip -U -T 1C"</tt> <tt class="py-op">)</tt> </tt> |
| 420 | <a name="L268"></a><tt class="py-lineno"> 268</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"mvn clean install -DskipTests"</tt> <tt class="py-op">+</tt> </tt> |
| 421 | <a name="L269"></a><tt class="py-lineno"> 269</tt> <tt class="py-line"> <tt class="py-string">" -Dcheckstyle.skip -U -T 1C"</tt> <tt class="py-op">)</tt> </tt> |
| 422 | <a name="L270"></a><tt class="py-lineno"> 270</tt> <tt class="py-line"> <tt class="py-keyword">while</tt> <tt class="py-name">True</tt><tt class="py-op">:</tt> </tt> |
| 423 | <a name="L271"></a><tt class="py-lineno"> 271</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 424 | <a name="L272"></a><tt class="py-lineno"> 272</tt> <tt class="py-line"> <tt class="py-string">'There\sis\sinsufficient\smemory\sfor\sthe\sJava\s'</tt> <tt class="py-op">+</tt> </tt> |
| 425 | <a name="L273"></a><tt class="py-lineno"> 273</tt> <tt class="py-line"> <tt class="py-string">'Runtime\sEnvironment\sto\scontinue'</tt><tt class="py-op">,</tt> </tt> |
| 426 | <a name="L274"></a><tt class="py-lineno"> 274</tt> <tt class="py-line"> <tt class="py-string">'BUILD\sFAILURE'</tt><tt class="py-op">,</tt> </tt> |
| 427 | <a name="L275"></a><tt class="py-lineno"> 275</tt> <tt class="py-line"> <tt class="py-string">'BUILD\sSUCCESS'</tt><tt class="py-op">,</tt> </tt> |
| 428 | <a name="L276"></a><tt class="py-lineno"> 276</tt> <tt class="py-line"> <tt class="py-string">'onos\$'</tt><tt class="py-op">,</tt> <tt class="py-comment">#TODO: fix this to be more generic?</tt> </tt> |
| 429 | <a name="L277"></a><tt class="py-lineno"> 277</tt> <tt class="py-line"> <tt class="py-string">'ONOS\$'</tt><tt class="py-op">,</tt> </tt> |
| 430 | <a name="L278"></a><tt class="py-lineno"> 278</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">mciTimeout</tt> <tt class="py-op">)</tt> </tt> |
| 431 | <a name="L279"></a><tt class="py-lineno"> 279</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 432 | <a name="L280"></a><tt class="py-lineno"> 280</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-66" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-66', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">":There is insufficient memory \</tt> </tt> |
| 433 | <a name="L281"></a><tt class="py-lineno"> 281</tt> <tt class="py-line"><tt class="py-string"> for the Java Runtime Environment to continue."</tt> <tt class="py-op">)</tt> </tt> |
| 434 | <a name="L282"></a><tt class="py-lineno"> 282</tt> <tt class="py-line"> <tt class="py-comment"># return main.FALSE</tt> </tt> |
| 435 | <a name="L283"></a><tt class="py-lineno"> 283</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.cleanup" class="py-name" href="#" onclick="return doclink('link-67', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 436 | <a name="L284"></a><tt class="py-lineno"> 284</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.exit" class="py-name" href="#" onclick="return doclink('link-68', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 437 | <a name="L285"></a><tt class="py-lineno"> 285</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 438 | <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 id="link-69" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-69', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-70" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-70', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Build failure!"</tt> <tt class="py-op">)</tt> </tt> |
| 439 | <a name="L287"></a><tt class="py-lineno"> 287</tt> <tt class="py-line"> <tt class="py-comment"># return main.FALSE</tt> </tt> |
| 440 | <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 id="link-71" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-71', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 441 | <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 id="link-72" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-72', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 442 | <a name="L290"></a><tt class="py-lineno"> 290</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt> |
| 443 | <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-73" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-73', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Build success!"</tt> <tt class="py-op">)</tt> </tt> |
| 444 | <a name="L292"></a><tt class="py-lineno"> 292</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt> <tt class="py-keyword">or</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">4</tt><tt class="py-op">:</tt> </tt> |
| 445 | <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-74" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-74', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Build complete"</tt> <tt class="py-op">)</tt> </tt> |
| 446 | <a name="L294"></a><tt class="py-lineno"> 294</tt> <tt class="py-line"> <tt class="py-comment"># Print the build time</tt> </tt> |
| 447 | <a name="L295"></a><tt class="py-lineno"> 295</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">line</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 448 | <a name="L296"></a><tt class="py-lineno"> 296</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"Total time:"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">line</tt><tt class="py-op">:</tt> </tt> |
| 449 | <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-75" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-75', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">line</tt> <tt class="py-op">)</tt> </tt> |
| 450 | <a name="L298"></a><tt class="py-lineno"> 298</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-76" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-76', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 451 | <a name="L299"></a><tt class="py-lineno"> 299</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt> |
| 452 | <a name="L300"></a><tt class="py-lineno"> 300</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 453 | <a name="L301"></a><tt class="py-lineno"> 301</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">5</tt><tt class="py-op">:</tt> </tt> |
| 454 | <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-77" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-77', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-78" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-78', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 455 | <a name="L303"></a><tt class="py-lineno"> 303</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 456 | <a name="L304"></a><tt class="py-lineno"> 304</tt> <tt class="py-line"> <tt class="py-string">": mvn clean install TIMEOUT!"</tt> <tt class="py-op">)</tt> </tt> |
| 457 | <a name="L305"></a><tt class="py-lineno"> 305</tt> <tt class="py-line"> <tt class="py-comment"># return main.FALSE</tt> </tt> |
| 458 | <a name="L306"></a><tt class="py-lineno"> 306</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-79" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-79', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 459 | <a name="L307"></a><tt class="py-lineno"> 307</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-80', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 460 | <a name="L308"></a><tt class="py-lineno"> 308</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 461 | <a name="L309"></a><tt class="py-lineno"> 309</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-82" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-82', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": unexpected response from "</tt> <tt class="py-op">+</tt> </tt> |
| 462 | <a name="L310"></a><tt class="py-lineno"> 310</tt> <tt class="py-line"> <tt class="py-string">"mvn clean install"</tt> <tt class="py-op">)</tt> </tt> |
| 463 | <a name="L311"></a><tt class="py-lineno"> 311</tt> <tt class="py-line"> <tt class="py-comment"># return main.FALSE</tt> </tt> |
| 464 | <a name="L312"></a><tt class="py-lineno"> 312</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.cleanup" class="py-name" href="#" onclick="return doclink('link-83', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 465 | <a name="L313"></a><tt class="py-lineno"> 313</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-84" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-84', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 466 | <a name="L314"></a><tt class="py-lineno"> 314</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 467 | <a name="L315"></a><tt class="py-lineno"> 315</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-85" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-85', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-86" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-86', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 468 | <a name="L316"></a><tt class="py-lineno"> 316</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-87', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-88" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-88', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 469 | <a name="L317"></a><tt class="py-lineno"> 317</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-89" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-89', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 470 | <a name="L318"></a><tt class="py-lineno"> 318</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-90', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 471 | <a name="L319"></a><tt class="py-lineno"> 319</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 472 | <a name="L320"></a><tt class="py-lineno"> 320</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 473 | <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-92" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-92', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 474 | <a name="L322"></a><tt class="py-lineno"> 322</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-93" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-93', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 475 | </div><a name="L323"></a><tt class="py-lineno"> 323</tt> <tt class="py-line"> </tt> |
| 476 | <a name="OnosDriver.gitPull"></a><div id="OnosDriver.gitPull-def"><a name="L324"></a><tt class="py-lineno"> 324</tt> <a class="py-toggle" href="#" id="OnosDriver.gitPull-toggle" onclick="return toggle('OnosDriver.gitPull');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#gitPull">gitPull</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">comp1</tt><tt class="py-op">=</tt><tt class="py-string">""</tt><tt class="py-op">,</tt> <tt class="py-param">fastForward</tt><tt class="py-op">=</tt><tt class="py-name">True</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 477 | </div><div id="OnosDriver.gitPull-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.gitPull-expanded"><a name="L325"></a><tt class="py-lineno"> 325</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 478 | <a name="L326"></a><tt class="py-lineno"> 326</tt> <tt class="py-line"><tt class="py-docstring"> Assumes that "git pull" works without login</tt> </tt> |
| 479 | <a name="L327"></a><tt class="py-lineno"> 327</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 480 | <a name="L328"></a><tt class="py-lineno"> 328</tt> <tt class="py-line"><tt class="py-docstring"> If the fastForward boolean is set to true, only git pulls that can</tt> </tt> |
| 481 | <a name="L329"></a><tt class="py-lineno"> 329</tt> <tt class="py-line"><tt class="py-docstring"> be fast forwarded will be performed. IE if you have not local commits</tt> </tt> |
| 482 | <a name="L330"></a><tt class="py-lineno"> 330</tt> <tt class="py-line"><tt class="py-docstring"> in your branch.</tt> </tt> |
| 483 | <a name="L331"></a><tt class="py-lineno"> 331</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 484 | <a name="L332"></a><tt class="py-lineno"> 332</tt> <tt class="py-line"><tt class="py-docstring"> This function will perform a git pull on the ONOS instance.</tt> </tt> |
| 485 | <a name="L333"></a><tt class="py-lineno"> 333</tt> <tt class="py-line"><tt class="py-docstring"> If used as gitPull( "NODE" ) it will do git pull + NODE. This is</tt> </tt> |
| 486 | <a name="L334"></a><tt class="py-lineno"> 334</tt> <tt class="py-line"><tt class="py-docstring"> for the purpose of pulling from other nodes if necessary.</tt> </tt> |
| 487 | <a name="L335"></a><tt class="py-lineno"> 335</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 488 | <a name="L336"></a><tt class="py-lineno"> 336</tt> <tt class="py-line"><tt class="py-docstring"> Otherwise, this function will perform a git pull in the</tt> </tt> |
| 489 | <a name="L337"></a><tt class="py-lineno"> 337</tt> <tt class="py-line"><tt class="py-docstring"> ONOS repository. If it has any problems, it will return main.ERROR</tt> </tt> |
| 490 | <a name="L338"></a><tt class="py-lineno"> 338</tt> <tt class="py-line"><tt class="py-docstring"> If it successfully does a gitPull, it will return a 1 ( main.TRUE )</tt> </tt> |
| 491 | <a name="L339"></a><tt class="py-lineno"> 339</tt> <tt class="py-line"><tt class="py-docstring"> If it has no updates, it will return 3.</tt> </tt> |
| 492 | <a name="L340"></a><tt class="py-lineno"> 340</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 493 | <a name="L341"></a><tt class="py-lineno"> 341</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 494 | <a name="L342"></a><tt class="py-lineno"> 342</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 495 | <a name="L343"></a><tt class="py-lineno"> 343</tt> <tt class="py-line"> <tt class="py-comment"># main.log.info( self.name + ": Stopping ONOS" )</tt> </tt> |
| 496 | <a name="L344"></a><tt class="py-lineno"> 344</tt> <tt class="py-line"> <tt class="py-comment"># self.stop()</tt> </tt> |
| 497 | <a name="L345"></a><tt class="py-lineno"> 345</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-94" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-94', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 498 | <a name="L346"></a><tt class="py-lineno"> 346</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 499 | <a name="L347"></a><tt class="py-lineno"> 347</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"git pull"</tt> </tt> |
| 500 | <a name="L348"></a><tt class="py-lineno"> 348</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">comp1</tt> <tt class="py-op">!=</tt> <tt class="py-string">""</tt><tt class="py-op">:</tt> </tt> |
| 501 | <a name="L349"></a><tt class="py-lineno"> 349</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">' '</tt> <tt class="py-op">+</tt> <tt class="py-name">comp1</tt> </tt> |
| 502 | <a name="L350"></a><tt class="py-lineno"> 350</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">fastForward</tt><tt class="py-op">:</tt> </tt> |
| 503 | <a name="L351"></a><tt class="py-lineno"> 351</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">' '</tt> <tt class="py-op">+</tt> <tt class="py-string">" --ff-only"</tt> </tt> |
| 504 | <a name="L352"></a><tt class="py-lineno"> 352</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-95" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-95', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 505 | <a name="L353"></a><tt class="py-lineno"> 353</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> </tt> |
| 506 | <a name="L354"></a><tt class="py-lineno"> 354</tt> <tt class="py-line"> <tt class="py-op">[</tt> </tt> |
| 507 | <a name="L355"></a><tt class="py-lineno"> 355</tt> <tt class="py-line"> <tt class="py-string">'fatal'</tt><tt class="py-op">,</tt> </tt> |
| 508 | <a name="L356"></a><tt class="py-lineno"> 356</tt> <tt class="py-line"> <tt class="py-string">'Username\sfor\s(.*):\s'</tt><tt class="py-op">,</tt> </tt> |
| 509 | <a name="L357"></a><tt class="py-lineno"> 357</tt> <tt class="py-line"> <tt class="py-string">'\sfile(s*) changed,\s'</tt><tt class="py-op">,</tt> </tt> |
| 510 | <a name="L358"></a><tt class="py-lineno"> 358</tt> <tt class="py-line"> <tt class="py-string">'Already up-to-date'</tt><tt class="py-op">,</tt> </tt> |
| 511 | <a name="L359"></a><tt class="py-lineno"> 359</tt> <tt class="py-line"> <tt class="py-string">'Aborting'</tt><tt class="py-op">,</tt> </tt> |
| 512 | <a name="L360"></a><tt class="py-lineno"> 360</tt> <tt class="py-line"> <tt class="py-string">'You\sare\snot\scurrently\son\sa\sbranch'</tt><tt class="py-op">,</tt> </tt> |
| 513 | <a name="L361"></a><tt class="py-lineno"> 361</tt> <tt class="py-line"> <tt class="py-string">'You asked me to pull without telling me which branch you'</tt><tt class="py-op">,</tt> </tt> |
| 514 | <a name="L362"></a><tt class="py-lineno"> 362</tt> <tt class="py-line"> <tt class="py-string">'Pull is not possible because you have unmerged files'</tt><tt class="py-op">,</tt> </tt> |
| 515 | <a name="L363"></a><tt class="py-lineno"> 363</tt> <tt class="py-line"> <tt class="py-string">'Please enter a commit message to explain why this merge'</tt><tt class="py-op">,</tt> </tt> |
| 516 | <a name="L364"></a><tt class="py-lineno"> 364</tt> <tt class="py-line"> <tt class="py-string">'Found a swap file by the name'</tt><tt class="py-op">,</tt> </tt> |
| 517 | <a name="L365"></a><tt class="py-lineno"> 365</tt> <tt class="py-line"> <tt class="py-string">'Please, commit your changes before you can merge.'</tt><tt class="py-op">,</tt> </tt> |
| 518 | <a name="L366"></a><tt class="py-lineno"> 366</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt> |
| 519 | <a name="L367"></a><tt class="py-lineno"> 367</tt> <tt class="py-line"> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">300</tt> <tt class="py-op">)</tt> </tt> |
| 520 | <a name="L368"></a><tt class="py-lineno"> 368</tt> <tt class="py-line"> <tt class="py-comment"># debug</tt> </tt> |
| 521 | <a name="L369"></a><tt class="py-lineno"> 369</tt> <tt class="py-line"> <tt class="py-comment"># main.log.report( self.name +": DEBUG: \n"+</tt> </tt> |
| 522 | <a name="L370"></a><tt class="py-lineno"> 370</tt> <tt class="py-line"> <tt class="py-comment"># "git pull response: " +</tt> </tt> |
| 523 | <a name="L371"></a><tt class="py-lineno"> 371</tt> <tt class="py-line"> <tt class="py-comment"># str( self.handle.before ) + str( self.handle.after ) )</tt> </tt> |
| 524 | <a name="L372"></a><tt class="py-lineno"> 372</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 525 | <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 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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-97" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-97', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Git pull had some issue"</tt> <tt class="py-op">)</tt> </tt> |
| 526 | <a name="L374"></a><tt class="py-lineno"> 374</tt> <tt class="py-line"> <tt id="link-98" class="py-name" targets="Function TestON.bin.cli.output()=TestON.bin.cli-module.html#output"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-98', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">after</tt> </tt> |
| 527 | <a name="L375"></a><tt class="py-lineno"> 375</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">'\$'</tt> <tt class="py-op">)</tt> </tt> |
| 528 | <a name="L376"></a><tt class="py-lineno"> 376</tt> <tt class="py-line"> <tt id="link-99" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-99', 'output', 'link-98');">output</a></tt> <tt class="py-op">+=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 529 | <a name="L377"></a><tt class="py-lineno"> 377</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-100" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-100', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt id="link-101" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-101', 'output', 'link-98');">output</a></tt> <tt class="py-op">)</tt> </tt> |
| 530 | <a name="L378"></a><tt class="py-lineno"> 378</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 531 | <a name="L379"></a><tt class="py-lineno"> 379</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 532 | <a name="L380"></a><tt class="py-lineno"> 380</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-102', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-103" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-103', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 533 | <a name="L381"></a><tt class="py-lineno"> 381</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 534 | <a name="L382"></a><tt class="py-lineno"> 382</tt> <tt class="py-line"> <tt class="py-string">": Git Pull Asking for username. "</tt> <tt class="py-op">)</tt> </tt> |
| 535 | <a name="L383"></a><tt class="py-lineno"> 383</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 536 | <a name="L384"></a><tt class="py-lineno"> 384</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt> |
| 537 | <a name="L385"></a><tt class="py-lineno"> 385</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-104" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-104', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 538 | <a name="L386"></a><tt class="py-lineno"> 386</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 539 | <a name="L387"></a><tt class="py-lineno"> 387</tt> <tt class="py-line"> <tt class="py-string">": Git Pull - pulling repository now"</tt> <tt class="py-op">)</tt> </tt> |
| 540 | <a name="L388"></a><tt class="py-lineno"> 388</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt><tt class="py-op">,</tt> <tt class="py-number">120</tt> <tt class="py-op">)</tt> </tt> |
| 541 | <a name="L389"></a><tt class="py-lineno"> 389</tt> <tt class="py-line"> <tt class="py-comment"># So that only when git pull is done, we do mvn clean compile</tt> </tt> |
| 542 | <a name="L390"></a><tt class="py-lineno"> 390</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 543 | <a name="L391"></a><tt class="py-lineno"> 391</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt> |
| 544 | <a name="L392"></a><tt class="py-lineno"> 392</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-105', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Git Pull - Already up to date"</tt> <tt class="py-op">)</tt> </tt> |
| 545 | <a name="L393"></a><tt class="py-lineno"> 393</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">i</tt> </tt> |
| 546 | <a name="L394"></a><tt class="py-lineno"> 394</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">4</tt><tt class="py-op">:</tt> </tt> |
| 547 | <a name="L395"></a><tt class="py-lineno"> 395</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-106" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-106', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 548 | <a name="L396"></a><tt class="py-lineno"> 396</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 549 | <a name="L397"></a><tt class="py-lineno"> 397</tt> <tt class="py-line"> <tt class="py-string">": Git Pull - Aborting..."</tt> <tt class="py-op">+</tt> </tt> |
| 550 | <a name="L398"></a><tt class="py-lineno"> 398</tt> <tt class="py-line"> <tt class="py-string">"Are there conflicting git files?"</tt> <tt class="py-op">)</tt> </tt> |
| 551 | <a name="L399"></a><tt class="py-lineno"> 399</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 552 | <a name="L400"></a><tt class="py-lineno"> 400</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">5</tt><tt class="py-op">:</tt> </tt> |
| 553 | <a name="L401"></a><tt class="py-lineno"> 401</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-107" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-107', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 554 | <a name="L402"></a><tt class="py-lineno"> 402</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 555 | <a name="L403"></a><tt class="py-lineno"> 403</tt> <tt class="py-line"> <tt class="py-string">": Git Pull - You are not currently "</tt> <tt class="py-op">+</tt> </tt> |
| 556 | <a name="L404"></a><tt class="py-lineno"> 404</tt> <tt class="py-line"> <tt class="py-string">"on a branch so git pull failed!"</tt> <tt class="py-op">)</tt> </tt> |
| 557 | <a name="L405"></a><tt class="py-lineno"> 405</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 558 | <a name="L406"></a><tt class="py-lineno"> 406</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">6</tt><tt class="py-op">:</tt> </tt> |
| 559 | <a name="L407"></a><tt class="py-lineno"> 407</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-108" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-108', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 560 | <a name="L408"></a><tt class="py-lineno"> 408</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 561 | <a name="L409"></a><tt class="py-lineno"> 409</tt> <tt class="py-line"> <tt class="py-string">": Git Pull - You have not configured an upstream "</tt> <tt class="py-op">+</tt> </tt> |
| 562 | <a name="L410"></a><tt class="py-lineno"> 410</tt> <tt class="py-line"> <tt class="py-string">"branch to pull from. Git pull failed!"</tt> <tt class="py-op">)</tt> </tt> |
| 563 | <a name="L411"></a><tt class="py-lineno"> 411</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 564 | <a name="L412"></a><tt class="py-lineno"> 412</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">7</tt><tt class="py-op">:</tt> </tt> |
| 565 | <a name="L413"></a><tt class="py-lineno"> 413</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-109" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-109', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 566 | <a name="L414"></a><tt class="py-lineno"> 414</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 567 | <a name="L415"></a><tt class="py-lineno"> 415</tt> <tt class="py-line"> <tt class="py-string">": Git Pull - Pull is not possible because "</tt> <tt class="py-op">+</tt> </tt> |
| 568 | <a name="L416"></a><tt class="py-lineno"> 416</tt> <tt class="py-line"> <tt class="py-string">"you have unmerged files."</tt> <tt class="py-op">)</tt> </tt> |
| 569 | <a name="L417"></a><tt class="py-lineno"> 417</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 570 | <a name="L418"></a><tt class="py-lineno"> 418</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">8</tt><tt class="py-op">:</tt> </tt> |
| 571 | <a name="L419"></a><tt class="py-lineno"> 419</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: abandoning test since we can't reliably handle this</tt> </tt> |
| 572 | <a name="L420"></a><tt class="py-lineno"> 420</tt> <tt class="py-line"> <tt class="py-comment"># there could be different default text editors and we</tt> </tt> |
| 573 | <a name="L421"></a><tt class="py-lineno"> 421</tt> <tt class="py-line"> <tt class="py-comment"># also don't know if we actually want to make the commit</tt> </tt> |
| 574 | <a name="L422"></a><tt class="py-lineno"> 422</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-110" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-110', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-111" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-111', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Git pull resulted in a merge commit message"</tt> <tt class="py-op">+</tt> </tt> |
| 575 | <a name="L423"></a><tt class="py-lineno"> 423</tt> <tt class="py-line"> <tt class="py-string">". Exiting test!"</tt> <tt class="py-op">)</tt> </tt> |
| 576 | <a name="L424"></a><tt class="py-lineno"> 424</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-112" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-112', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 577 | <a name="L425"></a><tt class="py-lineno"> 425</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-113" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-113', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 578 | <a name="L426"></a><tt class="py-lineno"> 426</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">9</tt><tt class="py-op">:</tt> <tt class="py-comment"># Merge commit message but swap file exists</tt> </tt> |
| 579 | <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 id="link-114" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-114', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-115" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-115', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Git pull resulted in a merge commit message"</tt> <tt class="py-op">+</tt> </tt> |
| 580 | <a name="L428"></a><tt class="py-lineno"> 428</tt> <tt class="py-line"> <tt class="py-string">" but a swap file exists."</tt> <tt class="py-op">)</tt> </tt> |
| 581 | <a name="L429"></a><tt class="py-lineno"> 429</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 582 | <a name="L430"></a><tt class="py-lineno"> 430</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-116" class="py-name" targets="Method TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.send()=TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver-class.html#send"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.send" class="py-name" href="#" onclick="return doclink('link-116', 'send', 'link-116');">send</a></tt><tt class="py-op">(</tt> <tt class="py-string">'A'</tt> <tt class="py-op">)</tt> <tt class="py-comment"># Abort</tt> </tt> |
| 583 | <a name="L431"></a><tt class="py-lineno"> 431</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 584 | <a name="L432"></a><tt class="py-lineno"> 432</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 585 | <a name="L433"></a><tt class="py-lineno"> 433</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 586 | <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-117" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-117', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Couldn't exit editor prompt!"</tt><tt class="py-op">)</tt> </tt> |
| 587 | <a name="L435"></a><tt class="py-lineno"> 435</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-118', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 588 | <a name="L436"></a><tt class="py-lineno"> 436</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-119" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-119', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 589 | <a name="L437"></a><tt class="py-lineno"> 437</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">10</tt><tt class="py-op">:</tt> <tt class="py-comment"># In the middle of a merge commit</tt> </tt> |
| 590 | <a name="L438"></a><tt class="py-lineno"> 438</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-120', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-121" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-121', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Git branch is in the middle of a merge. "</tt> <tt class="py-op">)</tt> </tt> |
| 591 | <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-122" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-122', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">after</tt> <tt class="py-op">)</tt> </tt> |
| 592 | <a name="L440"></a><tt class="py-lineno"> 440</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 593 | <a name="L441"></a><tt class="py-lineno"> 441</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">11</tt><tt class="py-op">:</tt> </tt> |
| 594 | <a name="L442"></a><tt class="py-lineno"> 442</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-124" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-124', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Git Pull - TIMEOUT"</tt> <tt class="py-op">)</tt> </tt> |
| 595 | <a name="L443"></a><tt class="py-lineno"> 443</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-125', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-126" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-126', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 596 | <a name="L444"></a><tt class="py-lineno"> 444</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">" Response was: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt> |
| 597 | <a name="L445"></a><tt class="py-lineno"> 445</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 598 | <a name="L446"></a><tt class="py-lineno"> 446</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 599 | <a name="L447"></a><tt class="py-lineno"> 447</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 600 | <a name="L448"></a><tt class="py-lineno"> 448</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-127" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-127', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-128" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-128', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 601 | <a name="L449"></a><tt class="py-lineno"> 449</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 602 | <a name="L450"></a><tt class="py-lineno"> 450</tt> <tt class="py-line"> <tt class="py-string">": Git Pull - Unexpected response, check for pull errors"</tt> <tt class="py-op">)</tt> </tt> |
| 603 | <a name="L451"></a><tt class="py-lineno"> 451</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 604 | <a name="L452"></a><tt class="py-lineno"> 452</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 605 | <a name="L453"></a><tt class="py-lineno"> 453</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-129" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-129', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-130" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-130', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 606 | <a name="L454"></a><tt class="py-lineno"> 454</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-131" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-131', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-132" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-132', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 607 | <a name="L455"></a><tt class="py-lineno"> 455</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-133', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 608 | <a name="L456"></a><tt class="py-lineno"> 456</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-134" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-134', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 609 | <a name="L457"></a><tt class="py-lineno"> 457</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 610 | <a name="L458"></a><tt class="py-lineno"> 458</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-135" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-135', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 611 | <a name="L459"></a><tt class="py-lineno"> 459</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-136" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-136', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 612 | <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-137" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-137', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 613 | </div><a name="L461"></a><tt class="py-lineno"> 461</tt> <tt class="py-line"> </tt> |
| 614 | <a name="OnosDriver.gitCheckout"></a><div id="OnosDriver.gitCheckout-def"><a name="L462"></a><tt class="py-lineno"> 462</tt> <a class="py-toggle" href="#" id="OnosDriver.gitCheckout-toggle" onclick="return toggle('OnosDriver.gitCheckout');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#gitCheckout">gitCheckout</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">branch</tt><tt class="py-op">=</tt><tt class="py-string">"master"</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 615 | </div><div id="OnosDriver.gitCheckout-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.gitCheckout-expanded"><a name="L463"></a><tt class="py-lineno"> 463</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 616 | <a name="L464"></a><tt class="py-lineno"> 464</tt> <tt class="py-line"><tt class="py-docstring"> Assumes that "git pull" works without login</tt> </tt> |
| 617 | <a name="L465"></a><tt class="py-lineno"> 465</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 618 | <a name="L466"></a><tt class="py-lineno"> 466</tt> <tt class="py-line"><tt class="py-docstring"> This function will perform a git git checkout on the ONOS instance.</tt> </tt> |
| 619 | <a name="L467"></a><tt class="py-lineno"> 467</tt> <tt class="py-line"><tt class="py-docstring"> If used as gitCheckout( "branch" ) it will do git checkout</tt> </tt> |
| 620 | <a name="L468"></a><tt class="py-lineno"> 468</tt> <tt class="py-line"><tt class="py-docstring"> of the "branch".</tt> </tt> |
| 621 | <a name="L469"></a><tt class="py-lineno"> 469</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 622 | <a name="L470"></a><tt class="py-lineno"> 470</tt> <tt class="py-line"><tt class="py-docstring"> Otherwise, this function will perform a git checkout of the master</tt> </tt> |
| 623 | <a name="L471"></a><tt class="py-lineno"> 471</tt> <tt class="py-line"><tt class="py-docstring"> branch of the ONOS repository. If it has any problems, it will return</tt> </tt> |
| 624 | <a name="L472"></a><tt class="py-lineno"> 472</tt> <tt class="py-line"><tt class="py-docstring"> main.ERROR.</tt> </tt> |
| 625 | <a name="L473"></a><tt class="py-lineno"> 473</tt> <tt class="py-line"><tt class="py-docstring"> If the branch was already the specified branch, or the git checkout was</tt> </tt> |
| 626 | <a name="L474"></a><tt class="py-lineno"> 474</tt> <tt class="py-line"><tt class="py-docstring"> successful then the function will return main.TRUE.</tt> </tt> |
| 627 | <a name="L475"></a><tt class="py-lineno"> 475</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 628 | <a name="L476"></a><tt class="py-lineno"> 476</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 629 | <a name="L477"></a><tt class="py-lineno"> 477</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 630 | <a name="L478"></a><tt class="py-lineno"> 478</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-138" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-138', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 631 | <a name="L479"></a><tt class="py-lineno"> 479</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 632 | <a name="L480"></a><tt class="py-lineno"> 480</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 633 | <a name="L481"></a><tt class="py-lineno"> 481</tt> <tt class="py-line"> <tt class="py-string">": Checking out git branch/ref: "</tt> <tt class="py-op">+</tt> <tt class="py-name">branch</tt> <tt class="py-op">+</tt> <tt class="py-string">"..."</tt> <tt class="py-op">)</tt> </tt> |
| 634 | <a name="L482"></a><tt class="py-lineno"> 482</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"git checkout "</tt> <tt class="py-op">+</tt> <tt class="py-name">branch</tt> </tt> |
| 635 | <a name="L483"></a><tt class="py-lineno"> 483</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-140" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-140', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 636 | <a name="L484"></a><tt class="py-lineno"> 484</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 637 | <a name="L485"></a><tt class="py-lineno"> 485</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> </tt> |
| 638 | <a name="L486"></a><tt class="py-lineno"> 486</tt> <tt class="py-line"> <tt class="py-op">[</tt> <tt class="py-string">'fatal'</tt><tt class="py-op">,</tt> </tt> |
| 639 | <a name="L487"></a><tt class="py-lineno"> 487</tt> <tt class="py-line"> <tt class="py-string">'Username for (.*): '</tt><tt class="py-op">,</tt> </tt> |
| 640 | <a name="L488"></a><tt class="py-lineno"> 488</tt> <tt class="py-line"> <tt class="py-string">'Already on \''</tt><tt class="py-op">,</tt> </tt> |
| 641 | <a name="L489"></a><tt class="py-lineno"> 489</tt> <tt class="py-line"> <tt class="py-string">'Switched to (a new )?branch \''</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">branch</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> </tt> |
| 642 | <a name="L490"></a><tt class="py-lineno"> 490</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">,</tt> </tt> |
| 643 | <a name="L491"></a><tt class="py-lineno"> 491</tt> <tt class="py-line"> <tt class="py-string">'error: Your local changes to the following files'</tt> <tt class="py-op">+</tt> </tt> |
| 644 | <a name="L492"></a><tt class="py-lineno"> 492</tt> <tt class="py-line"> <tt class="py-string">'would be overwritten by checkout:'</tt><tt class="py-op">,</tt> </tt> |
| 645 | <a name="L493"></a><tt class="py-lineno"> 493</tt> <tt class="py-line"> <tt class="py-string">'error: you need to resolve your current index first'</tt><tt class="py-op">,</tt> </tt> |
| 646 | <a name="L494"></a><tt class="py-lineno"> 494</tt> <tt class="py-line"> <tt class="py-string">"You are in 'detached HEAD' state."</tt><tt class="py-op">,</tt> </tt> |
| 647 | <a name="L495"></a><tt class="py-lineno"> 495</tt> <tt class="py-line"> <tt class="py-string">"HEAD is now at "</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt> |
| 648 | <a name="L496"></a><tt class="py-lineno"> 496</tt> <tt class="py-line"> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt> |
| 649 | <a name="L497"></a><tt class="py-lineno"> 497</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 650 | <a name="L498"></a><tt class="py-lineno"> 498</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-142" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-142', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 651 | <a name="L499"></a><tt class="py-lineno"> 499</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 652 | <a name="L500"></a><tt class="py-lineno"> 500</tt> <tt class="py-line"> <tt class="py-string">": Git checkout had some issue..."</tt> <tt class="py-op">)</tt> </tt> |
| 653 | <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-143" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-143', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-144" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-144', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 654 | <a name="L502"></a><tt class="py-lineno"> 502</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 655 | <a name="L503"></a><tt class="py-lineno"> 503</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 656 | <a name="L504"></a><tt class="py-lineno"> 504</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-145" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-145', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-146" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-146', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 657 | <a name="L505"></a><tt class="py-lineno"> 505</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 658 | <a name="L506"></a><tt class="py-lineno"> 506</tt> <tt class="py-line"> <tt class="py-string">": Git checkout asking for username."</tt> <tt class="py-op">+</tt> </tt> |
| 659 | <a name="L507"></a><tt class="py-lineno"> 507</tt> <tt class="py-line"> <tt class="py-string">" Please configure your local git repository to be able "</tt> <tt class="py-op">+</tt> </tt> |
| 660 | <a name="L508"></a><tt class="py-lineno"> 508</tt> <tt class="py-line"> <tt class="py-string">"to access your remote repository passwordlessly"</tt> <tt class="py-op">)</tt> </tt> |
| 661 | <a name="L509"></a><tt class="py-lineno"> 509</tt> <tt class="py-line"> <tt class="py-comment"># TODO add support for authenticating</tt> </tt> |
| 662 | <a name="L510"></a><tt class="py-lineno"> 510</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 663 | <a name="L511"></a><tt class="py-lineno"> 511</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt> |
| 664 | <a name="L512"></a><tt class="py-lineno"> 512</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-147" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-147', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 665 | <a name="L513"></a><tt class="py-lineno"> 513</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 666 | <a name="L514"></a><tt class="py-lineno"> 514</tt> <tt class="py-line"> <tt class="py-string">": Git Checkout %s : Already on this branch"</tt> <tt class="py-op">%</tt> <tt class="py-name">branch</tt> <tt class="py-op">)</tt> </tt> |
| 667 | <a name="L515"></a><tt class="py-lineno"> 515</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 668 | <a name="L516"></a><tt class="py-lineno"> 516</tt> <tt class="py-line"> <tt class="py-comment"># main.log.info( "DEBUG: after checkout cmd = "+</tt> </tt> |
| 669 | <a name="L517"></a><tt class="py-lineno"> 517</tt> <tt class="py-line"> <tt class="py-comment"># self.handle.before )</tt> </tt> |
| 670 | <a name="L518"></a><tt class="py-lineno"> 518</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 671 | <a name="L519"></a><tt class="py-lineno"> 519</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt> |
| 672 | <a name="L520"></a><tt class="py-lineno"> 520</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-148" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-148', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 673 | <a name="L521"></a><tt class="py-lineno"> 521</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 674 | <a name="L522"></a><tt class="py-lineno"> 522</tt> <tt class="py-line"> <tt class="py-string">": Git checkout %s - Switched to this branch"</tt> <tt class="py-op">%</tt> <tt class="py-name">branch</tt> <tt class="py-op">)</tt> </tt> |
| 675 | <a name="L523"></a><tt class="py-lineno"> 523</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 676 | <a name="L524"></a><tt class="py-lineno"> 524</tt> <tt class="py-line"> <tt class="py-comment"># main.log.info( "DEBUG: after checkout cmd = "+</tt> </tt> |
| 677 | <a name="L525"></a><tt class="py-lineno"> 525</tt> <tt class="py-line"> <tt class="py-comment"># self.handle.before )</tt> </tt> |
| 678 | <a name="L526"></a><tt class="py-lineno"> 526</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 679 | <a name="L527"></a><tt class="py-lineno"> 527</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">4</tt><tt class="py-op">:</tt> </tt> |
| 680 | <a name="L528"></a><tt class="py-lineno"> 528</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-149" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-149', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-150" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-150', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Git Checkout- TIMEOUT"</tt> <tt class="py-op">)</tt> </tt> |
| 681 | <a name="L529"></a><tt class="py-lineno"> 529</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-151" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-151', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-152" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-152', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 682 | <a name="L530"></a><tt class="py-lineno"> 530</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">" Response was: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 683 | <a name="L531"></a><tt class="py-lineno"> 531</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 684 | <a name="L532"></a><tt class="py-lineno"> 532</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">5</tt><tt class="py-op">:</tt> </tt> |
| 685 | <a name="L533"></a><tt class="py-lineno"> 533</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"Aborting"</tt> <tt class="py-op">)</tt> </tt> |
| 686 | <a name="L534"></a><tt class="py-lineno"> 534</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-153" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-153', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-154" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-154', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 687 | <a name="L535"></a><tt class="py-lineno"> 535</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 688 | <a name="L536"></a><tt class="py-lineno"> 536</tt> <tt class="py-line"> <tt class="py-string">": Git checkout error: \n"</tt> <tt class="py-op">+</tt> </tt> |
| 689 | <a name="L537"></a><tt class="py-lineno"> 537</tt> <tt class="py-line"> <tt class="py-string">"Your local changes to the following files would"</tt> <tt class="py-op">+</tt> </tt> |
| 690 | <a name="L538"></a><tt class="py-lineno"> 538</tt> <tt class="py-line"> <tt class="py-string">" be overwritten by checkout:"</tt> <tt class="py-op">+</tt> </tt> |
| 691 | <a name="L539"></a><tt class="py-lineno"> 539</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 692 | <a name="L540"></a><tt class="py-lineno"> 540</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 693 | <a name="L541"></a><tt class="py-lineno"> 541</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 694 | <a name="L542"></a><tt class="py-lineno"> 542</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">6</tt><tt class="py-op">:</tt> </tt> |
| 695 | <a name="L543"></a><tt class="py-lineno"> 543</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-155" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-155', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-156" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-156', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 696 | <a name="L544"></a><tt class="py-lineno"> 544</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 697 | <a name="L545"></a><tt class="py-lineno"> 545</tt> <tt class="py-line"> <tt class="py-string">": Git checkout error: \n"</tt> <tt class="py-op">+</tt> </tt> |
| 698 | <a name="L546"></a><tt class="py-lineno"> 546</tt> <tt class="py-line"> <tt class="py-string">"You need to resolve your current index first:"</tt> <tt class="py-op">+</tt> </tt> |
| 699 | <a name="L547"></a><tt class="py-lineno"> 547</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 700 | <a name="L548"></a><tt class="py-lineno"> 548</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 701 | <a name="L549"></a><tt class="py-lineno"> 549</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 702 | <a name="L550"></a><tt class="py-lineno"> 550</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">7</tt><tt class="py-op">:</tt> </tt> |
| 703 | <a name="L551"></a><tt class="py-lineno"> 551</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-157" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-157', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 704 | <a name="L552"></a><tt class="py-lineno"> 552</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 705 | <a name="L553"></a><tt class="py-lineno"> 553</tt> <tt class="py-line"> <tt class="py-string">": Git checkout "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">branch</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 706 | <a name="L554"></a><tt class="py-lineno"> 554</tt> <tt class="py-line"> <tt class="py-string">" - You are in 'detached HEAD' state. HEAD is now at "</tt> <tt class="py-op">+</tt> </tt> |
| 707 | <a name="L555"></a><tt class="py-lineno"> 555</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">branch</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 708 | <a name="L556"></a><tt class="py-lineno"> 556</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 709 | <a name="L557"></a><tt class="py-lineno"> 557</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 710 | <a name="L558"></a><tt class="py-lineno"> 558</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">8</tt><tt class="py-op">:</tt> <tt class="py-comment"># Already in detached HEAD on the specified commit</tt> </tt> |
| 711 | <a name="L559"></a><tt class="py-lineno"> 559</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-158', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 712 | <a name="L560"></a><tt class="py-lineno"> 560</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 713 | <a name="L561"></a><tt class="py-lineno"> 561</tt> <tt class="py-line"> <tt class="py-string">": Git Checkout %s : Already on commit"</tt> <tt class="py-op">%</tt> <tt class="py-name">branch</tt> <tt class="py-op">)</tt> </tt> |
| 714 | <a name="L562"></a><tt class="py-lineno"> 562</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 715 | <a name="L563"></a><tt class="py-lineno"> 563</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 716 | <a name="L564"></a><tt class="py-lineno"> 564</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 717 | <a name="L565"></a><tt class="py-lineno"> 565</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-159" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-159', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-160" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-160', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> </tt> |
| 718 | <a name="L566"></a><tt class="py-lineno"> 566</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 719 | <a name="L567"></a><tt class="py-lineno"> 567</tt> <tt class="py-line"> <tt class="py-string">": Git Checkout - Unexpected response, "</tt> <tt class="py-op">+</tt> </tt> |
| 720 | <a name="L568"></a><tt class="py-lineno"> 568</tt> <tt class="py-line"> <tt class="py-string">"check for pull errors"</tt> <tt class="py-op">)</tt> </tt> |
| 721 | <a name="L569"></a><tt class="py-lineno"> 569</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-161" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-161', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-162" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-162', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 722 | <a name="L570"></a><tt class="py-lineno"> 570</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 723 | <a name="L571"></a><tt class="py-lineno"> 571</tt> <tt class="py-line"> </tt> |
| 724 | <a name="L572"></a><tt class="py-lineno"> 572</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 725 | <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-163" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-163', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-164" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-164', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 726 | <a name="L574"></a><tt class="py-lineno"> 574</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-165" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-165', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-166" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-166', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 727 | <a name="L575"></a><tt class="py-lineno"> 575</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-167', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 728 | <a name="L576"></a><tt class="py-lineno"> 576</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-168" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-168', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 729 | <a name="L577"></a><tt class="py-lineno"> 577</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 730 | <a name="L578"></a><tt class="py-lineno"> 578</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-169" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-169', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 731 | <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-170" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-170', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 732 | <a name="L580"></a><tt class="py-lineno"> 580</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-171', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 733 | </div><a name="L581"></a><tt class="py-lineno"> 581</tt> <tt class="py-line"> </tt> |
| 734 | <a name="OnosDriver.getBranchName"></a><div id="OnosDriver.getBranchName-def"><a name="L582"></a><tt class="py-lineno"> 582</tt> <a class="py-toggle" href="#" id="OnosDriver.getBranchName-toggle" onclick="return toggle('OnosDriver.getBranchName');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getBranchName">getBranchName</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 735 | </div><div id="OnosDriver.getBranchName-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.getBranchName-expanded"><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-172" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-172', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"self.home = "</tt> <tt class="py-op">)</tt> </tt> |
| 736 | <a name="L584"></a><tt class="py-lineno"> 584</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-173" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-173', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 737 | <a name="L585"></a><tt class="py-lineno"> 585</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-174" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-174', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 738 | <a name="L586"></a><tt class="py-lineno"> 586</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 739 | <a name="L587"></a><tt class="py-lineno"> 587</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-175" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-175', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"git name-rev --name-only HEAD"</tt> <tt class="py-op">)</tt> </tt> |
| 740 | <a name="L588"></a><tt class="py-lineno"> 588</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"git name-rev --name-only HEAD"</tt> <tt class="py-op">)</tt> </tt> |
| 741 | <a name="L589"></a><tt class="py-lineno"> 589</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 742 | <a name="L590"></a><tt class="py-lineno"> 590</tt> <tt class="py-line"> </tt> |
| 743 | <a name="L591"></a><tt class="py-lineno"> 591</tt> <tt class="py-line"> <tt class="py-name">lines</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 744 | <a name="L592"></a><tt class="py-lineno"> 592</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">lines</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">"master"</tt><tt class="py-op">:</tt> </tt> |
| 745 | <a name="L593"></a><tt class="py-lineno"> 593</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">"master"</tt> </tt> |
| 746 | <a name="L594"></a><tt class="py-lineno"> 594</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">lines</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">"onos-1.0"</tt><tt class="py-op">:</tt> </tt> |
| 747 | <a name="L595"></a><tt class="py-lineno"> 595</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">"onos-1.0"</tt> </tt> |
| 748 | <a name="L596"></a><tt class="py-lineno"> 596</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 749 | <a name="L597"></a><tt class="py-lineno"> 597</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-176" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-176', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">lines</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt> |
| 750 | <a name="L598"></a><tt class="py-lineno"> 598</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">"unexpected ONOS branch for SDN-IP test"</tt> </tt> |
| 751 | </div><a name="L599"></a><tt class="py-lineno"> 599</tt> <tt class="py-line"> </tt> |
| 752 | <a name="OnosDriver.getVersion"></a><div id="OnosDriver.getVersion-def"><a name="L600"></a><tt class="py-lineno"> 600</tt> <a class="py-toggle" href="#" id="OnosDriver.getVersion-toggle" onclick="return toggle('OnosDriver.getVersion');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getVersion">getVersion</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">report</tt><tt class="py-op">=</tt><tt class="py-name">False</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 753 | </div><div id="OnosDriver.getVersion-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.getVersion-expanded"><a name="L601"></a><tt class="py-lineno"> 601</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 754 | <a name="L602"></a><tt class="py-lineno"> 602</tt> <tt class="py-line"><tt class="py-docstring"> Writes the COMMIT number to the report to be parsed</tt> </tt> |
| 755 | <a name="L603"></a><tt class="py-lineno"> 603</tt> <tt class="py-line"><tt class="py-docstring"> by Jenkins data collector.</tt> </tt> |
| 756 | <a name="L604"></a><tt class="py-lineno"> 604</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 757 | <a name="L605"></a><tt class="py-lineno"> 605</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 758 | <a name="L606"></a><tt class="py-lineno"> 606</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-177" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-177', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 759 | <a name="L607"></a><tt class="py-lineno"> 607</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 760 | <a name="L608"></a><tt class="py-lineno"> 608</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-178" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-178', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> </tt> |
| 761 | <a name="L609"></a><tt class="py-lineno"> 609</tt> <tt class="py-line"> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> </tt> |
| 762 | <a name="L610"></a><tt class="py-lineno"> 610</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> </tt> |
| 763 | <a name="L611"></a><tt class="py-lineno"> 611</tt> <tt class="py-line"> <tt class="py-string">"; git log -1 --pretty=fuller --decorate=short | grep -A 6 "</tt> <tt class="py-op">+</tt> </tt> |
| 764 | <a name="L612"></a><tt class="py-lineno"> 612</tt> <tt class="py-line"> <tt class="py-string">" \"commit\" --color=never"</tt> <tt class="py-op">)</tt> </tt> |
| 765 | <a name="L613"></a><tt class="py-lineno"> 613</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: for some reason there are backspaces inserted in this</tt> </tt> |
| 766 | <a name="L614"></a><tt class="py-lineno"> 614</tt> <tt class="py-line"> <tt class="py-comment"># phrase when run from Jenkins on some tests</tt> </tt> |
| 767 | <a name="L615"></a><tt class="py-lineno"> 615</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"never"</tt> <tt class="py-op">)</tt> </tt> |
| 768 | <a name="L616"></a><tt class="py-lineno"> 616</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 769 | <a name="L617"></a><tt class="py-lineno"> 617</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": \n"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt> |
| 770 | <a name="L618"></a><tt class="py-lineno"> 618</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">after</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 771 | <a name="L619"></a><tt class="py-lineno"> 619</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-179" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-179', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 772 | <a name="L620"></a><tt class="py-lineno"> 620</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 773 | <a name="L621"></a><tt class="py-lineno"> 621</tt> <tt class="py-line"> <tt class="py-name">lines</tt> <tt class="py-op">=</tt> <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 774 | <a name="L622"></a><tt class="py-lineno"> 622</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">line</tt> <tt class="py-keyword">in</tt> <tt class="py-name">lines</tt><tt class="py-op">:</tt> </tt> |
| 775 | <a name="L623"></a><tt class="py-lineno"> 623</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">line</tt> </tt> |
| 776 | <a name="L624"></a><tt class="py-lineno"> 624</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">report</tt><tt class="py-op">:</tt> </tt> |
| 777 | <a name="L625"></a><tt class="py-lineno"> 625</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-180" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-180', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">wiki</tt><tt class="py-op">(</tt> <tt class="py-string">"<blockquote>"</tt> <tt class="py-op">)</tt> </tt> |
| 778 | <a name="L626"></a><tt class="py-lineno"> 626</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">line</tt> <tt class="py-keyword">in</tt> <tt class="py-name">lines</tt><tt class="py-op">[</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt> <tt class="py-op">]</tt><tt class="py-op">:</tt> </tt> |
| 779 | <a name="L627"></a><tt class="py-lineno"> 627</tt> <tt class="py-line"> <tt class="py-comment"># Bracket replacement is for Wiki-compliant</tt> </tt> |
| 780 | <a name="L628"></a><tt class="py-lineno"> 628</tt> <tt class="py-line"> <tt class="py-comment"># formatting. '<' or '>' are interpreted</tt> </tt> |
| 781 | <a name="L629"></a><tt class="py-lineno"> 629</tt> <tt class="py-line"> <tt class="py-comment"># as xml specific tags that cause errors</tt> </tt> |
| 782 | <a name="L630"></a><tt class="py-lineno"> 630</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-name">line</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">"<"</tt><tt class="py-op">,</tt> <tt class="py-string">"["</tt> <tt class="py-op">)</tt> </tt> |
| 783 | <a name="L631"></a><tt class="py-lineno"> 631</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-name">line</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">">"</tt><tt class="py-op">,</tt> <tt class="py-string">"]"</tt> <tt class="py-op">)</tt> </tt> |
| 784 | <a name="L632"></a><tt class="py-lineno"> 632</tt> <tt class="py-line"> <tt class="py-comment">#main.log.wiki( "\t" + line )</tt> </tt> |
| 785 | <a name="L633"></a><tt class="py-lineno"> 633</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-181" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-181', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">wiki</tt><tt class="py-op">(</tt> <tt class="py-name">line</tt> <tt class="py-op">+</tt> <tt class="py-string">"<br /> "</tt> <tt class="py-op">)</tt> </tt> |
| 786 | <a name="L634"></a><tt class="py-lineno"> 634</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-183" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.summary()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#summary"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.summary" class="py-name" href="#" onclick="return doclink('link-183', 'summary', 'link-183');">summary</a></tt><tt class="py-op">(</tt> <tt class="py-name">line</tt> <tt class="py-op">)</tt> </tt> |
| 787 | <a name="L635"></a><tt class="py-lineno"> 635</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-184" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-184', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">wiki</tt><tt class="py-op">(</tt> <tt class="py-string">"</blockquote>"</tt> <tt class="py-op">)</tt> </tt> |
| 788 | <a name="L636"></a><tt class="py-lineno"> 636</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-185" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-185', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-186" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.summary" class="py-name" href="#" onclick="return doclink('link-186', 'summary', 'link-183');">summary</a></tt><tt class="py-op">(</tt><tt class="py-string">"\n"</tt><tt class="py-op">)</tt> </tt> |
| 789 | <a name="L637"></a><tt class="py-lineno"> 637</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">lines</tt><tt class="py-op">[</tt> <tt class="py-number">2</tt> <tt class="py-op">]</tt> </tt> |
| 790 | <a name="L638"></a><tt class="py-lineno"> 638</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 791 | <a name="L639"></a><tt class="py-lineno"> 639</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-188" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-188', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 792 | <a name="L640"></a><tt class="py-lineno"> 640</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-189" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-189', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-190" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-190', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 793 | <a name="L641"></a><tt class="py-lineno"> 641</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-191" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-191', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 794 | <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-192" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-192', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 795 | <a name="L643"></a><tt class="py-lineno"> 643</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">:</tt> </tt> |
| 796 | <a name="L644"></a><tt class="py-lineno"> 644</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-193" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-193', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-194" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-194', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": TIMEOUT exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 797 | <a name="L645"></a><tt class="py-lineno"> 645</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-195" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-195', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-196" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-196', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 798 | <a name="L646"></a><tt class="py-lineno"> 646</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-197', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 799 | <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-198" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-198', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 800 | <a name="L648"></a><tt class="py-lineno"> 648</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 801 | <a name="L649"></a><tt class="py-lineno"> 649</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 802 | <a name="L650"></a><tt class="py-lineno"> 650</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-200" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-200', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 803 | <a name="L651"></a><tt class="py-lineno"> 651</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-201" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-201', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 804 | </div><a name="L652"></a><tt class="py-lineno"> 652</tt> <tt class="py-line"> </tt> |
| 805 | <a name="OnosDriver.createCellFile"></a><div id="OnosDriver.createCellFile-def"><a name="L653"></a><tt class="py-lineno"> 653</tt> <a class="py-toggle" href="#" id="OnosDriver.createCellFile-toggle" onclick="return toggle('OnosDriver.createCellFile');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#createCellFile">createCellFile</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">benchIp</tt><tt class="py-op">,</tt> <tt class="py-param">fileName</tt><tt class="py-op">,</tt> <tt class="py-param">mnIpAddrs</tt><tt class="py-op">,</tt> </tt> |
| 806 | <a name="L654"></a><tt class="py-lineno"> 654</tt> <tt class="py-line"> <tt class="py-param">appString</tt><tt class="py-op">,</tt> <tt class="py-param">onosIpAddrs</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 807 | </div><div id="OnosDriver.createCellFile-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.createCellFile-expanded"><a name="L655"></a><tt class="py-lineno"> 655</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 808 | <a name="L656"></a><tt class="py-lineno"> 656</tt> <tt class="py-line"><tt class="py-docstring"> Creates a cell file based on arguments</tt> </tt> |
| 809 | <a name="L657"></a><tt class="py-lineno"> 657</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 810 | <a name="L658"></a><tt class="py-lineno"> 658</tt> <tt class="py-line"><tt class="py-docstring"> * Bench IP address ( benchIp )</tt> </tt> |
| 811 | <a name="L659"></a><tt class="py-lineno"> 659</tt> <tt class="py-line"><tt class="py-docstring"> - Needed to copy the cell file over</tt> </tt> |
| 812 | <a name="L660"></a><tt class="py-lineno"> 660</tt> <tt class="py-line"><tt class="py-docstring"> * File name of the cell file ( fileName )</tt> </tt> |
| 813 | <a name="L661"></a><tt class="py-lineno"> 661</tt> <tt class="py-line"><tt class="py-docstring"> * Mininet IP address ( mnIpAddrs )</tt> </tt> |
| 814 | <a name="L662"></a><tt class="py-lineno"> 662</tt> <tt class="py-line"><tt class="py-docstring"> - Note that only 1 ip address is</tt> </tt> |
| 815 | <a name="L663"></a><tt class="py-lineno"> 663</tt> <tt class="py-line"><tt class="py-docstring"> supported currently</tt> </tt> |
| 816 | <a name="L664"></a><tt class="py-lineno"> 664</tt> <tt class="py-line"><tt class="py-docstring"> * ONOS IP addresses ( onosIpAddrs )</tt> </tt> |
| 817 | <a name="L665"></a><tt class="py-lineno"> 665</tt> <tt class="py-line"><tt class="py-docstring"> - Must be passed in as last arguments</tt> </tt> |
| 818 | <a name="L666"></a><tt class="py-lineno"> 666</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 819 | <a name="L667"></a><tt class="py-lineno"> 667</tt> <tt class="py-line"><tt class="py-docstring"> NOTE: Assumes cells are located at:</tt> </tt> |
| 820 | <a name="L668"></a><tt class="py-lineno"> 668</tt> <tt class="py-line"><tt class="py-docstring"> ~/<self.home>/tools/test/cells/</tt> </tt> |
| 821 | <a name="L669"></a><tt class="py-lineno"> 669</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 822 | <a name="L670"></a><tt class="py-lineno"> 670</tt> <tt class="py-line"> <tt class="py-comment"># Variable initialization</tt> </tt> |
| 823 | <a name="L671"></a><tt class="py-lineno"> 671</tt> <tt class="py-line"> <tt class="py-name">cellDirectory</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"/tools/test/cells/"</tt> </tt> |
| 824 | <a name="L672"></a><tt class="py-lineno"> 672</tt> <tt class="py-line"> <tt class="py-comment"># We want to create the cell file in the dependencies directory</tt> </tt> |
| 825 | <a name="L673"></a><tt class="py-lineno"> 673</tt> <tt class="py-line"> <tt class="py-comment"># of TestON first, then copy over to ONOS bench</tt> </tt> |
| 826 | <a name="L674"></a><tt class="py-lineno"> 674</tt> <tt class="py-line"> <tt class="py-name">tempDirectory</tt> <tt class="py-op">=</tt> <tt class="py-string">"/tmp/"</tt> </tt> |
| 827 | <a name="L675"></a><tt class="py-lineno"> 675</tt> <tt class="py-line"> <tt class="py-comment"># Create the cell file in the directory for writing ( w+ )</tt> </tt> |
| 828 | <a name="L676"></a><tt class="py-lineno"> 676</tt> <tt class="py-line"> <tt class="py-name">cellFile</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt> <tt class="py-name">tempDirectory</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt><tt class="py-op">,</tt> <tt class="py-string">'w+'</tt> <tt class="py-op">)</tt> </tt> |
| 829 | <a name="L677"></a><tt class="py-lineno"> 677</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt> <tt class="py-name">onosIpAddrs</tt><tt class="py-op">,</tt> <tt class="py-name">types</tt><tt class="py-op">.</tt><tt class="py-name">StringType</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 830 | <a name="L678"></a><tt class="py-lineno"> 678</tt> <tt class="py-line"> <tt class="py-name">onosIpAddrs</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">onosIpAddrs</tt> <tt class="py-op">]</tt> </tt> |
| 831 | <a name="L679"></a><tt class="py-lineno"> 679</tt> <tt class="py-line"> </tt> |
| 832 | <a name="L680"></a><tt class="py-lineno"> 680</tt> <tt class="py-line"> <tt class="py-comment"># App string is hardcoded environment variables</tt> </tt> |
| 833 | <a name="L681"></a><tt class="py-lineno"> 681</tt> <tt class="py-line"> <tt class="py-comment"># That you may wish to use by default on startup.</tt> </tt> |
| 834 | <a name="L682"></a><tt class="py-lineno"> 682</tt> <tt class="py-line"> <tt class="py-comment"># Note that you may not want certain apps listed</tt> </tt> |
| 835 | <a name="L683"></a><tt class="py-lineno"> 683</tt> <tt class="py-line"> <tt class="py-comment"># on here.</tt> </tt> |
| 836 | <a name="L684"></a><tt class="py-lineno"> 684</tt> <tt class="py-line"> <tt class="py-name">appString</tt> <tt class="py-op">=</tt> <tt class="py-string">"export ONOS_APPS="</tt> <tt class="py-op">+</tt> <tt class="py-name">appString</tt> </tt> |
| 837 | <a name="L685"></a><tt class="py-lineno"> 685</tt> <tt class="py-line"> <tt class="py-name">mnString</tt> <tt class="py-op">=</tt> <tt class="py-string">"export OCN="</tt> </tt> |
| 838 | <a name="L686"></a><tt class="py-lineno"> 686</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">mnIpAddrs</tt> <tt class="py-op">==</tt> <tt class="py-string">""</tt><tt class="py-op">:</tt> </tt> |
| 839 | <a name="L687"></a><tt class="py-lineno"> 687</tt> <tt class="py-line"> <tt class="py-name">mnString</tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt> </tt> |
| 840 | <a name="L688"></a><tt class="py-lineno"> 688</tt> <tt class="py-line"> <tt class="py-name">onosString</tt> <tt class="py-op">=</tt> <tt class="py-string">"export OC"</tt> </tt> |
| 841 | <a name="L689"></a><tt class="py-lineno"> 689</tt> <tt class="py-line"> <tt class="py-name">tempCount</tt> <tt class="py-op">=</tt> <tt class="py-number">1</tt> </tt> |
| 842 | <a name="L690"></a><tt class="py-lineno"> 690</tt> <tt class="py-line"> </tt> |
| 843 | <a name="L691"></a><tt class="py-lineno"> 691</tt> <tt class="py-line"> <tt class="py-comment"># Create ONOSNIC ip address prefix</tt> </tt> |
| 844 | <a name="L692"></a><tt class="py-lineno"> 692</tt> <tt class="py-line"> <tt class="py-name">tempOnosIp</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosIpAddrs</tt><tt class="py-op">[</tt> <tt class="py-number">0</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt> |
| 845 | <a name="L693"></a><tt class="py-lineno"> 693</tt> <tt class="py-line"> <tt class="py-name">tempList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> |
| 846 | <a name="L694"></a><tt class="py-lineno"> 694</tt> <tt class="py-line"> <tt class="py-name">tempList</tt> <tt class="py-op">=</tt> <tt class="py-name">tempOnosIp</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> |
| 847 | <a name="L695"></a><tt class="py-lineno"> 695</tt> <tt class="py-line"> <tt class="py-comment"># Omit last element of list to format for NIC</tt> </tt> |
| 848 | <a name="L696"></a><tt class="py-lineno"> 696</tt> <tt class="py-line"> <tt class="py-name">tempList</tt> <tt class="py-op">=</tt> <tt class="py-name">tempList</tt><tt class="py-op">[</tt> <tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt> <tt class="py-op">]</tt> </tt> |
| 849 | <a name="L697"></a><tt class="py-lineno"> 697</tt> <tt class="py-line"> <tt class="py-comment"># Structure the nic string ip</tt> </tt> |
| 850 | <a name="L698"></a><tt class="py-lineno"> 698</tt> <tt class="py-line"> <tt class="py-name">nicAddr</tt> <tt class="py-op">=</tt> <tt class="py-string">"."</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt> <tt class="py-name">tempList</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">".*"</tt> </tt> |
| 851 | <a name="L699"></a><tt class="py-lineno"> 699</tt> <tt class="py-line"> <tt class="py-name">onosNicString</tt> <tt class="py-op">=</tt> <tt class="py-string">"export ONOS_NIC="</tt> <tt class="py-op">+</tt> <tt class="py-name">nicAddr</tt> </tt> |
| 852 | <a name="L700"></a><tt class="py-lineno"> 700</tt> <tt class="py-line"> </tt> |
| 853 | <a name="L701"></a><tt class="py-lineno"> 701</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 854 | <a name="L702"></a><tt class="py-lineno"> 702</tt> <tt class="py-line"> <tt class="py-comment"># Start writing to file</tt> </tt> |
| 855 | <a name="L703"></a><tt class="py-lineno"> 703</tt> <tt class="py-line"> <tt class="py-name">cellFile</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt> <tt class="py-name">onosNicString</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">)</tt> </tt> |
| 856 | <a name="L704"></a><tt class="py-lineno"> 704</tt> <tt class="py-line"> </tt> |
| 857 | <a name="L705"></a><tt class="py-lineno"> 705</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">arg</tt> <tt class="py-keyword">in</tt> <tt class="py-name">onosIpAddrs</tt><tt class="py-op">:</tt> </tt> |
| 858 | <a name="L706"></a><tt class="py-lineno"> 706</tt> <tt class="py-line"> <tt class="py-comment"># For each argument in onosIpAddrs, write to file</tt> </tt> |
| 859 | <a name="L707"></a><tt class="py-lineno"> 707</tt> <tt class="py-line"> <tt class="py-comment"># Output should look like the following:</tt> </tt> |
| 860 | <a name="L708"></a><tt class="py-lineno"> 708</tt> <tt class="py-line"> <tt class="py-comment"># export OC1="10.128.20.11"</tt> </tt> |
| 861 | <a name="L709"></a><tt class="py-lineno"> 709</tt> <tt class="py-line"> <tt class="py-comment"># export OC2="10.128.20.12"</tt> </tt> |
| 862 | <a name="L710"></a><tt class="py-lineno"> 710</tt> <tt class="py-line"> <tt class="py-name">cellFile</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt> <tt class="py-name">onosString</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">tempCount</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 863 | <a name="L711"></a><tt class="py-lineno"> 711</tt> <tt class="py-line"> <tt class="py-string">"="</tt> <tt class="py-op">+</tt> <tt class="py-string">"\""</tt> <tt class="py-op">+</tt> <tt class="py-name">arg</tt> <tt class="py-op">+</tt> <tt class="py-string">"\""</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">)</tt> </tt> |
| 864 | <a name="L712"></a><tt class="py-lineno"> 712</tt> <tt class="py-line"> <tt class="py-name">tempCount</tt> <tt class="py-op">=</tt> <tt class="py-name">tempCount</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt> |
| 865 | <a name="L713"></a><tt class="py-lineno"> 713</tt> <tt class="py-line"> </tt> |
| 866 | <a name="L714"></a><tt class="py-lineno"> 714</tt> <tt class="py-line"> <tt class="py-name">cellFile</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt> <tt class="py-name">mnString</tt> <tt class="py-op">+</tt> <tt class="py-string">"\""</tt> <tt class="py-op">+</tt> <tt class="py-name">mnIpAddrs</tt> <tt class="py-op">+</tt> <tt class="py-string">"\""</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">)</tt> </tt> |
| 867 | <a name="L715"></a><tt class="py-lineno"> 715</tt> <tt class="py-line"> <tt class="py-name">cellFile</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt> <tt class="py-name">appString</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">)</tt> </tt> |
| 868 | <a name="L716"></a><tt class="py-lineno"> 716</tt> <tt class="py-line"> <tt class="py-name">cellFile</tt><tt class="py-op">.</tt><tt class="py-name">close</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 869 | <a name="L717"></a><tt class="py-lineno"> 717</tt> <tt class="py-line"> </tt> |
| 870 | <a name="L718"></a><tt class="py-lineno"> 718</tt> <tt class="py-line"> <tt class="py-comment"># We use os.system to send the command to TestON cluster</tt> </tt> |
| 871 | <a name="L719"></a><tt class="py-lineno"> 719</tt> <tt class="py-line"> <tt class="py-comment"># to account for the case in which TestON is not located</tt> </tt> |
| 872 | <a name="L720"></a><tt class="py-lineno"> 720</tt> <tt class="py-line"> <tt class="py-comment"># on the same cluster as the ONOS bench</tt> </tt> |
| 873 | <a name="L721"></a><tt class="py-lineno"> 721</tt> <tt class="py-line"> <tt class="py-comment"># Note that even if TestON is located on the same cluster</tt> </tt> |
| 874 | <a name="L722"></a><tt class="py-lineno"> 722</tt> <tt class="py-line"> <tt class="py-comment"># as ONOS bench, you must setup passwordless ssh</tt> </tt> |
| 875 | <a name="L723"></a><tt class="py-lineno"> 723</tt> <tt class="py-line"> <tt class="py-comment"># between TestON and ONOS bench in order to automate the test.</tt> </tt> |
| 876 | <a name="L724"></a><tt class="py-lineno"> 724</tt> <tt class="py-line"> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">system</tt><tt class="py-op">(</tt> <tt class="py-string">"scp "</tt> <tt class="py-op">+</tt> <tt class="py-name">tempDirectory</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> </tt> |
| 877 | <a name="L725"></a><tt class="py-lineno"> 725</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">user_name</tt> <tt class="py-op">+</tt> <tt class="py-string">"@"</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ip_address</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">cellDirectory</tt> <tt class="py-op">)</tt> </tt> |
| 878 | <a name="L726"></a><tt class="py-lineno"> 726</tt> <tt class="py-line"> </tt> |
| 879 | <a name="L727"></a><tt class="py-lineno"> 727</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 880 | <a name="L728"></a><tt class="py-lineno"> 728</tt> <tt class="py-line"> </tt> |
| 881 | <a name="L729"></a><tt class="py-lineno"> 729</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 882 | <a name="L730"></a><tt class="py-lineno"> 730</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-202" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-202', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-203" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-203', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 883 | <a name="L731"></a><tt class="py-lineno"> 731</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-205" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-205', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 884 | <a name="L732"></a><tt class="py-lineno"> 732</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.cleanup" class="py-name" href="#" onclick="return doclink('link-206', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 885 | <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-207" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-207', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 886 | <a name="L734"></a><tt class="py-lineno"> 734</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 887 | <a name="L735"></a><tt class="py-lineno"> 735</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-208" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-208', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 888 | <a name="L736"></a><tt class="py-lineno"> 736</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-209" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-209', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 889 | <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-210" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-210', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 890 | </div><a name="L738"></a><tt class="py-lineno"> 738</tt> <tt class="py-line"> </tt> |
| 891 | <a name="OnosDriver.setCell"></a><div id="OnosDriver.setCell-def"><a name="L739"></a><tt class="py-lineno"> 739</tt> <a class="py-toggle" href="#" id="OnosDriver.setCell-toggle" onclick="return toggle('OnosDriver.setCell');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#setCell">setCell</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">cellname</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 892 | </div><div id="OnosDriver.setCell-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.setCell-expanded"><a name="L740"></a><tt class="py-lineno"> 740</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 893 | <a name="L741"></a><tt class="py-lineno"> 741</tt> <tt class="py-line"><tt class="py-docstring"> Calls 'cell <name>' to set the environment variables on ONOSbench</tt> </tt> |
| 894 | <a name="L742"></a><tt class="py-lineno"> 742</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 895 | <a name="L743"></a><tt class="py-lineno"> 743</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt> |
| 896 | <a name="L744"></a><tt class="py-lineno"> 744</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 897 | <a name="L745"></a><tt class="py-lineno"> 745</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">cellname</tt><tt class="py-op">:</tt> </tt> |
| 898 | <a name="L746"></a><tt class="py-lineno"> 746</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-211" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-211', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-212" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-212', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Must define cellname"</tt> <tt class="py-op">)</tt> </tt> |
| 899 | <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-213" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-213', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 900 | <a name="L748"></a><tt class="py-lineno"> 748</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-214', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 901 | <a name="L749"></a><tt class="py-lineno"> 749</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 902 | <a name="L750"></a><tt class="py-lineno"> 750</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-215" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-215', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cell "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">cellname</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 903 | <a name="L751"></a><tt class="py-lineno"> 751</tt> <tt class="py-line"> <tt class="py-comment"># Expect the cellname in the ONOSCELL variable.</tt> </tt> |
| 904 | <a name="L752"></a><tt class="py-lineno"> 752</tt> <tt class="py-line"> <tt class="py-comment"># Note that this variable name is subject to change</tt> </tt> |
| 905 | <a name="L753"></a><tt class="py-lineno"> 753</tt> <tt class="py-line"> <tt class="py-comment"># and that this driver will have to change accordingly</tt> </tt> |
| 906 | <a name="L754"></a><tt class="py-lineno"> 754</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">cellname</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> |
| 907 | <a name="L755"></a><tt class="py-lineno"> 755</tt> <tt class="py-line"> <tt class="py-name">handleBefore</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 908 | <a name="L756"></a><tt class="py-lineno"> 756</tt> <tt class="py-line"> <tt class="py-name">handleAfter</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">after</tt> </tt> |
| 909 | <a name="L757"></a><tt class="py-lineno"> 757</tt> <tt class="py-line"> <tt class="py-comment"># Get the rest of the handle</tt> </tt> |
| 910 | <a name="L758"></a><tt class="py-lineno"> 758</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-216" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-216', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">""</tt><tt class="py-op">)</tt> </tt> |
| 911 | <a name="L759"></a><tt class="py-lineno"> 759</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">"\$"</tt><tt class="py-op">)</tt> </tt> |
| 912 | <a name="L760"></a><tt class="py-lineno"> 760</tt> <tt class="py-line"> <tt class="py-name">handleMore</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 913 | <a name="L761"></a><tt class="py-lineno"> 761</tt> <tt class="py-line"> </tt> |
| 914 | <a name="L762"></a><tt class="py-lineno"> 762</tt> <tt class="py-line"> <tt class="py-name">cell_result</tt> <tt class="py-op">=</tt> <tt class="py-name">handleBefore</tt> <tt class="py-op">+</tt> <tt class="py-name">handleAfter</tt> <tt class="py-op">+</tt> <tt class="py-name">handleMore</tt> </tt> |
| 915 | <a name="L763"></a><tt class="py-lineno"> 763</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">cell_result</tt> </tt> |
| 916 | <a name="L764"></a><tt class="py-lineno"> 764</tt> <tt class="py-line"> <tt class="py-keyword">if</tt><tt class="py-op">(</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">"No such cell"</tt><tt class="py-op">,</tt> <tt class="py-name">cell_result</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 917 | <a name="L765"></a><tt class="py-lineno"> 765</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-217" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-217', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-218" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-218', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Cell call returned: "</tt> <tt class="py-op">+</tt> <tt class="py-name">handleBefore</tt> <tt class="py-op">+</tt> </tt> |
| 918 | <a name="L766"></a><tt class="py-lineno"> 766</tt> <tt class="py-line"> <tt class="py-name">handleAfter</tt> <tt class="py-op">+</tt> <tt class="py-name">handleMore</tt> <tt class="py-op">)</tt> </tt> |
| 919 | <a name="L767"></a><tt class="py-lineno"> 767</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-219', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 920 | <a name="L768"></a><tt class="py-lineno"> 768</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-220', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 921 | <a name="L769"></a><tt class="py-lineno"> 769</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 922 | <a name="L770"></a><tt class="py-lineno"> 770</tt> <tt class="py-line"> </tt> |
| 923 | <a name="L771"></a><tt class="py-lineno"> 771</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 924 | <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-221" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-221', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-222" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-222', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 925 | <a name="L773"></a><tt class="py-lineno"> 773</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-223" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-223', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-224" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-224', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 926 | <a name="L774"></a><tt class="py-lineno"> 774</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-225" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-225', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 927 | <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-226" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-226', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 928 | <a name="L776"></a><tt class="py-lineno"> 776</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 929 | <a name="L777"></a><tt class="py-lineno"> 777</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-227" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-227', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 930 | <a name="L778"></a><tt class="py-lineno"> 778</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-228', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 931 | <a name="L779"></a><tt class="py-lineno"> 779</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-229', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 932 | </div><a name="L780"></a><tt class="py-lineno"> 780</tt> <tt class="py-line"> </tt> |
| 933 | <a name="OnosDriver.verifyCell"></a><div id="OnosDriver.verifyCell-def"><a name="L781"></a><tt class="py-lineno"> 781</tt> <a class="py-toggle" href="#" id="OnosDriver.verifyCell-toggle" onclick="return toggle('OnosDriver.verifyCell');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#verifyCell">verifyCell</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 934 | </div><div id="OnosDriver.verifyCell-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.verifyCell-expanded"><a name="L782"></a><tt class="py-lineno"> 782</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 935 | <a name="L783"></a><tt class="py-lineno"> 783</tt> <tt class="py-line"><tt class="py-docstring"> Calls 'onos-verify-cell' to check for cell installation</tt> </tt> |
| 936 | <a name="L784"></a><tt class="py-lineno"> 784</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 937 | <a name="L785"></a><tt class="py-lineno"> 785</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Add meaningful expect value</tt> </tt> |
| 938 | <a name="L786"></a><tt class="py-lineno"> 786</tt> <tt class="py-line"> </tt> |
| 939 | <a name="L787"></a><tt class="py-lineno"> 787</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 940 | <a name="L788"></a><tt class="py-lineno"> 788</tt> <tt class="py-line"> <tt class="py-comment"># Clean handle by sending empty and expecting $</tt> </tt> |
| 941 | <a name="L789"></a><tt class="py-lineno"> 789</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-230" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-230', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 942 | <a name="L790"></a><tt class="py-lineno"> 790</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 943 | <a name="L791"></a><tt class="py-lineno"> 791</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-231" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-231', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-verify-cell"</tt> <tt class="py-op">)</tt> </tt> |
| 944 | <a name="L792"></a><tt class="py-lineno"> 792</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 945 | <a name="L793"></a><tt class="py-lineno"> 793</tt> <tt class="py-line"> <tt class="py-name">handleBefore</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 946 | <a name="L794"></a><tt class="py-lineno"> 794</tt> <tt class="py-line"> <tt class="py-name">handleAfter</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">after</tt> </tt> |
| 947 | <a name="L795"></a><tt class="py-lineno"> 795</tt> <tt class="py-line"> <tt class="py-comment"># Get the rest of the handle</tt> </tt> |
| 948 | <a name="L796"></a><tt class="py-lineno"> 796</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-232" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-232', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 949 | <a name="L797"></a><tt class="py-lineno"> 797</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 950 | <a name="L798"></a><tt class="py-lineno"> 798</tt> <tt class="py-line"> <tt class="py-name">handleMore</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 951 | <a name="L799"></a><tt class="py-lineno"> 799</tt> <tt class="py-line"> </tt> |
| 952 | <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-233" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-233', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Verify cell returned: "</tt> <tt class="py-op">+</tt> <tt class="py-name">handleBefore</tt> <tt class="py-op">+</tt> </tt> |
| 953 | <a name="L801"></a><tt class="py-lineno"> 801</tt> <tt class="py-line"> <tt class="py-name">handleAfter</tt> <tt class="py-op">+</tt> <tt class="py-name">handleMore</tt> <tt class="py-op">)</tt> </tt> |
| 954 | <a name="L802"></a><tt class="py-lineno"> 802</tt> <tt class="py-line"> </tt> |
| 955 | <a name="L803"></a><tt class="py-lineno"> 803</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 956 | <a name="L804"></a><tt class="py-lineno"> 804</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">ExceptionPexpect</tt> <tt class="py-keyword">as</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt> |
| 957 | <a name="L805"></a><tt class="py-lineno"> 805</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-234" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-234', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-235" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-235', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Pexpect exception found of type "</tt> <tt class="py-op">+</tt> </tt> |
| 958 | <a name="L806"></a><tt class="py-lineno"> 806</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt> <tt class="py-name">e</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 959 | <a name="L807"></a><tt class="py-lineno"> 807</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-237" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-237', 'error', 'link-12');">error</a></tt> <tt class="py-op">(</tt> <tt class="py-name">e</tt><tt class="py-op">.</tt><tt class="py-name">get_trace</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 960 | <a name="L808"></a><tt class="py-lineno"> 808</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-238" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-238', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-239" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-239', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 961 | <a name="L809"></a><tt class="py-lineno"> 809</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-240', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 962 | <a name="L810"></a><tt class="py-lineno"> 810</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.exit" class="py-name" href="#" onclick="return doclink('link-241', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 963 | <a name="L811"></a><tt class="py-lineno"> 811</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 964 | <a name="L812"></a><tt class="py-lineno"> 812</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-242', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 965 | <a name="L813"></a><tt class="py-lineno"> 813</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-243" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-243', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 966 | <a name="L814"></a><tt class="py-lineno"> 814</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-244" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-244', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 967 | </div><a name="L815"></a><tt class="py-lineno"> 815</tt> <tt class="py-line"> </tt> |
| 968 | <a name="OnosDriver.onosCfgSet"></a><div id="OnosDriver.onosCfgSet-def"><a name="L816"></a><tt class="py-lineno"> 816</tt> <a class="py-toggle" href="#" id="OnosDriver.onosCfgSet-toggle" onclick="return toggle('OnosDriver.onosCfgSet');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosCfgSet">onosCfgSet</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ONOSIp</tt><tt class="py-op">,</tt> <tt class="py-param">configName</tt><tt class="py-op">,</tt> <tt class="py-param">configParam</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 969 | </div><div id="OnosDriver.onosCfgSet-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosCfgSet-expanded"><a name="L817"></a><tt class="py-lineno"> 817</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 970 | <a name="L818"></a><tt class="py-lineno"> 818</tt> <tt class="py-line"><tt class="py-docstring"> Uses 'onos <node-ip> cfg set' to change a parameter value of an</tt> </tt> |
| 971 | <a name="L819"></a><tt class="py-lineno"> 819</tt> <tt class="py-line"><tt class="py-docstring"> application.</tt> </tt> |
| 972 | <a name="L820"></a><tt class="py-lineno"> 820</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 973 | <a name="L821"></a><tt class="py-lineno"> 821</tt> <tt class="py-line"><tt class="py-docstring"> ex)</tt> </tt> |
| 974 | <a name="L822"></a><tt class="py-lineno"> 822</tt> <tt class="py-line"><tt class="py-docstring"> onos 10.0.0.1 cfg set org.onosproject.myapp appSetting 1</tt> </tt> |
| 975 | <a name="L823"></a><tt class="py-lineno"> 823</tt> <tt class="py-line"><tt class="py-docstring"> ONOSIp = '10.0.0.1'</tt> </tt> |
| 976 | <a name="L824"></a><tt class="py-lineno"> 824</tt> <tt class="py-line"><tt class="py-docstring"> configName = 'org.onosproject.myapp'</tt> </tt> |
| 977 | <a name="L825"></a><tt class="py-lineno"> 825</tt> <tt class="py-line"><tt class="py-docstring"> configParam = 'appSetting 1'</tt> </tt> |
| 978 | <a name="L826"></a><tt class="py-lineno"> 826</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 979 | <a name="L827"></a><tt class="py-lineno"> 827</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">5</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 980 | <a name="L828"></a><tt class="py-lineno"> 828</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 981 | <a name="L829"></a><tt class="py-lineno"> 829</tt> <tt class="py-line"> <tt class="py-name">cfgStr</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-string">"onos "</tt><tt class="py-op">+</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIp</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">" cfg set "</tt><tt class="py-op">+</tt> </tt> |
| 982 | <a name="L830"></a><tt class="py-lineno"> 830</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">configName</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> </tt> |
| 983 | <a name="L831"></a><tt class="py-lineno"> 831</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">configParam</tt><tt class="py-op">)</tt> </tt> |
| 984 | <a name="L832"></a><tt class="py-lineno"> 832</tt> <tt class="py-line"> <tt class="py-op">)</tt> </tt> |
| 985 | <a name="L833"></a><tt class="py-lineno"> 833</tt> <tt class="py-line"> </tt> |
| 986 | <a name="L834"></a><tt class="py-lineno"> 834</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-245" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-245', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 987 | <a name="L835"></a><tt class="py-lineno"> 835</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">":~"</tt> <tt class="py-op">)</tt> </tt> |
| 988 | <a name="L836"></a><tt class="py-lineno"> 836</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-246" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-246', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cfgStr</tt> <tt class="py-op">)</tt> </tt> |
| 989 | <a name="L837"></a><tt class="py-lineno"> 837</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">"cfg set"</tt><tt class="py-op">)</tt> </tt> |
| 990 | <a name="L838"></a><tt class="py-lineno"> 838</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">":~"</tt> <tt class="py-op">)</tt> </tt> |
| 991 | <a name="L839"></a><tt class="py-lineno"> 839</tt> <tt class="py-line"> </tt> |
| 992 | <a name="L840"></a><tt class="py-lineno"> 840</tt> <tt class="py-line"> <tt class="py-name">paramValue</tt> <tt class="py-op">=</tt> <tt class="py-name">configParam</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> |
| 993 | <a name="L841"></a><tt class="py-lineno"> 841</tt> <tt class="py-line"> <tt class="py-name">paramName</tt> <tt class="py-op">=</tt> <tt class="py-name">configParam</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> |
| 994 | <a name="L842"></a><tt class="py-lineno"> 842</tt> <tt class="py-line"> </tt> |
| 995 | <a name="L843"></a><tt class="py-lineno"> 843</tt> <tt class="py-line"> <tt class="py-name">checkStr</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-string">"onos "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIp</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">""" cfg get " """</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">configName</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">paramName</tt> <tt class="py-op">+</tt> <tt class="py-string">""" " """</tt><tt class="py-op">)</tt> </tt> |
| 996 | <a name="L844"></a><tt class="py-lineno"> 844</tt> <tt class="py-line"> </tt> |
| 997 | <a name="L845"></a><tt class="py-lineno"> 845</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-247" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-247', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">checkStr</tt> <tt class="py-op">)</tt> </tt> |
| 998 | <a name="L846"></a><tt class="py-lineno"> 846</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">":~"</tt> <tt class="py-op">)</tt> </tt> |
| 999 | <a name="L847"></a><tt class="py-lineno"> 847</tt> <tt class="py-line"> </tt> |
| 1000 | <a name="L848"></a><tt class="py-lineno"> 848</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"value="</tt> <tt class="py-op">+</tt> <tt class="py-name">paramValue</tt> <tt class="py-op">+</tt> <tt class="py-string">","</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt><tt class="py-op">:</tt> </tt> |
| 1001 | <a name="L849"></a><tt class="py-lineno"> 849</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-248" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-248', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"cfg "</tt> <tt class="py-op">+</tt> <tt class="py-name">configName</tt> <tt class="py-op">+</tt> <tt class="py-string">" successfully set to "</tt> <tt class="py-op">+</tt> <tt class="py-name">configParam</tt><tt class="py-op">)</tt> </tt> |
| 1002 | <a name="L850"></a><tt class="py-lineno"> 850</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1003 | <a name="L851"></a><tt class="py-lineno"> 851</tt> <tt class="py-line"> </tt> |
| 1004 | <a name="L852"></a><tt class="py-lineno"> 852</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">ExceptionPexpect</tt> <tt class="py-keyword">as</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt> |
| 1005 | <a name="L853"></a><tt class="py-lineno"> 853</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-249" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-249', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-250" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-250', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Pexpect exception found of type "</tt> <tt class="py-op">+</tt> </tt> |
| 1006 | <a name="L854"></a><tt class="py-lineno"> 854</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt> <tt class="py-name">e</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1007 | <a name="L855"></a><tt class="py-lineno"> 855</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-251" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-251', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-252" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-252', 'error', 'link-12');">error</a></tt> <tt class="py-op">(</tt> <tt class="py-name">e</tt><tt class="py-op">.</tt><tt class="py-name">get_trace</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1008 | <a name="L856"></a><tt class="py-lineno"> 856</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-253" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-253', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-254" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-254', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1009 | <a name="L857"></a><tt class="py-lineno"> 857</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-255', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1010 | <a name="L858"></a><tt class="py-lineno"> 858</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-256', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1011 | <a name="L859"></a><tt class="py-lineno"> 859</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1012 | <a name="L860"></a><tt class="py-lineno"> 860</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-257', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1013 | <a name="L861"></a><tt class="py-lineno"> 861</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.cleanup" class="py-name" href="#" onclick="return doclink('link-258', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1014 | <a name="L862"></a><tt class="py-lineno"> 862</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-259" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-259', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1015 | <a name="L863"></a><tt class="py-lineno"> 863</tt> <tt class="py-line"> </tt> |
| 1016 | <a name="L864"></a><tt class="py-lineno"> 864</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> |
| 1017 | <a name="L865"></a><tt class="py-lineno"> 865</tt> <tt class="py-line"> </tt> |
| 1018 | <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-260" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-260', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-261" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-261', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt><tt class="py-string">"CFG SET FAILURE: "</tt> <tt class="py-op">+</tt> <tt class="py-name">configName</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">configParam</tt> <tt class="py-op">)</tt> </tt> |
| 1019 | <a name="L867"></a><tt class="py-lineno"> 867</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-262" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-262', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg get"</tt><tt class="py-op">)</tt> </tt> |
| 1020 | <a name="L868"></a><tt class="py-lineno"> 868</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">"\$"</tt><tt class="py-op">)</tt> </tt> |
| 1021 | <a name="L869"></a><tt class="py-lineno"> 869</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1022 | <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 class="py-name">ONOSbench</tt><tt class="py-op">.</tt><tt id="link-263" class="py-name" targets="Method TestON.drivers.common.cli.onosdriver.OnosDriver.logReport()=TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#logReport"><a title="TestON.drivers.common.cli.onosdriver.OnosDriver.logReport" class="py-name" href="#" onclick="return doclink('link-263', 'logReport', 'link-263');">logReport</a></tt><tt class="py-op">(</tt> <tt class="py-name">ONOSIp</tt><tt class="py-op">,</tt> <tt class="py-op">[</tt><tt class="py-string">"ERROR"</tt><tt class="py-op">,</tt><tt class="py-string">"WARN"</tt><tt class="py-op">,</tt><tt class="py-string">"EXCEPT"</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-string">"d"</tt><tt class="py-op">)</tt> </tt> |
| 1023 | <a name="L871"></a><tt class="py-lineno"> 871</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1024 | </div><a name="L872"></a><tt class="py-lineno"> 872</tt> <tt class="py-line"> </tt> |
| 1025 | <a name="L873"></a><tt class="py-lineno"> 873</tt> <tt class="py-line"> </tt> |
| 1026 | <a name="OnosDriver.onosCli"></a><div id="OnosDriver.onosCli-def"><a name="L874"></a><tt class="py-lineno"> 874</tt> <a class="py-toggle" href="#" id="OnosDriver.onosCli-toggle" onclick="return toggle('OnosDriver.onosCli');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosCli">onosCli</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ONOSIp</tt><tt class="py-op">,</tt> <tt class="py-param">cmdstr</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1027 | </div><div id="OnosDriver.onosCli-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosCli-expanded"><a name="L875"></a><tt class="py-lineno"> 875</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1028 | <a name="L876"></a><tt class="py-lineno"> 876</tt> <tt class="py-line"><tt class="py-docstring"> Uses 'onos' command to send various ONOS CLI arguments.</tt> </tt> |
| 1029 | <a name="L877"></a><tt class="py-lineno"> 877</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 1030 | <a name="L878"></a><tt class="py-lineno"> 878</tt> <tt class="py-line"><tt class="py-docstring"> * ONOSIp: specify the ip of the cell machine</tt> </tt> |
| 1031 | <a name="L879"></a><tt class="py-lineno"> 879</tt> <tt class="py-line"><tt class="py-docstring"> * cmdstr: specify the command string to send</tt> </tt> |
| 1032 | <a name="L880"></a><tt class="py-lineno"> 880</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1033 | <a name="L881"></a><tt class="py-lineno"> 881</tt> <tt class="py-line"><tt class="py-docstring"> This function is intended to expose the entire karaf</tt> </tt> |
| 1034 | <a name="L882"></a><tt class="py-lineno"> 882</tt> <tt class="py-line"><tt class="py-docstring"> CLI commands for ONOS. Try to use this function first</tt> </tt> |
| 1035 | <a name="L883"></a><tt class="py-lineno"> 883</tt> <tt class="py-line"><tt class="py-docstring"> before attempting to write a ONOS CLI specific driver</tt> </tt> |
| 1036 | <a name="L884"></a><tt class="py-lineno"> 884</tt> <tt class="py-line"><tt class="py-docstring"> function.</tt> </tt> |
| 1037 | <a name="L885"></a><tt class="py-lineno"> 885</tt> <tt class="py-line"><tt class="py-docstring"> You can see a list of available 'cmdstr' arguments</tt> </tt> |
| 1038 | <a name="L886"></a><tt class="py-lineno"> 886</tt> <tt class="py-line"><tt class="py-docstring"> by starting onos, and typing in 'onos' to enter the</tt> </tt> |
| 1039 | <a name="L887"></a><tt class="py-lineno"> 887</tt> <tt class="py-line"><tt class="py-docstring"> onos> CLI. Then, type 'help' to see the list of</tt> </tt> |
| 1040 | <a name="L888"></a><tt class="py-lineno"> 888</tt> <tt class="py-line"><tt class="py-docstring"> available commands.</tt> </tt> |
| 1041 | <a name="L889"></a><tt class="py-lineno"> 889</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1042 | <a name="L890"></a><tt class="py-lineno"> 890</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1043 | <a name="L891"></a><tt class="py-lineno"> 891</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ONOSIp</tt><tt class="py-op">:</tt> </tt> |
| 1044 | <a name="L892"></a><tt class="py-lineno"> 892</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-264" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-264', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-265" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-265', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"You must specify the IP address"</tt> <tt class="py-op">)</tt> </tt> |
| 1045 | <a name="L893"></a><tt class="py-lineno"> 893</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1046 | <a name="L894"></a><tt class="py-lineno"> 894</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">cmdstr</tt><tt class="py-op">:</tt> </tt> |
| 1047 | <a name="L895"></a><tt class="py-lineno"> 895</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-266', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-267" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-267', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"You must specify the command string"</tt> <tt class="py-op">)</tt> </tt> |
| 1048 | <a name="L896"></a><tt class="py-lineno"> 896</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1049 | <a name="L897"></a><tt class="py-lineno"> 897</tt> <tt class="py-line"> </tt> |
| 1050 | <a name="L898"></a><tt class="py-lineno"> 898</tt> <tt class="py-line"> <tt class="py-name">cmdstr</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">cmdstr</tt> <tt class="py-op">)</tt> </tt> |
| 1051 | <a name="L899"></a><tt class="py-lineno"> 899</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-268" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-268', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1052 | <a name="L900"></a><tt class="py-lineno"> 900</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1053 | <a name="L901"></a><tt class="py-lineno"> 901</tt> <tt class="py-line"> </tt> |
| 1054 | <a name="L902"></a><tt class="py-lineno"> 902</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-269" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-269', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos -w "</tt> <tt class="py-op">+</tt> <tt class="py-name">ONOSIp</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">cmdstr</tt> <tt class="py-op">)</tt> </tt> |
| 1055 | <a name="L903"></a><tt class="py-lineno"> 903</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1056 | <a name="L904"></a><tt class="py-lineno"> 904</tt> <tt class="py-line"> </tt> |
| 1057 | <a name="L905"></a><tt class="py-lineno"> 905</tt> <tt class="py-line"> <tt class="py-name">handleBefore</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1058 | <a name="L906"></a><tt class="py-lineno"> 906</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"handle_before = "</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1059 | <a name="L907"></a><tt class="py-lineno"> 907</tt> <tt class="py-line"> <tt class="py-comment"># handleAfter = str( self.handle.after )</tt> </tt> |
| 1060 | <a name="L908"></a><tt class="py-lineno"> 908</tt> <tt class="py-line"> </tt> |
| 1061 | <a name="L909"></a><tt class="py-lineno"> 909</tt> <tt class="py-line"> <tt class="py-comment"># self.handle.sendline( "" )</tt> </tt> |
| 1062 | <a name="L910"></a><tt class="py-lineno"> 910</tt> <tt class="py-line"> <tt class="py-comment"># self.handle.expect( "\$" )</tt> </tt> |
| 1063 | <a name="L911"></a><tt class="py-lineno"> 911</tt> <tt class="py-line"> <tt class="py-comment"># handleMore = str( self.handle.before )</tt> </tt> |
| 1064 | <a name="L912"></a><tt class="py-lineno"> 912</tt> <tt class="py-line"> </tt> |
| 1065 | <a name="L913"></a><tt class="py-lineno"> 913</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-270" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-270', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Command sent successfully"</tt> <tt class="py-op">)</tt> </tt> |
| 1066 | <a name="L914"></a><tt class="py-lineno"> 914</tt> <tt class="py-line"> </tt> |
| 1067 | <a name="L915"></a><tt class="py-lineno"> 915</tt> <tt class="py-line"> <tt class="py-comment"># Obtain return handle that consists of result from</tt> </tt> |
| 1068 | <a name="L916"></a><tt class="py-lineno"> 916</tt> <tt class="py-line"> <tt class="py-comment"># the onos command. The string may need to be</tt> </tt> |
| 1069 | <a name="L917"></a><tt class="py-lineno"> 917</tt> <tt class="py-line"> <tt class="py-comment"># configured further.</tt> </tt> |
| 1070 | <a name="L918"></a><tt class="py-lineno"> 918</tt> <tt class="py-line"> <tt class="py-comment"># returnString = handleBefore + handleAfter</tt> </tt> |
| 1071 | <a name="L919"></a><tt class="py-lineno"> 919</tt> <tt class="py-line"> <tt class="py-name">returnString</tt> <tt class="py-op">=</tt> <tt class="py-name">handleBefore</tt> </tt> |
| 1072 | <a name="L920"></a><tt class="py-lineno"> 920</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"return_string = "</tt><tt class="py-op">,</tt> <tt class="py-name">returnString</tt> </tt> |
| 1073 | <a name="L921"></a><tt class="py-lineno"> 921</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">returnString</tt> </tt> |
| 1074 | <a name="L922"></a><tt class="py-lineno"> 922</tt> <tt class="py-line"> </tt> |
| 1075 | <a name="L923"></a><tt class="py-lineno"> 923</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1076 | <a name="L924"></a><tt class="py-lineno"> 924</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-272" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-272', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1077 | <a name="L925"></a><tt class="py-lineno"> 925</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-273', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-274" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-274', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1078 | <a name="L926"></a><tt class="py-lineno"> 926</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-275" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-275', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1079 | <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-276" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-276', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1080 | <a name="L928"></a><tt class="py-lineno"> 928</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1081 | <a name="L929"></a><tt class="py-lineno"> 929</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-277" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-277', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1082 | <a name="L930"></a><tt class="py-lineno"> 930</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-278" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-278', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1083 | <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-279" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-279', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1084 | </div><a name="L932"></a><tt class="py-lineno"> 932</tt> <tt class="py-line"> </tt> |
| 1085 | <a name="OnosDriver.onosInstall"></a><div id="OnosDriver.onosInstall-def"><a name="L933"></a><tt class="py-lineno"> 933</tt> <a class="py-toggle" href="#" id="OnosDriver.onosInstall-toggle" onclick="return toggle('OnosDriver.onosInstall');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosInstall">onosInstall</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">options</tt><tt class="py-op">=</tt><tt class="py-string">"-f"</tt><tt class="py-op">,</tt> <tt class="py-param">node</tt><tt class="py-op">=</tt><tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1086 | </div><div id="OnosDriver.onosInstall-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosInstall-expanded"><a name="L934"></a><tt class="py-lineno"> 934</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1087 | <a name="L935"></a><tt class="py-lineno"> 935</tt> <tt class="py-line"><tt class="py-docstring"> Installs ONOS bits on the designated cell machine.</tt> </tt> |
| 1088 | <a name="L936"></a><tt class="py-lineno"> 936</tt> <tt class="py-line"><tt class="py-docstring"> If -f option is provided, it also forces an uninstall.</tt> </tt> |
| 1089 | <a name="L937"></a><tt class="py-lineno"> 937</tt> <tt class="py-line"><tt class="py-docstring"> Presently, install also includes onos-push-bits and</tt> </tt> |
| 1090 | <a name="L938"></a><tt class="py-lineno"> 938</tt> <tt class="py-line"><tt class="py-docstring"> onos-config within.</tt> </tt> |
| 1091 | <a name="L939"></a><tt class="py-lineno"> 939</tt> <tt class="py-line"><tt class="py-docstring"> The node option allows you to selectively only push the jar</tt> </tt> |
| 1092 | <a name="L940"></a><tt class="py-lineno"> 940</tt> <tt class="py-line"><tt class="py-docstring"> files to certain onos nodes</tt> </tt> |
| 1093 | <a name="L941"></a><tt class="py-lineno"> 941</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1094 | <a name="L942"></a><tt class="py-lineno"> 942</tt> <tt class="py-line"><tt class="py-docstring"> Returns: main.TRUE on success and main.FALSE on failure</tt> </tt> |
| 1095 | <a name="L943"></a><tt class="py-lineno"> 943</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1096 | <a name="L944"></a><tt class="py-lineno"> 944</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1097 | <a name="L945"></a><tt class="py-lineno"> 945</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">options</tt><tt class="py-op">:</tt> </tt> |
| 1098 | <a name="L946"></a><tt class="py-lineno"> 946</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-280" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-280', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-install "</tt> <tt class="py-op">+</tt> <tt class="py-name">options</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt> </tt> |
| 1099 | <a name="L947"></a><tt class="py-lineno"> 947</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1100 | <a name="L948"></a><tt class="py-lineno"> 948</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-281" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-281', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-install "</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt> </tt> |
| 1101 | <a name="L949"></a><tt class="py-lineno"> 949</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"onos-install "</tt> <tt class="py-op">)</tt> </tt> |
| 1102 | <a name="L950"></a><tt class="py-lineno"> 950</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: this timeout may need to change depending on the network</tt> </tt> |
| 1103 | <a name="L951"></a><tt class="py-lineno"> 951</tt> <tt class="py-line"> <tt class="py-comment"># and size of ONOS</tt> </tt> |
| 1104 | <a name="L952"></a><tt class="py-lineno"> 952</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> <tt class="py-string">"Network\sis\sunreachable"</tt><tt class="py-op">,</tt> </tt> |
| 1105 | <a name="L953"></a><tt class="py-lineno"> 953</tt> <tt class="py-line"> <tt class="py-string">"onos\sstart/running,\sprocess"</tt><tt class="py-op">,</tt> </tt> |
| 1106 | <a name="L954"></a><tt class="py-lineno"> 954</tt> <tt class="py-line"> <tt class="py-string">"ONOS\sis\salready\sinstalled"</tt><tt class="py-op">,</tt> </tt> |
| 1107 | <a name="L955"></a><tt class="py-lineno"> 955</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt> |
| 1108 | <a name="L956"></a><tt class="py-lineno"> 956</tt> <tt class="py-line"> </tt> |
| 1109 | <a name="L957"></a><tt class="py-lineno"> 957</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1110 | <a name="L958"></a><tt class="py-lineno"> 958</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-282', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"Network is unreachable"</tt> <tt class="py-op">)</tt> </tt> |
| 1111 | <a name="L959"></a><tt class="py-lineno"> 959</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1112 | <a name="L960"></a><tt class="py-lineno"> 960</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1113 | <a name="L961"></a><tt class="py-lineno"> 961</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-283" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-283', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 1114 | <a name="L962"></a><tt class="py-lineno"> 962</tt> <tt class="py-line"> <tt class="py-string">"ONOS was installed on "</tt> <tt class="py-op">+</tt> </tt> |
| 1115 | <a name="L963"></a><tt class="py-lineno"> 963</tt> <tt class="py-line"> <tt class="py-name">node</tt> <tt class="py-op">+</tt> </tt> |
| 1116 | <a name="L964"></a><tt class="py-lineno"> 964</tt> <tt class="py-line"> <tt class="py-string">" and started"</tt> <tt class="py-op">)</tt> </tt> |
| 1117 | <a name="L965"></a><tt class="py-lineno"> 965</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1118 | <a name="L966"></a><tt class="py-lineno"> 966</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt> |
| 1119 | <a name="L967"></a><tt class="py-lineno"> 967</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS is already installed on "</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt> </tt> |
| 1120 | <a name="L968"></a><tt class="py-lineno"> 968</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1121 | <a name="L969"></a><tt class="py-lineno"> 969</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt> |
| 1122 | <a name="L970"></a><tt class="py-lineno"> 970</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-285" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-285', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 1123 | <a name="L971"></a><tt class="py-lineno"> 971</tt> <tt class="py-line"> <tt class="py-string">"Installation of ONOS on "</tt> <tt class="py-op">+</tt> </tt> |
| 1124 | <a name="L972"></a><tt class="py-lineno"> 972</tt> <tt class="py-line"> <tt class="py-name">node</tt> <tt class="py-op">+</tt> </tt> |
| 1125 | <a name="L973"></a><tt class="py-lineno"> 973</tt> <tt class="py-line"> <tt class="py-string">" timed out"</tt> <tt class="py-op">)</tt> </tt> |
| 1126 | <a name="L974"></a><tt class="py-lineno"> 974</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1127 | <a name="L975"></a><tt class="py-lineno"> 975</tt> <tt class="py-line"> </tt> |
| 1128 | <a name="L976"></a><tt class="py-lineno"> 976</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1129 | <a name="L977"></a><tt class="py-lineno"> 977</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-286" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-286', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-287" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-287', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1130 | <a name="L978"></a><tt class="py-lineno"> 978</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-289" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-289', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1131 | <a name="L979"></a><tt class="py-lineno"> 979</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.cleanup" class="py-name" href="#" onclick="return doclink('link-290', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1132 | <a name="L980"></a><tt class="py-lineno"> 980</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-291', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1133 | <a name="L981"></a><tt class="py-lineno"> 981</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1134 | <a name="L982"></a><tt class="py-lineno"> 982</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-292" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-292', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1135 | <a name="L983"></a><tt class="py-lineno"> 983</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.cleanup" class="py-name" href="#" onclick="return doclink('link-293', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1136 | <a name="L984"></a><tt class="py-lineno"> 984</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-294" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-294', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1137 | </div><a name="L985"></a><tt class="py-lineno"> 985</tt> <tt class="py-line"> </tt> |
| 1138 | <a name="OnosDriver.onosStart"></a><div id="OnosDriver.onosStart-def"><a name="L986"></a><tt class="py-lineno"> 986</tt> <a class="py-toggle" href="#" id="OnosDriver.onosStart-toggle" onclick="return toggle('OnosDriver.onosStart');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStart">onosStart</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">nodeIp</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1139 | </div><div id="OnosDriver.onosStart-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosStart-expanded"><a name="L987"></a><tt class="py-lineno"> 987</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1140 | <a name="L988"></a><tt class="py-lineno"> 988</tt> <tt class="py-line"><tt class="py-docstring"> Calls onos command: 'onos-service [<node-ip>] start'</tt> </tt> |
| 1141 | <a name="L989"></a><tt class="py-lineno"> 989</tt> <tt class="py-line"><tt class="py-docstring"> This command is a remote management of the ONOS upstart daemon</tt> </tt> |
| 1142 | <a name="L990"></a><tt class="py-lineno"> 990</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1143 | <a name="L991"></a><tt class="py-lineno"> 991</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1144 | <a name="L992"></a><tt class="py-lineno"> 992</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-295" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-295', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1145 | <a name="L993"></a><tt class="py-lineno"> 993</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1146 | <a name="L994"></a><tt class="py-lineno"> 994</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-296" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-296', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-service "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1147 | <a name="L995"></a><tt class="py-lineno"> 995</tt> <tt class="py-line"> <tt class="py-string">" start"</tt> <tt class="py-op">)</tt> </tt> |
| 1148 | <a name="L996"></a><tt class="py-lineno"> 996</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 1149 | <a name="L997"></a><tt class="py-lineno"> 997</tt> <tt class="py-line"> <tt class="py-string">"Job\sis\salready\srunning"</tt><tt class="py-op">,</tt> </tt> |
| 1150 | <a name="L998"></a><tt class="py-lineno"> 998</tt> <tt class="py-line"> <tt class="py-string">"start/running"</tt><tt class="py-op">,</tt> </tt> |
| 1151 | <a name="L999"></a><tt class="py-lineno"> 999</tt> <tt class="py-line"> <tt class="py-string">"Unknown\sinstance"</tt><tt class="py-op">,</tt> </tt> |
| 1152 | <a name="L1000"></a><tt class="py-lineno">1000</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">120</tt> <tt class="py-op">)</tt> </tt> |
| 1153 | <a name="L1001"></a><tt class="py-lineno">1001</tt> <tt class="py-line"> </tt> |
| 1154 | <a name="L1002"></a><tt class="py-lineno">1002</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1155 | <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-297" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-297', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Service is already running"</tt> <tt class="py-op">)</tt> </tt> |
| 1156 | <a name="L1004"></a><tt class="py-lineno">1004</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1157 | <a name="L1005"></a><tt class="py-lineno">1005</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1158 | <a name="L1006"></a><tt class="py-lineno">1006</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-298" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-298', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS service started"</tt> <tt class="py-op">)</tt> </tt> |
| 1159 | <a name="L1007"></a><tt class="py-lineno">1007</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1160 | <a name="L1008"></a><tt class="py-lineno">1008</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1161 | <a name="L1009"></a><tt class="py-lineno">1009</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-299" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-299', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-300" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-300', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS service failed to start"</tt> <tt class="py-op">)</tt> </tt> |
| 1162 | <a name="L1010"></a><tt class="py-lineno">1010</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-301" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-301', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1163 | <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-302" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-302', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1164 | <a name="L1012"></a><tt class="py-lineno">1012</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1165 | <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-303" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-303', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-304" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-304', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1166 | <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 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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-306" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-306', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1167 | <a name="L1015"></a><tt class="py-lineno">1015</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-307" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-307', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1168 | <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 id="link-308" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-308', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1169 | <a name="L1017"></a><tt class="py-lineno">1017</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1170 | <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 id="link-309" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-309', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1171 | <a name="L1019"></a><tt class="py-lineno">1019</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-310" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-310', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1172 | <a name="L1020"></a><tt class="py-lineno">1020</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-311" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-311', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1173 | </div><a name="L1021"></a><tt class="py-lineno">1021</tt> <tt class="py-line"> </tt> |
| 1174 | <a name="OnosDriver.onosStop"></a><div id="OnosDriver.onosStop-def"><a name="L1022"></a><tt class="py-lineno">1022</tt> <a class="py-toggle" href="#" id="OnosDriver.onosStop-toggle" onclick="return toggle('OnosDriver.onosStop');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStop">onosStop</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">nodeIp</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1175 | </div><div id="OnosDriver.onosStop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosStop-expanded"><a name="L1023"></a><tt class="py-lineno">1023</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1176 | <a name="L1024"></a><tt class="py-lineno">1024</tt> <tt class="py-line"><tt class="py-docstring"> Calls onos command: 'onos-service [<node-ip>] stop'</tt> </tt> |
| 1177 | <a name="L1025"></a><tt class="py-lineno">1025</tt> <tt class="py-line"><tt class="py-docstring"> This command is a remote management of the ONOS upstart daemon</tt> </tt> |
| 1178 | <a name="L1026"></a><tt class="py-lineno">1026</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1179 | <a name="L1027"></a><tt class="py-lineno">1027</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1180 | <a name="L1028"></a><tt class="py-lineno">1028</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-312" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-312', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1181 | <a name="L1029"></a><tt class="py-lineno">1029</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1182 | <a name="L1030"></a><tt class="py-lineno">1030</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-313" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-313', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-service "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1183 | <a name="L1031"></a><tt class="py-lineno">1031</tt> <tt class="py-line"> <tt class="py-string">" stop"</tt> <tt class="py-op">)</tt> </tt> |
| 1184 | <a name="L1032"></a><tt class="py-lineno">1032</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 1185 | <a name="L1033"></a><tt class="py-lineno">1033</tt> <tt class="py-line"> <tt class="py-string">"stop/waiting"</tt><tt class="py-op">,</tt> </tt> |
| 1186 | <a name="L1034"></a><tt class="py-lineno">1034</tt> <tt class="py-line"> <tt class="py-string">"Could not resolve hostname"</tt><tt class="py-op">,</tt> </tt> |
| 1187 | <a name="L1035"></a><tt class="py-lineno">1035</tt> <tt class="py-line"> <tt class="py-string">"Unknown\sinstance"</tt><tt class="py-op">,</tt> </tt> |
| 1188 | <a name="L1036"></a><tt class="py-lineno">1036</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt> |
| 1189 | <a name="L1037"></a><tt class="py-lineno">1037</tt> <tt class="py-line"> </tt> |
| 1190 | <a name="L1038"></a><tt class="py-lineno">1038</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1191 | <a name="L1039"></a><tt class="py-lineno">1039</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-314" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-314', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS service stopped"</tt> <tt class="py-op">)</tt> </tt> |
| 1192 | <a name="L1040"></a><tt class="py-lineno">1040</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1193 | <a name="L1041"></a><tt class="py-lineno">1041</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1194 | <a name="L1042"></a><tt class="py-lineno">1042</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-315', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"onosStop() Unknown ONOS instance specified: "</tt> <tt class="py-op">+</tt> </tt> |
| 1195 | <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">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1196 | <a name="L1044"></a><tt class="py-lineno">1044</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1197 | <a name="L1045"></a><tt class="py-lineno">1045</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt> |
| 1198 | <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-316" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-316', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS wasn't running"</tt> <tt class="py-op">)</tt> </tt> |
| 1199 | <a name="L1047"></a><tt class="py-lineno">1047</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1200 | <a name="L1048"></a><tt class="py-lineno">1048</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1201 | <a name="L1049"></a><tt class="py-lineno">1049</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-318" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-318', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS service failed to stop"</tt> <tt class="py-op">)</tt> </tt> |
| 1202 | <a name="L1050"></a><tt class="py-lineno">1050</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1203 | <a name="L1051"></a><tt class="py-lineno">1051</tt> <tt class="py-line"> </tt> |
| 1204 | <a name="L1052"></a><tt class="py-lineno">1052</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1205 | <a name="L1053"></a><tt class="py-lineno">1053</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-319" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-319', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-320" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-320', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1206 | <a name="L1054"></a><tt class="py-lineno">1054</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-322" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-322', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1207 | <a name="L1055"></a><tt class="py-lineno">1055</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-323" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-323', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1208 | <a name="L1056"></a><tt class="py-lineno">1056</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-324', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1209 | <a name="L1057"></a><tt class="py-lineno">1057</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1210 | <a name="L1058"></a><tt class="py-lineno">1058</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1211 | <a name="L1059"></a><tt class="py-lineno">1059</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.cleanup" class="py-name" href="#" onclick="return doclink('link-326', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1212 | <a name="L1060"></a><tt class="py-lineno">1060</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-327" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-327', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1213 | </div><a name="L1061"></a><tt class="py-lineno">1061</tt> <tt class="py-line"> </tt> |
| 1214 | <a name="OnosDriver.onosUninstall"></a><div id="OnosDriver.onosUninstall-def"><a name="L1062"></a><tt class="py-lineno">1062</tt> <a class="py-toggle" href="#" id="OnosDriver.onosUninstall-toggle" onclick="return toggle('OnosDriver.onosUninstall');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosUninstall">onosUninstall</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">nodeIp</tt><tt class="py-op">=</tt><tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1215 | </div><div id="OnosDriver.onosUninstall-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosUninstall-expanded"><a name="L1063"></a><tt class="py-lineno">1063</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1216 | <a name="L1064"></a><tt class="py-lineno">1064</tt> <tt class="py-line"><tt class="py-docstring"> Calls the command: 'onos-uninstall'</tt> </tt> |
| 1217 | <a name="L1065"></a><tt class="py-lineno">1065</tt> <tt class="py-line"><tt class="py-docstring"> Uninstalls ONOS from the designated cell machine, stopping</tt> </tt> |
| 1218 | <a name="L1066"></a><tt class="py-lineno">1066</tt> <tt class="py-line"><tt class="py-docstring"> if needed</tt> </tt> |
| 1219 | <a name="L1067"></a><tt class="py-lineno">1067</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1220 | <a name="L1068"></a><tt class="py-lineno">1068</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1221 | <a name="L1069"></a><tt class="py-lineno">1069</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-328" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-328', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1222 | <a name="L1070"></a><tt class="py-lineno">1070</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">60</tt> <tt class="py-op">)</tt> </tt> |
| 1223 | <a name="L1071"></a><tt class="py-lineno">1071</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-329" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-329', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-uninstall "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1224 | <a name="L1072"></a><tt class="py-lineno">1072</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1225 | <a name="L1073"></a><tt class="py-lineno">1073</tt> <tt class="py-line"> </tt> |
| 1226 | <a name="L1074"></a><tt class="py-lineno">1074</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-330" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-330', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS "</tt> <tt class="py-op">+</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">+</tt> <tt class="py-string">" was uninstalled"</tt> <tt class="py-op">)</tt> </tt> |
| 1227 | <a name="L1075"></a><tt class="py-lineno">1075</tt> <tt class="py-line"> </tt> |
| 1228 | <a name="L1076"></a><tt class="py-lineno">1076</tt> <tt class="py-line"> <tt class="py-comment"># onos-uninstall command does not return any text</tt> </tt> |
| 1229 | <a name="L1077"></a><tt class="py-lineno">1077</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1230 | <a name="L1078"></a><tt class="py-lineno">1078</tt> <tt class="py-line"> </tt> |
| 1231 | <a name="L1079"></a><tt class="py-lineno">1079</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">:</tt> </tt> |
| 1232 | <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-331" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-331', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Timeout in onosUninstall"</tt> <tt class="py-op">)</tt> </tt> |
| 1233 | <a name="L1081"></a><tt class="py-lineno">1081</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1234 | <a name="L1082"></a><tt class="py-lineno">1082</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1235 | <a name="L1083"></a><tt class="py-lineno">1083</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-332" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-332', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-333" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-333', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1236 | <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 id="link-334" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-334', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-335" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-335', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1237 | <a name="L1085"></a><tt class="py-lineno">1085</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-336" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-336', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1238 | <a name="L1086"></a><tt class="py-lineno">1086</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-337" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-337', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1239 | <a name="L1087"></a><tt class="py-lineno">1087</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1240 | <a name="L1088"></a><tt class="py-lineno">1088</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1241 | <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 id="link-339" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-339', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1242 | <a name="L1090"></a><tt class="py-lineno">1090</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-340" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-340', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1243 | </div><a name="L1091"></a><tt class="py-lineno">1091</tt> <tt class="py-line"> </tt> |
| 1244 | <a name="OnosDriver.onosDie"></a><div id="OnosDriver.onosDie-def"><a name="L1092"></a><tt class="py-lineno">1092</tt> <a class="py-toggle" href="#" id="OnosDriver.onosDie-toggle" onclick="return toggle('OnosDriver.onosDie');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosDie">onosDie</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">nodeIp</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1245 | </div><div id="OnosDriver.onosDie-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosDie-expanded"><a name="L1093"></a><tt class="py-lineno">1093</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1246 | <a name="L1094"></a><tt class="py-lineno">1094</tt> <tt class="py-line"><tt class="py-docstring"> Issues the command 'onos-die <node-ip>'</tt> </tt> |
| 1247 | <a name="L1095"></a><tt class="py-lineno">1095</tt> <tt class="py-line"><tt class="py-docstring"> This command calls onos-kill and also stops the node</tt> </tt> |
| 1248 | <a name="L1096"></a><tt class="py-lineno">1096</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1249 | <a name="L1097"></a><tt class="py-lineno">1097</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1250 | <a name="L1098"></a><tt class="py-lineno">1098</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-341" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-341', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1251 | <a name="L1099"></a><tt class="py-lineno">1099</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1252 | <a name="L1100"></a><tt class="py-lineno">1100</tt> <tt class="py-line"> <tt class="py-name">cmdStr</tt> <tt class="py-op">=</tt> <tt class="py-string">"onos-kill "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> </tt> |
| 1253 | <a name="L1101"></a><tt class="py-lineno">1101</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-342" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-342', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmdStr</tt> <tt class="py-op">)</tt> </tt> |
| 1254 | <a name="L1102"></a><tt class="py-lineno">1102</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 1255 | <a name="L1103"></a><tt class="py-lineno">1103</tt> <tt class="py-line"> <tt class="py-string">"Killing\sONOS"</tt><tt class="py-op">,</tt> </tt> |
| 1256 | <a name="L1104"></a><tt class="py-lineno">1104</tt> <tt class="py-line"> <tt class="py-string">"ONOS\sprocess\sis\snot\srunning"</tt><tt class="py-op">,</tt> </tt> |
| 1257 | <a name="L1105"></a><tt class="py-lineno">1105</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">20</tt> <tt class="py-op">)</tt> </tt> |
| 1258 | <a name="L1106"></a><tt class="py-lineno">1106</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1259 | <a name="L1107"></a><tt class="py-lineno">1107</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-343" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-343', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS instance "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1260 | <a name="L1108"></a><tt class="py-lineno">1108</tt> <tt class="py-line"> <tt class="py-string">" was killed and stopped"</tt> <tt class="py-op">)</tt> </tt> |
| 1261 | <a name="L1109"></a><tt class="py-lineno">1109</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1262 | <a name="L1110"></a><tt class="py-lineno">1110</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1263 | <a name="L1111"></a><tt class="py-lineno">1111</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-344" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-344', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS process was not running"</tt> <tt class="py-op">)</tt> </tt> |
| 1264 | <a name="L1112"></a><tt class="py-lineno">1112</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1265 | <a name="L1113"></a><tt class="py-lineno">1113</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1266 | <a name="L1114"></a><tt class="py-lineno">1114</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-345" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-345', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-346" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-346', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1267 | <a name="L1115"></a><tt class="py-lineno">1115</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-347" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-347', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-348" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-348', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1268 | <a name="L1116"></a><tt class="py-lineno">1116</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-349" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-349', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1269 | <a name="L1117"></a><tt class="py-lineno">1117</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-350', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1270 | <a name="L1118"></a><tt class="py-lineno">1118</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1271 | <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-351" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-351', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1272 | <a name="L1120"></a><tt class="py-lineno">1120</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-352" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-352', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1273 | <a name="L1121"></a><tt class="py-lineno">1121</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-353', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1274 | </div><a name="L1122"></a><tt class="py-lineno">1122</tt> <tt class="py-line"> </tt> |
| 1275 | <a name="OnosDriver.onosKill"></a><div id="OnosDriver.onosKill-def"><a name="L1123"></a><tt class="py-lineno">1123</tt> <a class="py-toggle" href="#" id="OnosDriver.onosKill-toggle" onclick="return toggle('OnosDriver.onosKill');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosKill">onosKill</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">nodeIp</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1276 | </div><div id="OnosDriver.onosKill-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosKill-expanded"><a name="L1124"></a><tt class="py-lineno">1124</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1277 | <a name="L1125"></a><tt class="py-lineno">1125</tt> <tt class="py-line"><tt class="py-docstring"> Calls the command: 'onos-kill [<node-ip>]'</tt> </tt> |
| 1278 | <a name="L1126"></a><tt class="py-lineno">1126</tt> <tt class="py-line"><tt class="py-docstring"> "Remotely, and unceremoniously kills the ONOS instance running on</tt> </tt> |
| 1279 | <a name="L1127"></a><tt class="py-lineno">1127</tt> <tt class="py-line"><tt class="py-docstring"> the specified cell machine" - Tom V</tt> </tt> |
| 1280 | <a name="L1128"></a><tt class="py-lineno">1128</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1281 | <a name="L1129"></a><tt class="py-lineno">1129</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1282 | <a name="L1130"></a><tt class="py-lineno">1130</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-354" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-354', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1283 | <a name="L1131"></a><tt class="py-lineno">1131</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1284 | <a name="L1132"></a><tt class="py-lineno">1132</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-355" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-355', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-kill "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1285 | <a name="L1133"></a><tt class="py-lineno">1133</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 1286 | <a name="L1134"></a><tt class="py-lineno">1134</tt> <tt class="py-line"> <tt class="py-string">"\$"</tt><tt class="py-op">,</tt> </tt> |
| 1287 | <a name="L1135"></a><tt class="py-lineno">1135</tt> <tt class="py-line"> <tt class="py-string">"No\sroute\sto\shost"</tt><tt class="py-op">,</tt> </tt> |
| 1288 | <a name="L1136"></a><tt class="py-lineno">1136</tt> <tt class="py-line"> <tt class="py-string">"password:"</tt><tt class="py-op">,</tt> </tt> |
| 1289 | <a name="L1137"></a><tt class="py-lineno">1137</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">20</tt> <tt class="py-op">)</tt> </tt> |
| 1290 | <a name="L1138"></a><tt class="py-lineno">1138</tt> <tt class="py-line"> </tt> |
| 1291 | <a name="L1139"></a><tt class="py-lineno">1139</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1292 | <a name="L1140"></a><tt class="py-lineno">1140</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-356" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-356', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 1293 | <a name="L1141"></a><tt class="py-lineno">1141</tt> <tt class="py-line"> <tt class="py-string">"ONOS instance "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> </tt> |
| 1294 | <a name="L1142"></a><tt class="py-lineno">1142</tt> <tt class="py-line"> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" was killed"</tt> <tt class="py-op">)</tt> </tt> |
| 1295 | <a name="L1143"></a><tt class="py-lineno">1143</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1296 | <a name="L1144"></a><tt class="py-lineno">1144</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1297 | <a name="L1145"></a><tt class="py-lineno">1145</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-357" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-357', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"No route to host"</tt> <tt class="py-op">)</tt> </tt> |
| 1298 | <a name="L1146"></a><tt class="py-lineno">1146</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1299 | <a name="L1147"></a><tt class="py-lineno">1147</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">2</tt><tt class="py-op">:</tt> </tt> |
| 1300 | <a name="L1148"></a><tt class="py-lineno">1148</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-358" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-358', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> </tt> |
| 1301 | <a name="L1149"></a><tt class="py-lineno">1149</tt> <tt class="py-line"> <tt class="py-string">"Passwordless login for host: "</tt> <tt class="py-op">+</tt> </tt> |
| 1302 | <a name="L1150"></a><tt class="py-lineno">1150</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1303 | <a name="L1151"></a><tt class="py-lineno">1151</tt> <tt class="py-line"> <tt class="py-string">" not configured"</tt> <tt class="py-op">)</tt> </tt> |
| 1304 | <a name="L1152"></a><tt class="py-lineno">1152</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1305 | <a name="L1153"></a><tt class="py-lineno">1153</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1306 | <a name="L1154"></a><tt class="py-lineno">1154</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-359" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-359', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS instance was not killed"</tt> <tt class="py-op">)</tt> </tt> |
| 1307 | <a name="L1155"></a><tt class="py-lineno">1155</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1308 | <a name="L1156"></a><tt class="py-lineno">1156</tt> <tt class="py-line"> </tt> |
| 1309 | <a name="L1157"></a><tt class="py-lineno">1157</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1310 | <a name="L1158"></a><tt class="py-lineno">1158</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-360" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-360', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-361" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-361', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1311 | <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-362" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-362', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-363" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-363', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1312 | <a name="L1160"></a><tt class="py-lineno">1160</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-364" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-364', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1313 | <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-365" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-365', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1314 | <a name="L1162"></a><tt class="py-lineno">1162</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1315 | <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 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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1316 | <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 id="link-367" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-367', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1317 | <a name="L1165"></a><tt class="py-lineno">1165</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.exit" class="py-name" href="#" onclick="return doclink('link-368', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1318 | </div><a name="L1166"></a><tt class="py-lineno">1166</tt> <tt class="py-line"> </tt> |
| 1319 | <a name="OnosDriver.onosRemoveRaftLogs"></a><div id="OnosDriver.onosRemoveRaftLogs-def"><a name="L1167"></a><tt class="py-lineno">1167</tt> <a class="py-toggle" href="#" id="OnosDriver.onosRemoveRaftLogs-toggle" onclick="return toggle('OnosDriver.onosRemoveRaftLogs');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosRemoveRaftLogs">onosRemoveRaftLogs</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1320 | </div><div id="OnosDriver.onosRemoveRaftLogs-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosRemoveRaftLogs-expanded"><a name="L1168"></a><tt class="py-lineno">1168</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1321 | <a name="L1169"></a><tt class="py-lineno">1169</tt> <tt class="py-line"><tt class="py-docstring"> Removes Raft / Copy cat files from ONOS to ensure</tt> </tt> |
| 1322 | <a name="L1170"></a><tt class="py-lineno">1170</tt> <tt class="py-line"><tt class="py-docstring"> a cleaner environment.</tt> </tt> |
| 1323 | <a name="L1171"></a><tt class="py-lineno">1171</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1324 | <a name="L1172"></a><tt class="py-lineno">1172</tt> <tt class="py-line"><tt class="py-docstring"> Description:</tt> </tt> |
| 1325 | <a name="L1173"></a><tt class="py-lineno">1173</tt> <tt class="py-line"><tt class="py-docstring"> Stops all ONOS defined in the cell,</tt> </tt> |
| 1326 | <a name="L1174"></a><tt class="py-lineno">1174</tt> <tt class="py-line"><tt class="py-docstring"> wipes the raft / copycat log files</tt> </tt> |
| 1327 | <a name="L1175"></a><tt class="py-lineno">1175</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1328 | <a name="L1176"></a><tt class="py-lineno">1176</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1329 | <a name="L1177"></a><tt class="py-lineno">1177</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-369" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-369', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1330 | <a name="L1178"></a><tt class="py-lineno">1178</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1331 | <a name="L1179"></a><tt class="py-lineno">1179</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-370" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-370', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-remove-raft-logs"</tt> <tt class="py-op">)</tt> </tt> |
| 1332 | <a name="L1180"></a><tt class="py-lineno">1180</tt> <tt class="py-line"> <tt class="py-comment"># Sometimes this command hangs</tt> </tt> |
| 1333 | <a name="L1181"></a><tt class="py-lineno">1181</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> <tt class="py-string">"\$"</tt><tt class="py-op">,</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt> |
| 1334 | <a name="L1182"></a><tt class="py-lineno">1182</tt> <tt class="py-line"> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">120</tt> <tt class="py-op">)</tt> </tt> |
| 1335 | <a name="L1183"></a><tt class="py-lineno">1183</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1336 | <a name="L1184"></a><tt class="py-lineno">1184</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> <tt class="py-string">"\$"</tt><tt class="py-op">,</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> </tt> |
| 1337 | <a name="L1185"></a><tt class="py-lineno">1185</tt> <tt class="py-line"> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">120</tt> <tt class="py-op">)</tt> </tt> |
| 1338 | <a name="L1186"></a><tt class="py-lineno">1186</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1339 | <a name="L1187"></a><tt class="py-lineno">1187</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1340 | <a name="L1188"></a><tt class="py-lineno">1188</tt> <tt class="py-line"> <tt class="py-comment">#self.handle.sendline( "" )</tt> </tt> |
| 1341 | <a name="L1189"></a><tt class="py-lineno">1189</tt> <tt class="py-line"> <tt class="py-comment">#self.handle.expect( "\$" )</tt> </tt> |
| 1342 | <a name="L1190"></a><tt class="py-lineno">1190</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1343 | <a name="L1191"></a><tt class="py-lineno">1191</tt> <tt class="py-line"> </tt> |
| 1344 | <a name="L1192"></a><tt class="py-lineno">1192</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1345 | <a name="L1193"></a><tt class="py-lineno">1193</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-371" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-371', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-372" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-372', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1346 | <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-373" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-373', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-374" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-374', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1347 | <a name="L1195"></a><tt class="py-lineno">1195</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-375" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-375', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1348 | <a name="L1196"></a><tt class="py-lineno">1196</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-376', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1349 | <a name="L1197"></a><tt class="py-lineno">1197</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1350 | <a name="L1198"></a><tt class="py-lineno">1198</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-377" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-377', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1351 | <a name="L1199"></a><tt class="py-lineno">1199</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-378" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-378', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1352 | <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-379" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-379', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1353 | </div><a name="L1201"></a><tt class="py-lineno">1201</tt> <tt class="py-line"> </tt> |
| 1354 | <a name="OnosDriver.onosStartNetwork"></a><div id="OnosDriver.onosStartNetwork-def"><a name="L1202"></a><tt class="py-lineno">1202</tt> <a class="py-toggle" href="#" id="OnosDriver.onosStartNetwork-toggle" onclick="return toggle('OnosDriver.onosStartNetwork');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStartNetwork">onosStartNetwork</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">mntopo</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1355 | </div><div id="OnosDriver.onosStartNetwork-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosStartNetwork-expanded"><a name="L1203"></a><tt class="py-lineno">1203</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1356 | <a name="L1204"></a><tt class="py-lineno">1204</tt> <tt class="py-line"><tt class="py-docstring"> Calls the command 'onos-start-network [ <mininet-topo> ]</tt> </tt> |
| 1357 | <a name="L1205"></a><tt class="py-lineno">1205</tt> <tt class="py-line"><tt class="py-docstring"> "remotely starts the specified topology on the cell's</tt> </tt> |
| 1358 | <a name="L1206"></a><tt class="py-lineno">1206</tt> <tt class="py-line"><tt class="py-docstring"> mininet machine against all controllers configured in the</tt> </tt> |
| 1359 | <a name="L1207"></a><tt class="py-lineno">1207</tt> <tt class="py-line"><tt class="py-docstring"> cell."</tt> </tt> |
| 1360 | <a name="L1208"></a><tt class="py-lineno">1208</tt> <tt class="py-line"><tt class="py-docstring"> * Specify mininet topology file name for mntopo</tt> </tt> |
| 1361 | <a name="L1209"></a><tt class="py-lineno">1209</tt> <tt class="py-line"><tt class="py-docstring"> * Topo files should be placed at:</tt> </tt> |
| 1362 | <a name="L1210"></a><tt class="py-lineno">1210</tt> <tt class="py-line"><tt class="py-docstring"> ~/<your-onos-directory>/tools/test/topos</tt> </tt> |
| 1363 | <a name="L1211"></a><tt class="py-lineno">1211</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1364 | <a name="L1212"></a><tt class="py-lineno">1212</tt> <tt class="py-line"><tt class="py-docstring"> NOTE: This function will take you to the mininet prompt</tt> </tt> |
| 1365 | <a name="L1213"></a><tt class="py-lineno">1213</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1366 | <a name="L1214"></a><tt class="py-lineno">1214</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1367 | <a name="L1215"></a><tt class="py-lineno">1215</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">mntopo</tt><tt class="py-op">:</tt> </tt> |
| 1368 | <a name="L1216"></a><tt class="py-lineno">1216</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-381" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-381', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"You must specify a topo file to execute"</tt> <tt class="py-op">)</tt> </tt> |
| 1369 | <a name="L1217"></a><tt class="py-lineno">1217</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1370 | <a name="L1218"></a><tt class="py-lineno">1218</tt> <tt class="py-line"> </tt> |
| 1371 | <a name="L1219"></a><tt class="py-lineno">1219</tt> <tt class="py-line"> <tt class="py-name">mntopo</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">mntopo</tt> <tt class="py-op">)</tt> </tt> |
| 1372 | <a name="L1220"></a><tt class="py-lineno">1220</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-382" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-382', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1373 | <a name="L1221"></a><tt class="py-lineno">1221</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1374 | <a name="L1222"></a><tt class="py-lineno">1222</tt> <tt class="py-line"> </tt> |
| 1375 | <a name="L1223"></a><tt class="py-lineno">1223</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-383" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-383', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-start-network "</tt> <tt class="py-op">+</tt> <tt class="py-name">mntopo</tt> <tt class="py-op">)</tt> </tt> |
| 1376 | <a name="L1224"></a><tt class="py-lineno">1224</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"mininet>"</tt> <tt class="py-op">)</tt> </tt> |
| 1377 | <a name="L1225"></a><tt class="py-lineno">1225</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-384" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-384', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Network started, entered mininet prompt"</tt> <tt class="py-op">)</tt> </tt> |
| 1378 | <a name="L1226"></a><tt class="py-lineno">1226</tt> <tt class="py-line"> </tt> |
| 1379 | <a name="L1227"></a><tt class="py-lineno">1227</tt> <tt class="py-line"> <tt class="py-comment"># TODO: Think about whether return is necessary or not</tt> </tt> |
| 1380 | <a name="L1228"></a><tt class="py-lineno">1228</tt> <tt class="py-line"> </tt> |
| 1381 | <a name="L1229"></a><tt class="py-lineno">1229</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1382 | <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-385" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-385', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-386" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-386', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1383 | <a name="L1231"></a><tt class="py-lineno">1231</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-387" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-387', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-388" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-388', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1384 | <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 id="link-389" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-389', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1385 | <a name="L1233"></a><tt class="py-lineno">1233</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-390" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-390', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1386 | <a name="L1234"></a><tt class="py-lineno">1234</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1387 | <a name="L1235"></a><tt class="py-lineno">1235</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-391" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-391', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1388 | <a name="L1236"></a><tt class="py-lineno">1236</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-392', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1389 | <a name="L1237"></a><tt class="py-lineno">1237</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-393" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-393', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1390 | </div><a name="L1238"></a><tt class="py-lineno">1238</tt> <tt class="py-line"> </tt> |
| 1391 | <a name="OnosDriver.isup"></a><div id="OnosDriver.isup-def"><a name="L1239"></a><tt class="py-lineno">1239</tt> <a class="py-toggle" href="#" id="OnosDriver.isup-toggle" onclick="return toggle('OnosDriver.isup');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#isup">isup</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">node</tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt><tt class="py-op">,</tt> <tt class="py-param">timeout</tt> <tt class="py-op">=</tt> <tt class="py-number">120</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1392 | </div><div id="OnosDriver.isup-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.isup-expanded"><a name="L1240"></a><tt class="py-lineno">1240</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1393 | <a name="L1241"></a><tt class="py-lineno">1241</tt> <tt class="py-line"><tt class="py-docstring"> Run's onos-wait-for-start which only returns once ONOS is at run</tt> </tt> |
| 1394 | <a name="L1242"></a><tt class="py-lineno">1242</tt> <tt class="py-line"><tt class="py-docstring"> level 100(ready for use)</tt> </tt> |
| 1395 | <a name="L1243"></a><tt class="py-lineno">1243</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1396 | <a name="L1244"></a><tt class="py-lineno">1244</tt> <tt class="py-line"><tt class="py-docstring"> Returns: main.TRUE if ONOS is running and main.FALSE on timeout</tt> </tt> |
| 1397 | <a name="L1245"></a><tt class="py-lineno">1245</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1398 | <a name="L1246"></a><tt class="py-lineno">1246</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1399 | <a name="L1247"></a><tt class="py-lineno">1247</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-394" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-394', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos-wait-for-start "</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt> </tt> |
| 1400 | <a name="L1248"></a><tt class="py-lineno">1248</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">"onos-wait-for-start"</tt><tt class="py-op">)</tt> </tt> |
| 1401 | <a name="L1249"></a><tt class="py-lineno">1249</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: this timeout is arbitrary"</tt> </tt> |
| 1402 | <a name="L1250"></a><tt class="py-lineno">1250</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">"\$"</tt><tt class="py-op">,</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">)</tt> </tt> |
| 1403 | <a name="L1251"></a><tt class="py-lineno">1251</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1404 | <a name="L1252"></a><tt class="py-lineno">1252</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-395" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-395', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">node</tt> <tt class="py-op">+</tt> <tt class="py-string">" is up"</tt> <tt class="py-op">)</tt> </tt> |
| 1405 | <a name="L1253"></a><tt class="py-lineno">1253</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1406 | <a name="L1254"></a><tt class="py-lineno">1254</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1407 | <a name="L1255"></a><tt class="py-lineno">1255</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: since this function won't return until ONOS is ready,</tt> </tt> |
| 1408 | <a name="L1256"></a><tt class="py-lineno">1256</tt> <tt class="py-line"> <tt class="py-comment"># we will kill it on timeout</tt> </tt> |
| 1409 | <a name="L1257"></a><tt class="py-lineno">1257</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-396" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-396', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-397" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-397', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS has not started yet"</tt> <tt class="py-op">)</tt> </tt> |
| 1410 | <a name="L1258"></a><tt class="py-lineno">1258</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-398" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.send" class="py-name" href="#" onclick="return doclink('link-398', 'send', 'link-116');">send</a></tt><tt class="py-op">(</tt> <tt class="py-string">"\x03"</tt> <tt class="py-op">)</tt> <tt class="py-comment"># Control-C</tt> </tt> |
| 1411 | <a name="L1259"></a><tt class="py-lineno">1259</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1412 | <a name="L1260"></a><tt class="py-lineno">1260</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1413 | <a name="L1261"></a><tt class="py-lineno">1261</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1414 | <a name="L1262"></a><tt class="py-lineno">1262</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-399" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-399', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-400" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-400', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1415 | <a name="L1263"></a><tt class="py-lineno">1263</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-401" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-401', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-402" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-402', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1416 | <a name="L1264"></a><tt class="py-lineno">1264</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-403" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-403', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1417 | <a name="L1265"></a><tt class="py-lineno">1265</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-404" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-404', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1418 | <a name="L1266"></a><tt class="py-lineno">1266</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1419 | <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-405" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-405', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1420 | <a name="L1268"></a><tt class="py-lineno">1268</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-406" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-406', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1421 | <a name="L1269"></a><tt class="py-lineno">1269</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-407" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-407', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1422 | </div><a name="L1270"></a><tt class="py-lineno">1270</tt> <tt class="py-line"> </tt> |
| 1423 | <a name="OnosDriver.pushTestIntentsShell"></a><div id="OnosDriver.pushTestIntentsShell-def"><a name="L1271"></a><tt class="py-lineno">1271</tt> <a class="py-toggle" href="#" id="OnosDriver.pushTestIntentsShell-toggle" onclick="return toggle('OnosDriver.pushTestIntentsShell');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#pushTestIntentsShell">pushTestIntentsShell</a><tt class="py-op">(</tt> </tt> |
| 1424 | <a name="L1272"></a><tt class="py-lineno">1272</tt> <tt class="py-line"> <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt> |
| 1425 | <a name="L1273"></a><tt class="py-lineno">1273</tt> <tt class="py-line"> <tt class="py-param">dpidSrc</tt><tt class="py-op">,</tt> </tt> |
| 1426 | <a name="L1274"></a><tt class="py-lineno">1274</tt> <tt class="py-line"> <tt class="py-param">dpidDst</tt><tt class="py-op">,</tt> </tt> |
| 1427 | <a name="L1275"></a><tt class="py-lineno">1275</tt> <tt class="py-line"> <tt class="py-param">numIntents</tt><tt class="py-op">,</tt> </tt> |
| 1428 | <a name="L1276"></a><tt class="py-lineno">1276</tt> <tt class="py-line"> <tt class="py-param">dirFile</tt><tt class="py-op">,</tt> </tt> |
| 1429 | <a name="L1277"></a><tt class="py-lineno">1277</tt> <tt class="py-line"> <tt class="py-param">onosIp</tt><tt class="py-op">,</tt> </tt> |
| 1430 | <a name="L1278"></a><tt class="py-lineno">1278</tt> <tt class="py-line"> <tt class="py-param">numMult</tt><tt class="py-op">=</tt><tt class="py-string">""</tt><tt class="py-op">,</tt> </tt> |
| 1431 | <a name="L1279"></a><tt class="py-lineno">1279</tt> <tt class="py-line"> <tt class="py-param">appId</tt><tt class="py-op">=</tt><tt class="py-string">""</tt><tt class="py-op">,</tt> </tt> |
| 1432 | <a name="L1280"></a><tt class="py-lineno">1280</tt> <tt class="py-line"> <tt class="py-param">report</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt> |
| 1433 | <a name="L1281"></a><tt class="py-lineno">1281</tt> <tt class="py-line"> <tt class="py-param">options</tt><tt class="py-op">=</tt><tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1434 | </div><div id="OnosDriver.pushTestIntentsShell-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.pushTestIntentsShell-expanded"><a name="L1282"></a><tt class="py-lineno">1282</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1435 | <a name="L1283"></a><tt class="py-lineno">1283</tt> <tt class="py-line"><tt class="py-docstring"> Description:</tt> </tt> |
| 1436 | <a name="L1284"></a><tt class="py-lineno">1284</tt> <tt class="py-line"><tt class="py-docstring"> Use the linux prompt to push test intents to</tt> </tt> |
| 1437 | <a name="L1285"></a><tt class="py-lineno">1285</tt> <tt class="py-line"><tt class="py-docstring"> better parallelize the results than the CLI</tt> </tt> |
| 1438 | <a name="L1286"></a><tt class="py-lineno">1286</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 1439 | <a name="L1287"></a><tt class="py-lineno">1287</tt> <tt class="py-line"><tt class="py-docstring"> * dpidSrc: specify source dpid</tt> </tt> |
| 1440 | <a name="L1288"></a><tt class="py-lineno">1288</tt> <tt class="py-line"><tt class="py-docstring"> * dpidDst: specify destination dpid</tt> </tt> |
| 1441 | <a name="L1289"></a><tt class="py-lineno">1289</tt> <tt class="py-line"><tt class="py-docstring"> * numIntents: specify number of intents to push</tt> </tt> |
| 1442 | <a name="L1290"></a><tt class="py-lineno">1290</tt> <tt class="py-line"><tt class="py-docstring"> * dirFile: specify directory and file name to save</tt> </tt> |
| 1443 | <a name="L1291"></a><tt class="py-lineno">1291</tt> <tt class="py-line"><tt class="py-docstring"> results</tt> </tt> |
| 1444 | <a name="L1292"></a><tt class="py-lineno">1292</tt> <tt class="py-line"><tt class="py-docstring"> * onosIp: specify the IP of ONOS to install on</tt> </tt> |
| 1445 | <a name="L1293"></a><tt class="py-lineno">1293</tt> <tt class="py-line"><tt class="py-docstring"> NOTE:</tt> </tt> |
| 1446 | <a name="L1294"></a><tt class="py-lineno">1294</tt> <tt class="py-line"><tt class="py-docstring"> You must invoke this command at linux shell prompt</tt> </tt> |
| 1447 | <a name="L1295"></a><tt class="py-lineno">1295</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1448 | <a name="L1296"></a><tt class="py-lineno">1296</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1449 | <a name="L1297"></a><tt class="py-lineno">1297</tt> <tt class="py-line"> <tt class="py-comment"># Create the string to sendline</tt> </tt> |
| 1450 | <a name="L1298"></a><tt class="py-lineno">1298</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">options</tt><tt class="py-op">:</tt> </tt> |
| 1451 | <a name="L1299"></a><tt class="py-lineno">1299</tt> <tt class="py-line"> <tt class="py-name">baseCmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"onos "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" push-test-intents "</tt> <tt class="py-op">+</tt>\ </tt> |
| 1452 | <a name="L1300"></a><tt class="py-lineno">1300</tt> <tt class="py-line"> <tt class="py-name">options</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> </tt> |
| 1453 | <a name="L1301"></a><tt class="py-lineno">1301</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1454 | <a name="L1302"></a><tt class="py-lineno">1302</tt> <tt class="py-line"> <tt class="py-name">baseCmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"onos "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosIp</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" push-test-intents "</tt> </tt> |
| 1455 | <a name="L1303"></a><tt class="py-lineno">1303</tt> <tt class="py-line"> </tt> |
| 1456 | <a name="L1304"></a><tt class="py-lineno">1304</tt> <tt class="py-line"> <tt class="py-name">addDpid</tt> <tt class="py-op">=</tt> <tt class="py-name">baseCmd</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">dpidSrc</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">dpidDst</tt> <tt class="py-op">)</tt> </tt> |
| 1457 | <a name="L1305"></a><tt class="py-lineno">1305</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">numMult</tt><tt class="py-op">:</tt> </tt> |
| 1458 | <a name="L1306"></a><tt class="py-lineno">1306</tt> <tt class="py-line"> <tt class="py-name">addIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">addDpid</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">numIntents</tt> <tt class="py-op">)</tt> </tt> |
| 1459 | <a name="L1307"></a><tt class="py-lineno">1307</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">numMult</tt><tt class="py-op">:</tt> </tt> |
| 1460 | <a name="L1308"></a><tt class="py-lineno">1308</tt> <tt class="py-line"> <tt class="py-name">addIntents</tt> <tt class="py-op">=</tt> <tt class="py-name">addDpid</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">numIntents</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt>\ </tt> |
| 1461 | <a name="L1309"></a><tt class="py-lineno">1309</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">numMult</tt> <tt class="py-op">)</tt> </tt> |
| 1462 | <a name="L1310"></a><tt class="py-lineno">1310</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">appId</tt><tt class="py-op">:</tt> </tt> |
| 1463 | <a name="L1311"></a><tt class="py-lineno">1311</tt> <tt class="py-line"> <tt class="py-name">addApp</tt> <tt class="py-op">=</tt> <tt class="py-name">addIntents</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">appId</tt> <tt class="py-op">)</tt> </tt> |
| 1464 | <a name="L1312"></a><tt class="py-lineno">1312</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1465 | <a name="L1313"></a><tt class="py-lineno">1313</tt> <tt class="py-line"> <tt class="py-name">addApp</tt> <tt class="py-op">=</tt> <tt class="py-name">addIntents</tt> </tt> |
| 1466 | <a name="L1314"></a><tt class="py-lineno">1314</tt> <tt class="py-line"> </tt> |
| 1467 | <a name="L1315"></a><tt class="py-lineno">1315</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">report</tt><tt class="py-op">:</tt> </tt> |
| 1468 | <a name="L1316"></a><tt class="py-lineno">1316</tt> <tt class="py-line"> <tt class="py-name">sendCmd</tt> <tt class="py-op">=</tt> <tt class="py-name">addApp</tt> <tt class="py-op">+</tt> <tt class="py-string">" > "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">dirFile</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" &"</tt> </tt> |
| 1469 | <a name="L1317"></a><tt class="py-lineno">1317</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1470 | <a name="L1318"></a><tt class="py-lineno">1318</tt> <tt class="py-line"> <tt class="py-name">sendCmd</tt> <tt class="py-op">=</tt> <tt class="py-name">addApp</tt> <tt class="py-op">+</tt> <tt class="py-string">" &"</tt> </tt> |
| 1471 | <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-408" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-408', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Send cmd: "</tt> <tt class="py-op">+</tt> <tt class="py-name">sendCmd</tt> <tt class="py-op">)</tt> </tt> |
| 1472 | <a name="L1320"></a><tt class="py-lineno">1320</tt> <tt class="py-line"> </tt> |
| 1473 | <a name="L1321"></a><tt class="py-lineno">1321</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-409" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-409', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">sendCmd</tt> <tt class="py-op">)</tt> </tt> |
| 1474 | <a name="L1322"></a><tt class="py-lineno">1322</tt> <tt class="py-line"> </tt> |
| 1475 | <a name="L1323"></a><tt class="py-lineno">1323</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1476 | <a name="L1324"></a><tt class="py-lineno">1324</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-410" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-410', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-411" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-411', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1477 | <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-412" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-412', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-413" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-413', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1478 | <a name="L1326"></a><tt class="py-lineno">1326</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-414', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1479 | <a name="L1327"></a><tt class="py-lineno">1327</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-415" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-415', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1480 | <a name="L1328"></a><tt class="py-lineno">1328</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1481 | <a name="L1329"></a><tt class="py-lineno">1329</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-416" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-416', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1482 | <a name="L1330"></a><tt class="py-lineno">1330</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-417', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1483 | <a name="L1331"></a><tt class="py-lineno">1331</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-418" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-418', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1484 | </div><a name="L1332"></a><tt class="py-lineno">1332</tt> <tt class="py-line"> </tt> |
| 1485 | <a name="OnosDriver.getTopology"></a><div id="OnosDriver.getTopology-def"><a name="L1333"></a><tt class="py-lineno">1333</tt> <a class="py-toggle" href="#" id="OnosDriver.getTopology-toggle" onclick="return toggle('OnosDriver.getTopology');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getTopology">getTopology</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">topologyOutput</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1486 | </div><div id="OnosDriver.getTopology-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.getTopology-expanded"><a name="L1334"></a><tt class="py-lineno">1334</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1487 | <a name="L1335"></a><tt class="py-lineno">1335</tt> <tt class="py-line"><tt class="py-docstring"> Definition:</tt> </tt> |
| 1488 | <a name="L1336"></a><tt class="py-lineno">1336</tt> <tt class="py-line"><tt class="py-docstring"> Loads a json topology output</tt> </tt> |
| 1489 | <a name="L1337"></a><tt class="py-lineno">1337</tt> <tt class="py-line"><tt class="py-docstring"> Return:</tt> </tt> |
| 1490 | <a name="L1338"></a><tt class="py-lineno">1338</tt> <tt class="py-line"><tt class="py-docstring"> topology = current ONOS topology</tt> </tt> |
| 1491 | <a name="L1339"></a><tt class="py-lineno">1339</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1492 | <a name="L1340"></a><tt class="py-lineno">1340</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">json</tt> </tt> |
| 1493 | <a name="L1341"></a><tt class="py-lineno">1341</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1494 | <a name="L1342"></a><tt class="py-lineno">1342</tt> <tt class="py-line"> <tt class="py-comment"># either onos:topology or 'topology' will work in CLI</tt> </tt> |
| 1495 | <a name="L1343"></a><tt class="py-lineno">1343</tt> <tt class="py-line"> <tt id="link-419" 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 |
| 1496 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-419', 'topology', 'link-419');">topology</a></tt> <tt class="py-op">=</tt> <tt class="py-name">json</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt><tt class="py-name">topologyOutput</tt><tt class="py-op">)</tt> </tt> |
| 1497 | <a name="L1344"></a><tt class="py-lineno">1344</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt id="link-420" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology |
| 1498 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-420', 'topology', 'link-419');">topology</a></tt> </tt> |
| 1499 | <a name="L1345"></a><tt class="py-lineno">1345</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt id="link-421" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology |
| 1500 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-421', 'topology', 'link-419');">topology</a></tt> </tt> |
| 1501 | <a name="L1346"></a><tt class="py-lineno">1346</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1502 | <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-422" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-422', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-423" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-423', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1503 | <a name="L1348"></a><tt class="py-lineno">1348</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-424" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-424', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-425" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-425', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1504 | <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-426" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-426', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1505 | <a name="L1350"></a><tt class="py-lineno">1350</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-427" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-427', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1506 | <a name="L1351"></a><tt class="py-lineno">1351</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1507 | <a name="L1352"></a><tt class="py-lineno">1352</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-428" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-428', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1508 | <a name="L1353"></a><tt class="py-lineno">1353</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-429" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-429', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1509 | <a name="L1354"></a><tt class="py-lineno">1354</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-430" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-430', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1510 | </div><a name="L1355"></a><tt class="py-lineno">1355</tt> <tt class="py-line"> </tt> |
| 1511 | <a name="OnosDriver.checkStatus"></a><div id="OnosDriver.checkStatus-def"><a name="L1356"></a><tt class="py-lineno">1356</tt> <a class="py-toggle" href="#" id="OnosDriver.checkStatus-toggle" onclick="return toggle('OnosDriver.checkStatus');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#checkStatus">checkStatus</a><tt class="py-op">(</tt> </tt> |
| 1512 | <a name="L1357"></a><tt class="py-lineno">1357</tt> <tt class="py-line"> <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt> |
| 1513 | <a name="L1358"></a><tt class="py-lineno">1358</tt> <tt class="py-line"> <tt class="py-param">topologyResult</tt><tt class="py-op">,</tt> </tt> |
| 1514 | <a name="L1359"></a><tt class="py-lineno">1359</tt> <tt class="py-line"> <tt class="py-param">numoswitch</tt><tt class="py-op">,</tt> </tt> |
| 1515 | <a name="L1360"></a><tt class="py-lineno">1360</tt> <tt class="py-line"> <tt class="py-param">numolink</tt><tt class="py-op">,</tt> </tt> |
| 1516 | <a name="L1361"></a><tt class="py-lineno">1361</tt> <tt class="py-line"> <tt class="py-param">logLevel</tt><tt class="py-op">=</tt><tt class="py-string">"info"</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1517 | </div><div id="OnosDriver.checkStatus-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.checkStatus-expanded"><a name="L1362"></a><tt class="py-lineno">1362</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1518 | <a name="L1363"></a><tt class="py-lineno">1363</tt> <tt class="py-line"><tt class="py-docstring"> Checks the number of switches & links that ONOS sees against the</tt> </tt> |
| 1519 | <a name="L1364"></a><tt class="py-lineno">1364</tt> <tt class="py-line"><tt class="py-docstring"> supplied values. By default this will report to main.log, but the</tt> </tt> |
| 1520 | <a name="L1365"></a><tt class="py-lineno">1365</tt> <tt class="py-line"><tt class="py-docstring"> log level can be specific.</tt> </tt> |
| 1521 | <a name="L1366"></a><tt class="py-lineno">1366</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1522 | <a name="L1367"></a><tt class="py-lineno">1367</tt> <tt class="py-line"><tt class="py-docstring"> Params: ip = ip used for the onos cli</tt> </tt> |
| 1523 | <a name="L1368"></a><tt class="py-lineno">1368</tt> <tt class="py-line"><tt class="py-docstring"> numoswitch = expected number of switches</tt> </tt> |
| 1524 | <a name="L1369"></a><tt class="py-lineno">1369</tt> <tt class="py-line"><tt class="py-docstring"> numolink = expected number of links</tt> </tt> |
| 1525 | <a name="L1370"></a><tt class="py-lineno">1370</tt> <tt class="py-line"><tt class="py-docstring"> logLevel = level to log to.</tt> </tt> |
| 1526 | <a name="L1371"></a><tt class="py-lineno">1371</tt> <tt class="py-line"><tt class="py-docstring"> Currently accepts 'info', 'warn' and 'report'</tt> </tt> |
| 1527 | <a name="L1372"></a><tt class="py-lineno">1372</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1528 | <a name="L1373"></a><tt class="py-lineno">1373</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1529 | <a name="L1374"></a><tt class="py-lineno">1374</tt> <tt class="py-line"><tt class="py-docstring"> logLevel can</tt> </tt> |
| 1530 | <a name="L1375"></a><tt class="py-lineno">1375</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1531 | <a name="L1376"></a><tt class="py-lineno">1376</tt> <tt class="py-line"><tt class="py-docstring"> Returns: main.TRUE if the number of switches and links are correct,</tt> </tt> |
| 1532 | <a name="L1377"></a><tt class="py-lineno">1377</tt> <tt class="py-line"><tt class="py-docstring"> main.FALSE if the number of switches and links is incorrect,</tt> </tt> |
| 1533 | <a name="L1378"></a><tt class="py-lineno">1378</tt> <tt class="py-line"><tt class="py-docstring"> and main.ERROR otherwise</tt> </tt> |
| 1534 | <a name="L1379"></a><tt class="py-lineno">1379</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1535 | <a name="L1380"></a><tt class="py-lineno">1380</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1536 | <a name="L1381"></a><tt class="py-lineno">1381</tt> <tt class="py-line"> <tt id="link-431" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology |
| 1537 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-431', 'topology', 'link-419');">topology</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-432" 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-432', 'getTopology', 'link-432');">getTopology</a></tt><tt class="py-op">(</tt> <tt class="py-name">topologyResult</tt> <tt class="py-op">)</tt> </tt> |
| 1538 | <a name="L1382"></a><tt class="py-lineno">1382</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt id="link-433" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology |
| 1539 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-433', 'topology', 'link-419');">topology</a></tt> <tt class="py-op">==</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">:</tt> </tt> |
| 1540 | <a name="L1383"></a><tt class="py-lineno">1383</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 1541 | <a name="L1384"></a><tt class="py-lineno">1384</tt> <tt class="py-line"> <tt id="link-434" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-434', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt> </tt> |
| 1542 | <a name="L1385"></a><tt class="py-lineno">1385</tt> <tt class="py-line"> <tt class="py-comment"># Is the number of switches is what we expected</tt> </tt> |
| 1543 | <a name="L1386"></a><tt class="py-lineno">1386</tt> <tt class="py-line"> <tt id="link-435" class="py-name" targets="Method TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices()=TestON.drivers.common.cli.onosclidriver.OnosCliDriver-class.html#devices"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-435', 'devices', 'link-435');">devices</a></tt> <tt class="py-op">=</tt> <tt id="link-436" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology |
| 1544 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-436', 'topology', 'link-419');">topology</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'devices'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt> <tt class="py-op">)</tt> </tt> |
| 1545 | <a name="L1387"></a><tt class="py-lineno">1387</tt> <tt class="py-line"> <tt id="link-437" 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 |
| 1546 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-437', 'links', 'link-437');">links</a></tt> <tt class="py-op">=</tt> <tt id="link-438" class="py-name"><a title="TestON.drivers.common.api.controller.onosrestdriver.OnosRestDriver.topology |
| 1547 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.topology" class="py-name" href="#" onclick="return doclink('link-438', 'topology', 'link-419');">topology</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt> <tt class="py-string">'links'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt> <tt class="py-op">)</tt> </tt> |
| 1548 | <a name="L1388"></a><tt class="py-lineno">1388</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-439" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-439', 'devices', 'link-435');">devices</a></tt> <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt id="link-440" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links |
| 1549 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-440', 'links', 'link-437');">links</a></tt><tt class="py-op">:</tt> </tt> |
| 1550 | <a name="L1389"></a><tt class="py-lineno">1389</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 1551 | <a name="L1390"></a><tt class="py-lineno">1390</tt> <tt class="py-line"> <tt class="py-name">switchCheck</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt id="link-441" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-441', 'devices', 'link-435');">devices</a></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">numoswitch</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1552 | <a name="L1391"></a><tt class="py-lineno">1391</tt> <tt class="py-line"> <tt class="py-comment"># Is the number of links is what we expected</tt> </tt> |
| 1553 | <a name="L1392"></a><tt class="py-lineno">1392</tt> <tt class="py-line"> <tt class="py-name">linkCheck</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt id="link-442" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links |
| 1554 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-442', 'links', 'link-437');">links</a></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">numolink</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1555 | <a name="L1393"></a><tt class="py-lineno">1393</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switchCheck</tt> <tt class="py-keyword">and</tt> <tt class="py-name">linkCheck</tt><tt class="py-op">:</tt> </tt> |
| 1556 | <a name="L1394"></a><tt class="py-lineno">1394</tt> <tt class="py-line"> <tt class="py-comment"># We expected the correct numbers</tt> </tt> |
| 1557 | <a name="L1395"></a><tt class="py-lineno">1395</tt> <tt class="py-line"> <tt id="link-443" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-443', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt id="link-444" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-444', 'output', 'link-98');">output</a></tt> <tt class="py-op">+</tt> <tt class="py-string">"The number of links and switches match "</tt>\ </tt> |
| 1558 | <a name="L1396"></a><tt class="py-lineno">1396</tt> <tt class="py-line"> <tt class="py-op">+</tt> <tt class="py-string">"what was expected"</tt> </tt> |
| 1559 | <a name="L1397"></a><tt class="py-lineno">1397</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1560 | <a name="L1398"></a><tt class="py-lineno">1398</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1561 | <a name="L1399"></a><tt class="py-lineno">1399</tt> <tt class="py-line"> <tt id="link-445" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-445', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt id="link-446" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-446', 'output', 'link-98');">output</a></tt> <tt class="py-op">+</tt> \ </tt> |
| 1562 | <a name="L1400"></a><tt class="py-lineno">1400</tt> <tt class="py-line"> <tt class="py-string">"The number of links and switches does not match "</tt> <tt class="py-op">+</tt> \ </tt> |
| 1563 | <a name="L1401"></a><tt class="py-lineno">1401</tt> <tt class="py-line"> <tt class="py-string">"what was expected"</tt> </tt> |
| 1564 | <a name="L1402"></a><tt class="py-lineno">1402</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1565 | <a name="L1403"></a><tt class="py-lineno">1403</tt> <tt class="py-line"> <tt id="link-447" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-447', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt id="link-448" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-448', 'output', 'link-98');">output</a></tt> <tt class="py-op">+</tt> <tt class="py-string">"\n ONOS sees %i devices"</tt> <tt class="py-op">%</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt id="link-449" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.devices" class="py-name" href="#" onclick="return doclink('link-449', 'devices', 'link-435');">devices</a></tt> <tt class="py-op">)</tt> </tt> |
| 1566 | <a name="L1404"></a><tt class="py-lineno">1404</tt> <tt class="py-line"> <tt id="link-450" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-450', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt id="link-451" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-451', 'output', 'link-98');">output</a></tt> <tt class="py-op">+</tt> <tt class="py-string">" (%i expected) "</tt> <tt class="py-op">%</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">numoswitch</tt> <tt class="py-op">)</tt> </tt> |
| 1567 | <a name="L1405"></a><tt class="py-lineno">1405</tt> <tt class="py-line"> <tt id="link-452" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-452', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt id="link-453" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-453', 'output', 'link-98');">output</a></tt> <tt class="py-op">+</tt> <tt class="py-string">"and %i links "</tt> <tt class="py-op">%</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt id="link-454" class="py-name"><a title="TestON.drivers.common.cli.emulator.mininetclidriver.MininetCliDriver.links |
| 1568 | TestON.drivers.common.cli.onosclidriver.OnosCliDriver.links" class="py-name" href="#" onclick="return doclink('link-454', 'links', 'link-437');">links</a></tt> <tt class="py-op">)</tt> </tt> |
| 1569 | <a name="L1406"></a><tt class="py-lineno">1406</tt> <tt class="py-line"> <tt id="link-455" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-455', 'output', 'link-98');">output</a></tt> <tt class="py-op">=</tt> <tt id="link-456" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-456', 'output', 'link-98');">output</a></tt> <tt class="py-op">+</tt> <tt class="py-string">"(%i expected)"</tt> <tt class="py-op">%</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt> <tt class="py-name">numolink</tt> <tt class="py-op">)</tt> </tt> |
| 1570 | <a name="L1407"></a><tt class="py-lineno">1407</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">logLevel</tt> <tt class="py-op">==</tt> <tt class="py-string">"report"</tt><tt class="py-op">:</tt> </tt> |
| 1571 | <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 id="link-457" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-457', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">report</tt><tt class="py-op">(</tt> <tt id="link-458" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-458', 'output', 'link-98');">output</a></tt> <tt class="py-op">)</tt> </tt> |
| 1572 | <a name="L1409"></a><tt class="py-lineno">1409</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">logLevel</tt> <tt class="py-op">==</tt> <tt class="py-string">"warn"</tt><tt class="py-op">:</tt> </tt> |
| 1573 | <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-459" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-459', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt id="link-460" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-460', 'output', 'link-98');">output</a></tt> <tt class="py-op">)</tt> </tt> |
| 1574 | <a name="L1411"></a><tt class="py-lineno">1411</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1575 | <a name="L1412"></a><tt class="py-lineno">1412</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-461" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-461', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt id="link-462" class="py-name"><a title="TestON.bin.cli.output" class="py-name" href="#" onclick="return doclink('link-462', 'output', 'link-98');">output</a></tt> <tt class="py-op">)</tt> </tt> |
| 1576 | <a name="L1413"></a><tt class="py-lineno">1413</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">result</tt> </tt> |
| 1577 | <a name="L1414"></a><tt class="py-lineno">1414</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1578 | <a name="L1415"></a><tt class="py-lineno">1415</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-464" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-464', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1579 | <a name="L1416"></a><tt class="py-lineno">1416</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-465', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-466" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-466', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1580 | <a name="L1417"></a><tt class="py-lineno">1417</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-467" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-467', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1581 | <a name="L1418"></a><tt class="py-lineno">1418</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-468" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-468', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1582 | <a name="L1419"></a><tt class="py-lineno">1419</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1583 | <a name="L1420"></a><tt class="py-lineno">1420</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-469" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-469', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1584 | <a name="L1421"></a><tt class="py-lineno">1421</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-470" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-470', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1585 | <a name="L1422"></a><tt class="py-lineno">1422</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-471" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-471', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1586 | </div><a name="L1423"></a><tt class="py-lineno">1423</tt> <tt class="py-line"> </tt> |
| 1587 | <a name="OnosDriver.tsharkPcap"></a><div id="OnosDriver.tsharkPcap-def"><a name="L1424"></a><tt class="py-lineno">1424</tt> <a class="py-toggle" href="#" id="OnosDriver.tsharkPcap-toggle" onclick="return toggle('OnosDriver.tsharkPcap');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#tsharkPcap">tsharkPcap</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">interface</tt><tt class="py-op">,</tt> <tt class="py-param">dirFile</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1588 | </div><div id="OnosDriver.tsharkPcap-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.tsharkPcap-expanded"><a name="L1425"></a><tt class="py-lineno">1425</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1589 | <a name="L1426"></a><tt class="py-lineno">1426</tt> <tt class="py-line"><tt class="py-docstring"> Capture all packet activity and store in specified</tt> </tt> |
| 1590 | <a name="L1427"></a><tt class="py-lineno">1427</tt> <tt class="py-line"><tt class="py-docstring"> directory/file</tt> </tt> |
| 1591 | <a name="L1428"></a><tt class="py-lineno">1428</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1592 | <a name="L1429"></a><tt class="py-lineno">1429</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 1593 | <a name="L1430"></a><tt class="py-lineno">1430</tt> <tt class="py-line"><tt class="py-docstring"> * interface: interface to capture</tt> </tt> |
| 1594 | <a name="L1431"></a><tt class="py-lineno">1431</tt> <tt class="py-line"><tt class="py-docstring"> * dir: directory/filename to store pcap</tt> </tt> |
| 1595 | <a name="L1432"></a><tt class="py-lineno">1432</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1596 | <a name="L1433"></a><tt class="py-lineno">1433</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1597 | <a name="L1434"></a><tt class="py-lineno">1434</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-472" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-472', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1598 | <a name="L1435"></a><tt class="py-lineno">1435</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1599 | <a name="L1436"></a><tt class="py-lineno">1436</tt> <tt class="py-line"> </tt> |
| 1600 | <a name="L1437"></a><tt class="py-lineno">1437</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-473" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-473', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"tshark -i "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">interface</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" -t e -w "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">dirFile</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" &"</tt> <tt class="py-op">)</tt> </tt> |
| 1601 | <a name="L1438"></a><tt class="py-lineno">1438</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-474" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-474', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"\r"</tt> <tt class="py-op">)</tt> </tt> |
| 1602 | <a name="L1439"></a><tt class="py-lineno">1439</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"Capturing on"</tt> <tt class="py-op">)</tt> </tt> |
| 1603 | <a name="L1440"></a><tt class="py-lineno">1440</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-475" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-475', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"\r"</tt> <tt class="py-op">)</tt> </tt> |
| 1604 | <a name="L1441"></a><tt class="py-lineno">1441</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1605 | <a name="L1442"></a><tt class="py-lineno">1442</tt> <tt class="py-line"> </tt> |
| 1606 | <a name="L1443"></a><tt class="py-lineno">1443</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-476" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-476', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Tshark started capturing files on "</tt> <tt class="py-op">+</tt> </tt> |
| 1607 | <a name="L1444"></a><tt class="py-lineno">1444</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">interface</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" and saving to directory: "</tt> <tt class="py-op">+</tt> </tt> |
| 1608 | <a name="L1445"></a><tt class="py-lineno">1445</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">dirFile</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1609 | <a name="L1446"></a><tt class="py-lineno">1446</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1610 | <a name="L1447"></a><tt class="py-lineno">1447</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-477" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-477', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-478" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-478', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1611 | <a name="L1448"></a><tt class="py-lineno">1448</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-480" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-480', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1612 | <a name="L1449"></a><tt class="py-lineno">1449</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-481" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-481', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1613 | <a name="L1450"></a><tt class="py-lineno">1450</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-482" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-482', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1614 | <a name="L1451"></a><tt class="py-lineno">1451</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1615 | <a name="L1452"></a><tt class="py-lineno">1452</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-483" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-483', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1616 | <a name="L1453"></a><tt class="py-lineno">1453</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-484" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-484', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1617 | <a name="L1454"></a><tt class="py-lineno">1454</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-485', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1618 | </div><a name="L1455"></a><tt class="py-lineno">1455</tt> <tt class="py-line"> </tt> |
| 1619 | <a name="OnosDriver.runOnosTopoCfg"></a><div id="OnosDriver.runOnosTopoCfg-def"><a name="L1456"></a><tt class="py-lineno">1456</tt> <a class="py-toggle" href="#" id="OnosDriver.runOnosTopoCfg-toggle" onclick="return toggle('OnosDriver.runOnosTopoCfg');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#runOnosTopoCfg">runOnosTopoCfg</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">instanceName</tt><tt class="py-op">,</tt> <tt class="py-param">jsonFile</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1620 | </div><div id="OnosDriver.runOnosTopoCfg-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.runOnosTopoCfg-expanded"><a name="L1457"></a><tt class="py-lineno">1457</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1621 | <a name="L1458"></a><tt class="py-lineno">1458</tt> <tt class="py-line"><tt class="py-docstring"> On ONOS bench, run this command:</tt> </tt> |
| 1622 | <a name="L1459"></a><tt class="py-lineno">1459</tt> <tt class="py-line"><tt class="py-docstring"> {ONOS_HOME}/tools/test/bin/onos-topo-cfg $OC1 filename</tt> </tt> |
| 1623 | <a name="L1460"></a><tt class="py-lineno">1460</tt> <tt class="py-line"><tt class="py-docstring"> which starts the rest and copies</tt> </tt> |
| 1624 | <a name="L1461"></a><tt class="py-lineno">1461</tt> <tt class="py-line"><tt class="py-docstring"> the json file to the onos instance</tt> </tt> |
| 1625 | <a name="L1462"></a><tt class="py-lineno">1462</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1626 | <a name="L1463"></a><tt class="py-lineno">1463</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1627 | <a name="L1464"></a><tt class="py-lineno">1464</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-486" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-486', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1628 | <a name="L1465"></a><tt class="py-lineno">1465</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1629 | <a name="L1466"></a><tt class="py-lineno">1466</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-487" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-487', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"/tools/test/bin"</tt> <tt class="py-op">)</tt> </tt> |
| 1630 | <a name="L1467"></a><tt class="py-lineno">1467</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"/bin$"</tt> <tt class="py-op">)</tt> </tt> |
| 1631 | <a name="L1468"></a><tt class="py-lineno">1468</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"./onos-topo-cfg "</tt> <tt class="py-op">+</tt> <tt class="py-name">instanceName</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">jsonFile</tt> </tt> |
| 1632 | <a name="L1469"></a><tt class="py-lineno">1469</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"cmd = "</tt><tt class="py-op">,</tt> <tt class="py-name">cmd</tt> </tt> |
| 1633 | <a name="L1470"></a><tt class="py-lineno">1470</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-488" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-488', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 1634 | <a name="L1471"></a><tt class="py-lineno">1471</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1635 | <a name="L1472"></a><tt class="py-lineno">1472</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-489" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-489', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd ~"</tt> <tt class="py-op">)</tt> </tt> |
| 1636 | <a name="L1473"></a><tt class="py-lineno">1473</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1637 | <a name="L1474"></a><tt class="py-lineno">1474</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1638 | <a name="L1475"></a><tt class="py-lineno">1475</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1639 | <a name="L1476"></a><tt class="py-lineno">1476</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-490" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-490', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-491" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-491', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1640 | <a name="L1477"></a><tt class="py-lineno">1477</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-493" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-493', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1641 | <a name="L1478"></a><tt class="py-lineno">1478</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-494" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-494', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1642 | <a name="L1479"></a><tt class="py-lineno">1479</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.exit" class="py-name" href="#" onclick="return doclink('link-495', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1643 | <a name="L1480"></a><tt class="py-lineno">1480</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1644 | <a name="L1481"></a><tt class="py-lineno">1481</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-496" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-496', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1645 | <a name="L1482"></a><tt class="py-lineno">1482</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-497', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1646 | <a name="L1483"></a><tt class="py-lineno">1483</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-498" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-498', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1647 | </div><a name="L1484"></a><tt class="py-lineno">1484</tt> <tt class="py-line"> </tt> |
| 1648 | <a name="OnosDriver.tsharkGrep"></a><div id="OnosDriver.tsharkGrep-def"><a name="L1485"></a><tt class="py-lineno">1485</tt> <a class="py-toggle" href="#" id="OnosDriver.tsharkGrep-toggle" onclick="return toggle('OnosDriver.tsharkGrep');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#tsharkGrep">tsharkGrep</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">grep</tt><tt class="py-op">,</tt> <tt class="py-param">directory</tt><tt class="py-op">,</tt> <tt class="py-param">interface</tt><tt class="py-op">=</tt><tt class="py-string">'eth0'</tt><tt class="py-op">,</tt> <tt class="py-param">grepOptions</tt><tt class="py-op">=</tt><tt class="py-string">''</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1649 | </div><div id="OnosDriver.tsharkGrep-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.tsharkGrep-expanded"><a name="L1486"></a><tt class="py-lineno">1486</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1650 | <a name="L1487"></a><tt class="py-lineno">1487</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 1651 | <a name="L1488"></a><tt class="py-lineno">1488</tt> <tt class="py-line"><tt class="py-docstring"> * grep string</tt> </tt> |
| 1652 | <a name="L1489"></a><tt class="py-lineno">1489</tt> <tt class="py-line"><tt class="py-docstring"> * directory to store results</tt> </tt> |
| 1653 | <a name="L1490"></a><tt class="py-lineno">1490</tt> <tt class="py-line"><tt class="py-docstring"> Optional:</tt> </tt> |
| 1654 | <a name="L1491"></a><tt class="py-lineno">1491</tt> <tt class="py-line"><tt class="py-docstring"> * interface - default: eth0</tt> </tt> |
| 1655 | <a name="L1492"></a><tt class="py-lineno">1492</tt> <tt class="py-line"><tt class="py-docstring"> * grepOptions - options for grep</tt> </tt> |
| 1656 | <a name="L1493"></a><tt class="py-lineno">1493</tt> <tt class="py-line"><tt class="py-docstring"> Description:</tt> </tt> |
| 1657 | <a name="L1494"></a><tt class="py-lineno">1494</tt> <tt class="py-line"><tt class="py-docstring"> Uses tshark command to grep specific group of packets</tt> </tt> |
| 1658 | <a name="L1495"></a><tt class="py-lineno">1495</tt> <tt class="py-line"><tt class="py-docstring"> and stores the results to specified directory.</tt> </tt> |
| 1659 | <a name="L1496"></a><tt class="py-lineno">1496</tt> <tt class="py-line"><tt class="py-docstring"> The timestamp is hardcoded to be in epoch</tt> </tt> |
| 1660 | <a name="L1497"></a><tt class="py-lineno">1497</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1661 | <a name="L1498"></a><tt class="py-lineno">1498</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1662 | <a name="L1499"></a><tt class="py-lineno">1499</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-499" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-499', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1663 | <a name="L1500"></a><tt class="py-lineno">1500</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1664 | <a name="L1501"></a><tt class="py-lineno">1501</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-500" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-500', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1665 | <a name="L1502"></a><tt class="py-lineno">1502</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">grepOptions</tt><tt class="py-op">:</tt> </tt> |
| 1666 | <a name="L1503"></a><tt class="py-lineno">1503</tt> <tt class="py-line"> <tt class="py-name">grepStr</tt> <tt class="py-op">=</tt> <tt class="py-string">"grep "</tt><tt class="py-op">+</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">grepOptions</tt><tt class="py-op">)</tt> </tt> |
| 1667 | <a name="L1504"></a><tt class="py-lineno">1504</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1668 | <a name="L1505"></a><tt class="py-lineno">1505</tt> <tt class="py-line"> <tt class="py-name">grepStr</tt> <tt class="py-op">=</tt> <tt class="py-string">"grep"</tt> </tt> |
| 1669 | <a name="L1506"></a><tt class="py-lineno">1506</tt> <tt class="py-line"> </tt> |
| 1670 | <a name="L1507"></a><tt class="py-lineno">1507</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> </tt> |
| 1671 | <a name="L1508"></a><tt class="py-lineno">1508</tt> <tt class="py-line"> <tt class="py-string">"sudo tshark -i "</tt> <tt class="py-op">+</tt> </tt> |
| 1672 | <a name="L1509"></a><tt class="py-lineno">1509</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">interface</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1673 | <a name="L1510"></a><tt class="py-lineno">1510</tt> <tt class="py-line"> <tt class="py-string">" -t e | "</tt> <tt class="py-op">+</tt> </tt> |
| 1674 | <a name="L1511"></a><tt class="py-lineno">1511</tt> <tt class="py-line"> <tt class="py-name">grepStr</tt> <tt class="py-op">+</tt> <tt class="py-string">" --line-buffered \""</tt> <tt class="py-op">+</tt> </tt> |
| 1675 | <a name="L1512"></a><tt class="py-lineno">1512</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">grep</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1676 | <a name="L1513"></a><tt class="py-lineno">1513</tt> <tt class="py-line"> <tt class="py-string">"\" >"</tt> <tt class="py-op">+</tt> </tt> |
| 1677 | <a name="L1514"></a><tt class="py-lineno">1514</tt> <tt class="py-line"> <tt class="py-name">directory</tt> <tt class="py-op">+</tt> </tt> |
| 1678 | <a name="L1515"></a><tt class="py-lineno">1515</tt> <tt class="py-line"> <tt class="py-string">" &"</tt> <tt class="py-op">)</tt> </tt> |
| 1679 | <a name="L1516"></a><tt class="py-lineno">1516</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-501" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-501', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-name">cmd</tt><tt class="py-op">)</tt> </tt> |
| 1680 | <a name="L1517"></a><tt class="py-lineno">1517</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-name">cmd</tt><tt class="py-op">)</tt> </tt> |
| 1681 | <a name="L1518"></a><tt class="py-lineno">1518</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"Capturing on"</tt> <tt class="py-op">)</tt> </tt> |
| 1682 | <a name="L1519"></a><tt class="py-lineno">1519</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-503" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-503', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">)</tt> </tt> |
| 1683 | <a name="L1520"></a><tt class="py-lineno">1520</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1684 | <a name="L1521"></a><tt class="py-lineno">1521</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1685 | <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-504" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-504', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-505" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-505', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1686 | <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-506" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-506', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-507" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-507', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1687 | <a name="L1524"></a><tt class="py-lineno">1524</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-508', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1688 | <a name="L1525"></a><tt class="py-lineno">1525</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-509" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-509', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1689 | <a name="L1526"></a><tt class="py-lineno">1526</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1690 | <a name="L1527"></a><tt class="py-lineno">1527</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-510" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-510', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1691 | <a name="L1528"></a><tt class="py-lineno">1528</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-511', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1692 | <a name="L1529"></a><tt class="py-lineno">1529</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-512" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-512', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1693 | </div><a name="L1530"></a><tt class="py-lineno">1530</tt> <tt class="py-line"> </tt> |
| 1694 | <a name="OnosDriver.tsharkStop"></a><div id="OnosDriver.tsharkStop-def"><a name="L1531"></a><tt class="py-lineno">1531</tt> <a class="py-toggle" href="#" id="OnosDriver.tsharkStop-toggle" onclick="return toggle('OnosDriver.tsharkStop');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#tsharkStop">tsharkStop</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1695 | </div><div id="OnosDriver.tsharkStop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.tsharkStop-expanded"><a name="L1532"></a><tt class="py-lineno">1532</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1696 | <a name="L1533"></a><tt class="py-lineno">1533</tt> <tt class="py-line"><tt class="py-docstring"> Removes wireshark files from /tmp and kills all tshark processes</tt> </tt> |
| 1697 | <a name="L1534"></a><tt class="py-lineno">1534</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1698 | <a name="L1535"></a><tt class="py-lineno">1535</tt> <tt class="py-line"> <tt class="py-comment"># Remove all pcap from previous captures</tt> </tt> |
| 1699 | <a name="L1536"></a><tt class="py-lineno">1536</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1700 | <a name="L1537"></a><tt class="py-lineno">1537</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-513" class="py-name" targets="Method TestON.bin.generatedriver.GenerateDriver.execute()=TestON.bin.generatedriver.GenerateDriver-class.html#execute,Method TestON.drivers.common.clidriver.CLI.execute()=TestON.drivers.common.clidriver.CLI-class.html#execute"><a title="TestON.bin.generatedriver.GenerateDriver.execute |
| 1701 | TestON.drivers.common.clidriver.CLI.execute" class="py-name" href="#" onclick="return doclink('link-513', 'execute', 'link-513');">execute</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt><tt class="py-op">=</tt><tt class="py-string">"sudo rm /tmp/wireshark*"</tt> <tt class="py-op">)</tt> </tt> |
| 1702 | <a name="L1538"></a><tt class="py-lineno">1538</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-514" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-514', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1703 | <a name="L1539"></a><tt class="py-lineno">1539</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-515" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-515', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"sudo kill -9 `ps -ef | grep \"tshark -i\""</tt> <tt class="py-op">+</tt> </tt> |
| 1704 | <a name="L1540"></a><tt class="py-lineno">1540</tt> <tt class="py-line"> <tt class="py-string">" | grep -v grep | awk '{print $2}'`"</tt> <tt class="py-op">)</tt> </tt> |
| 1705 | <a name="L1541"></a><tt class="py-lineno">1541</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-516" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-516', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1706 | <a name="L1542"></a><tt class="py-lineno">1542</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-517" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-517', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"Tshark stopped"</tt> <tt class="py-op">)</tt> </tt> |
| 1707 | <a name="L1543"></a><tt class="py-lineno">1543</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1708 | <a name="L1544"></a><tt class="py-lineno">1544</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-518" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-518', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-519" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-519', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1709 | <a name="L1545"></a><tt class="py-lineno">1545</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-521" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-521', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1710 | <a name="L1546"></a><tt class="py-lineno">1546</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-522" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-522', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1711 | <a name="L1547"></a><tt class="py-lineno">1547</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-523" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-523', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1712 | <a name="L1548"></a><tt class="py-lineno">1548</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1713 | <a name="L1549"></a><tt class="py-lineno">1549</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-524" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-524', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1714 | <a name="L1550"></a><tt class="py-lineno">1550</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-525', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1715 | <a name="L1551"></a><tt class="py-lineno">1551</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-526', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1716 | </div><a name="L1552"></a><tt class="py-lineno">1552</tt> <tt class="py-line"> </tt> |
| 1717 | <a name="OnosDriver.ptpd"></a><div id="OnosDriver.ptpd-def"><a name="L1553"></a><tt class="py-lineno">1553</tt> <a class="py-toggle" href="#" id="OnosDriver.ptpd-toggle" onclick="return toggle('OnosDriver.ptpd');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#ptpd">ptpd</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">args</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1718 | </div><div id="OnosDriver.ptpd-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.ptpd-expanded"><a name="L1554"></a><tt class="py-lineno">1554</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1719 | <a name="L1555"></a><tt class="py-lineno">1555</tt> <tt class="py-line"><tt class="py-docstring"> Initiate ptp with user-specified args.</tt> </tt> |
| 1720 | <a name="L1556"></a><tt class="py-lineno">1556</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 1721 | <a name="L1557"></a><tt class="py-lineno">1557</tt> <tt class="py-line"><tt class="py-docstring"> * args: specify string of args after command</tt> </tt> |
| 1722 | <a name="L1558"></a><tt class="py-lineno">1558</tt> <tt class="py-line"><tt class="py-docstring"> 'sudo ptpd'</tt> </tt> |
| 1723 | <a name="L1559"></a><tt class="py-lineno">1559</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1724 | <a name="L1560"></a><tt class="py-lineno">1560</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1725 | <a name="L1561"></a><tt class="py-lineno">1561</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-527" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-527', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"sudo ptpd "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">args</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1726 | <a name="L1562"></a><tt class="py-lineno">1562</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 1727 | <a name="L1563"></a><tt class="py-lineno">1563</tt> <tt class="py-line"> <tt class="py-string">"Multiple"</tt><tt class="py-op">,</tt> </tt> |
| 1728 | <a name="L1564"></a><tt class="py-lineno">1564</tt> <tt class="py-line"> <tt class="py-string">"Error"</tt><tt class="py-op">,</tt> </tt> |
| 1729 | <a name="L1565"></a><tt class="py-lineno">1565</tt> <tt class="py-line"> <tt class="py-string">"\$"</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt> |
| 1730 | <a name="L1566"></a><tt class="py-lineno">1566</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1731 | <a name="L1567"></a><tt class="py-lineno">1567</tt> <tt class="py-line"> </tt> |
| 1732 | <a name="L1568"></a><tt class="py-lineno">1568</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1733 | <a name="L1569"></a><tt class="py-lineno">1569</tt> <tt class="py-line"> <tt class="py-name">handle</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1734 | <a name="L1570"></a><tt class="py-lineno">1570</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-528" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-528', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ptpd returned an error: "</tt> <tt class="py-op">+</tt> </tt> |
| 1735 | <a name="L1571"></a><tt class="py-lineno">1571</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">handle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1736 | <a name="L1572"></a><tt class="py-lineno">1572</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">handle</tt> </tt> |
| 1737 | <a name="L1573"></a><tt class="py-lineno">1573</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1738 | <a name="L1574"></a><tt class="py-lineno">1574</tt> <tt class="py-line"> <tt class="py-name">handle</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1739 | <a name="L1575"></a><tt class="py-lineno">1575</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-529" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-529', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-530" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-530', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ptpd returned an error: "</tt> <tt class="py-op">+</tt> </tt> |
| 1740 | <a name="L1576"></a><tt class="py-lineno">1576</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">handle</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1741 | <a name="L1577"></a><tt class="py-lineno">1577</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">handle</tt> </tt> |
| 1742 | <a name="L1578"></a><tt class="py-lineno">1578</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1743 | <a name="L1579"></a><tt class="py-lineno">1579</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1744 | <a name="L1580"></a><tt class="py-lineno">1580</tt> <tt class="py-line"> </tt> |
| 1745 | <a name="L1581"></a><tt class="py-lineno">1581</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1746 | <a name="L1582"></a><tt class="py-lineno">1582</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-531" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-531', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-532" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-532', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1747 | <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-533" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-533', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-534" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-534', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1748 | <a name="L1584"></a><tt class="py-lineno">1584</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-535', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1749 | <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-536" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-536', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1750 | <a name="L1586"></a><tt class="py-lineno">1586</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1751 | <a name="L1587"></a><tt class="py-lineno">1587</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1752 | <a name="L1588"></a><tt class="py-lineno">1588</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-538', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1753 | <a name="L1589"></a><tt class="py-lineno">1589</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.exit" class="py-name" href="#" onclick="return doclink('link-539', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1754 | </div><a name="L1590"></a><tt class="py-lineno">1590</tt> <tt class="py-line"> </tt> |
| 1755 | <a name="OnosDriver.cpLogsToDir"></a><div id="OnosDriver.cpLogsToDir-def"><a name="L1591"></a><tt class="py-lineno">1591</tt> <a class="py-toggle" href="#" id="OnosDriver.cpLogsToDir-toggle" onclick="return toggle('OnosDriver.cpLogsToDir');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#cpLogsToDir">cpLogsToDir</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">logToCopy</tt><tt class="py-op">,</tt> </tt> |
| 1756 | <a name="L1592"></a><tt class="py-lineno">1592</tt> <tt class="py-line"> <tt class="py-param">destDir</tt><tt class="py-op">,</tt> <tt class="py-param">copyFileName</tt><tt class="py-op">=</tt><tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1757 | </div><div id="OnosDriver.cpLogsToDir-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.cpLogsToDir-expanded"><a name="L1593"></a><tt class="py-lineno">1593</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1758 | <a name="L1594"></a><tt class="py-lineno">1594</tt> <tt class="py-line"><tt class="py-docstring"> Copies logs to a desired directory.</tt> </tt> |
| 1759 | <a name="L1595"></a><tt class="py-lineno">1595</tt> <tt class="py-line"><tt class="py-docstring"> Current implementation of ONOS deletes its karaf</tt> </tt> |
| 1760 | <a name="L1596"></a><tt class="py-lineno">1596</tt> <tt class="py-line"><tt class="py-docstring"> logs on every iteration. For debugging purposes,</tt> </tt> |
| 1761 | <a name="L1597"></a><tt class="py-lineno">1597</tt> <tt class="py-line"><tt class="py-docstring"> you may want to use this function to capture</tt> </tt> |
| 1762 | <a name="L1598"></a><tt class="py-lineno">1598</tt> <tt class="py-line"><tt class="py-docstring"> certain karaf logs. ( or any other logs if needed )</tt> </tt> |
| 1763 | <a name="L1599"></a><tt class="py-lineno">1599</tt> <tt class="py-line"><tt class="py-docstring"> Localtime will be attached to the filename</tt> </tt> |
| 1764 | <a name="L1600"></a><tt class="py-lineno">1600</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 1765 | <a name="L1601"></a><tt class="py-lineno">1601</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 1766 | <a name="L1602"></a><tt class="py-lineno">1602</tt> <tt class="py-line"><tt class="py-docstring"> * logToCopy: specify directory and log name to</tt> </tt> |
| 1767 | <a name="L1603"></a><tt class="py-lineno">1603</tt> <tt class="py-line"><tt class="py-docstring"> copy.</tt> </tt> |
| 1768 | <a name="L1604"></a><tt class="py-lineno">1604</tt> <tt class="py-line"><tt class="py-docstring"> ex ) /opt/onos/log/karaf.log.1</tt> </tt> |
| 1769 | <a name="L1605"></a><tt class="py-lineno">1605</tt> <tt class="py-line"><tt class="py-docstring"> For copying multiple files, leave copyFileName</tt> </tt> |
| 1770 | <a name="L1606"></a><tt class="py-lineno">1606</tt> <tt class="py-line"><tt class="py-docstring"> empty and only specify destDir -</tt> </tt> |
| 1771 | <a name="L1607"></a><tt class="py-lineno">1607</tt> <tt class="py-line"><tt class="py-docstring"> ex ) /opt/onos/log/karaf*</tt> </tt> |
| 1772 | <a name="L1608"></a><tt class="py-lineno">1608</tt> <tt class="py-line"><tt class="py-docstring"> * destDir: specify directory to copy to.</tt> </tt> |
| 1773 | <a name="L1609"></a><tt class="py-lineno">1609</tt> <tt class="py-line"><tt class="py-docstring"> ex ) /tmp/</tt> </tt> |
| 1774 | <a name="L1610"></a><tt class="py-lineno">1610</tt> <tt class="py-line"><tt class="py-docstring"> Optional:</tt> </tt> |
| 1775 | <a name="L1611"></a><tt class="py-lineno">1611</tt> <tt class="py-line"><tt class="py-docstring"> * copyFileName: If you want to rename the log</tt> </tt> |
| 1776 | <a name="L1612"></a><tt class="py-lineno">1612</tt> <tt class="py-line"><tt class="py-docstring"> file, specify copyFileName. This will not work</tt> </tt> |
| 1777 | <a name="L1613"></a><tt class="py-lineno">1613</tt> <tt class="py-line"><tt class="py-docstring"> with multiple file copying</tt> </tt> |
| 1778 | <a name="L1614"></a><tt class="py-lineno">1614</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1779 | <a name="L1615"></a><tt class="py-lineno">1615</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1780 | <a name="L1616"></a><tt class="py-lineno">1616</tt> <tt class="py-line"> <tt class="py-name">localtime</tt> <tt class="py-op">=</tt> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">strftime</tt><tt class="py-op">(</tt> <tt class="py-string">'%x %X'</tt> <tt class="py-op">)</tt> </tt> |
| 1781 | <a name="L1617"></a><tt class="py-lineno">1617</tt> <tt class="py-line"> <tt class="py-name">localtime</tt> <tt class="py-op">=</tt> <tt class="py-name">localtime</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">"/"</tt><tt class="py-op">,</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1782 | <a name="L1618"></a><tt class="py-lineno">1618</tt> <tt class="py-line"> <tt class="py-name">localtime</tt> <tt class="py-op">=</tt> <tt class="py-name">localtime</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">" "</tt><tt class="py-op">,</tt> <tt class="py-string">"_"</tt> <tt class="py-op">)</tt> </tt> |
| 1783 | <a name="L1619"></a><tt class="py-lineno">1619</tt> <tt class="py-line"> <tt class="py-name">localtime</tt> <tt class="py-op">=</tt> <tt class="py-name">localtime</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt> <tt class="py-string">":"</tt><tt class="py-op">,</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1784 | <a name="L1620"></a><tt class="py-lineno">1620</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">destDir</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-string">"/"</tt><tt class="py-op">:</tt> </tt> |
| 1785 | <a name="L1621"></a><tt class="py-lineno">1621</tt> <tt class="py-line"> <tt class="py-name">destDir</tt> <tt class="py-op">+=</tt> <tt class="py-string">"/"</tt> </tt> |
| 1786 | <a name="L1622"></a><tt class="py-lineno">1622</tt> <tt class="py-line"> </tt> |
| 1787 | <a name="L1623"></a><tt class="py-lineno">1623</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">copyFileName</tt><tt class="py-op">:</tt> </tt> |
| 1788 | <a name="L1624"></a><tt class="py-lineno">1624</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-540" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-540', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cp "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">logToCopy</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> </tt> |
| 1789 | <a name="L1625"></a><tt class="py-lineno">1625</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">destDir</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">copyFileName</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1790 | <a name="L1626"></a><tt class="py-lineno">1626</tt> <tt class="py-line"> <tt class="py-name">localtime</tt> <tt class="py-op">)</tt> </tt> |
| 1791 | <a name="L1627"></a><tt class="py-lineno">1627</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"cp"</tt> <tt class="py-op">)</tt> </tt> |
| 1792 | <a name="L1628"></a><tt class="py-lineno">1628</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1793 | <a name="L1629"></a><tt class="py-lineno">1629</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 1794 | <a name="L1630"></a><tt class="py-lineno">1630</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-541" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-541', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cp "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">logToCopy</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1795 | <a name="L1631"></a><tt class="py-lineno">1631</tt> <tt class="py-line"> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">destDir</tt> <tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 1796 | <a name="L1632"></a><tt class="py-lineno">1632</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"cp"</tt> <tt class="py-op">)</tt> </tt> |
| 1797 | <a name="L1633"></a><tt class="py-lineno">1633</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1798 | <a name="L1634"></a><tt class="py-lineno">1634</tt> <tt class="py-line"> </tt> |
| 1799 | <a name="L1635"></a><tt class="py-lineno">1635</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1800 | <a name="L1636"></a><tt class="py-lineno">1636</tt> <tt class="py-line"> </tt> |
| 1801 | <a name="L1637"></a><tt class="py-lineno">1637</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1802 | <a name="L1638"></a><tt class="py-lineno">1638</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-542" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-542', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-543" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-543', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Copying files failed"</tt> <tt class="py-op">)</tt> </tt> |
| 1803 | <a name="L1639"></a><tt class="py-lineno">1639</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-545" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-545', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1804 | <a name="L1640"></a><tt class="py-lineno">1640</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-546" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-546', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-547" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-547', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1805 | <a name="L1641"></a><tt class="py-lineno">1641</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1806 | <a name="L1642"></a><tt class="py-lineno">1642</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-548" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-548', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-string">"Copying files failed"</tt> <tt class="py-op">)</tt> </tt> |
| 1807 | </div><a name="L1643"></a><tt class="py-lineno">1643</tt> <tt class="py-line"> </tt> |
| 1808 | <a name="OnosDriver.checkLogs"></a><div id="OnosDriver.checkLogs-def"><a name="L1644"></a><tt class="py-lineno">1644</tt> <a class="py-toggle" href="#" id="OnosDriver.checkLogs-toggle" onclick="return toggle('OnosDriver.checkLogs');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#checkLogs">checkLogs</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">onosIp</tt><tt class="py-op">,</tt> <tt class="py-param">restart</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1809 | </div><div id="OnosDriver.checkLogs-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.checkLogs-expanded"><a name="L1645"></a><tt class="py-lineno">1645</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1810 | <a name="L1646"></a><tt class="py-lineno">1646</tt> <tt class="py-line"><tt class="py-docstring"> runs onos-check-logs on the given onos node</tt> </tt> |
| 1811 | <a name="L1647"></a><tt class="py-lineno">1647</tt> <tt class="py-line"><tt class="py-docstring"> If restart is True, use the old version of onos-check-logs which</tt> </tt> |
| 1812 | <a name="L1648"></a><tt class="py-lineno">1648</tt> <tt class="py-line"><tt class="py-docstring"> does not print the full stacktrace, but shows the entire log file,</tt> </tt> |
| 1813 | <a name="L1649"></a><tt class="py-lineno">1649</tt> <tt class="py-line"><tt class="py-docstring"> including across restarts</tt> </tt> |
| 1814 | <a name="L1650"></a><tt class="py-lineno">1650</tt> <tt class="py-line"><tt class="py-docstring"> returns the response</tt> </tt> |
| 1815 | <a name="L1651"></a><tt class="py-lineno">1651</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1816 | <a name="L1652"></a><tt class="py-lineno">1652</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1817 | <a name="L1653"></a><tt class="py-lineno">1653</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"onos-check-logs "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">onosIp</tt> <tt class="py-op">)</tt> </tt> |
| 1818 | <a name="L1654"></a><tt class="py-lineno">1654</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">restart</tt><tt class="py-op">:</tt> </tt> |
| 1819 | <a name="L1655"></a><tt class="py-lineno">1655</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">" old"</tt> </tt> |
| 1820 | <a name="L1656"></a><tt class="py-lineno">1656</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-549" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-549', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 1821 | <a name="L1657"></a><tt class="py-lineno">1657</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 1822 | <a name="L1658"></a><tt class="py-lineno">1658</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1823 | <a name="L1659"></a><tt class="py-lineno">1659</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1824 | <a name="L1660"></a><tt class="py-lineno">1660</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">response</tt> </tt> |
| 1825 | <a name="L1661"></a><tt class="py-lineno">1661</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1826 | <a name="L1662"></a><tt class="py-lineno">1662</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-551" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-551', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Lost ssh connection"</tt> <tt class="py-op">)</tt> </tt> |
| 1827 | <a name="L1663"></a><tt class="py-lineno">1663</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-552', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-553" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-553', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1828 | <a name="L1664"></a><tt class="py-lineno">1664</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-554" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-554', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-555" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-555', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1829 | <a name="L1665"></a><tt class="py-lineno">1665</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1830 | <a name="L1666"></a><tt class="py-lineno">1666</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-556" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-556', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1831 | <a name="L1667"></a><tt class="py-lineno">1667</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-557" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-557', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1832 | <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-558" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-558', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1833 | </div><a name="L1669"></a><tt class="py-lineno">1669</tt> <tt class="py-line"> </tt> |
| 1834 | <a name="OnosDriver.onosStatus"></a><div id="OnosDriver.onosStatus-def"><a name="L1670"></a><tt class="py-lineno">1670</tt> <a class="py-toggle" href="#" id="OnosDriver.onosStatus-toggle" onclick="return toggle('OnosDriver.onosStatus');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#onosStatus">onosStatus</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">node</tt><tt class="py-op">=</tt><tt class="py-string">""</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1835 | </div><div id="OnosDriver.onosStatus-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.onosStatus-expanded"><a name="L1671"></a><tt class="py-lineno">1671</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1836 | <a name="L1672"></a><tt class="py-lineno">1672</tt> <tt class="py-line"><tt class="py-docstring"> Calls onos command: 'onos-service [<node-ip>] status'</tt> </tt> |
| 1837 | <a name="L1673"></a><tt class="py-lineno">1673</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1838 | <a name="L1674"></a><tt class="py-lineno">1674</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1839 | <a name="L1675"></a><tt class="py-lineno">1675</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-559" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-559', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1840 | <a name="L1676"></a><tt class="py-lineno">1676</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1841 | <a name="L1677"></a><tt class="py-lineno">1677</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-560" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-560', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"onos-service "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">node</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> </tt> |
| 1842 | <a name="L1678"></a><tt class="py-lineno">1678</tt> <tt class="py-line"> <tt class="py-string">" status"</tt> <tt class="py-op">)</tt> </tt> |
| 1843 | <a name="L1679"></a><tt class="py-lineno">1679</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> </tt> |
| 1844 | <a name="L1680"></a><tt class="py-lineno">1680</tt> <tt class="py-line"> <tt class="py-string">"start/running"</tt><tt class="py-op">,</tt> </tt> |
| 1845 | <a name="L1681"></a><tt class="py-lineno">1681</tt> <tt class="py-line"> <tt class="py-string">"stop/waiting"</tt><tt class="py-op">,</tt> </tt> |
| 1846 | <a name="L1682"></a><tt class="py-lineno">1682</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">timeout</tt><tt class="py-op">=</tt><tt class="py-number">120</tt> <tt class="py-op">)</tt> </tt> |
| 1847 | <a name="L1683"></a><tt class="py-lineno">1683</tt> <tt class="py-line"> </tt> |
| 1848 | <a name="L1684"></a><tt class="py-lineno">1684</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 1849 | <a name="L1685"></a><tt class="py-lineno">1685</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-561" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-561', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS is running"</tt> <tt class="py-op">)</tt> </tt> |
| 1850 | <a name="L1686"></a><tt class="py-lineno">1686</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1851 | <a name="L1687"></a><tt class="py-lineno">1687</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 1852 | <a name="L1688"></a><tt class="py-lineno">1688</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-562" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-562', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS is stopped"</tt> <tt class="py-op">)</tt> </tt> |
| 1853 | <a name="L1689"></a><tt class="py-lineno">1689</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-563" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-563', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-564" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-564', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"ONOS service failed to check the status"</tt> <tt class="py-op">)</tt> </tt> |
| 1854 | <a name="L1690"></a><tt class="py-lineno">1690</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.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-565', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1855 | <a name="L1691"></a><tt class="py-lineno">1691</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-566', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1856 | <a name="L1692"></a><tt class="py-lineno">1692</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1857 | <a name="L1693"></a><tt class="py-lineno">1693</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-567" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-567', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-568" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-568', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1858 | <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-569" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-569', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-570" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-570', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1859 | <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-571" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-571', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1860 | <a name="L1696"></a><tt class="py-lineno">1696</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-572', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1861 | <a name="L1697"></a><tt class="py-lineno">1697</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1862 | <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-573" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-573', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1863 | <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-574" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-574', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1864 | <a name="L1700"></a><tt class="py-lineno">1700</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-575" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-575', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1865 | </div><a name="L1701"></a><tt class="py-lineno">1701</tt> <tt class="py-line"> </tt> |
| 1866 | <a name="OnosDriver.setIpTables"></a><div id="OnosDriver.setIpTables-def"><a name="L1702"></a><tt class="py-lineno">1702</tt> <a class="py-toggle" href="#" id="OnosDriver.setIpTables-toggle" onclick="return toggle('OnosDriver.setIpTables');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#setIpTables">setIpTables</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ip</tt><tt class="py-op">,</tt> <tt class="py-param">port</tt><tt class="py-op">=</tt><tt class="py-string">''</tt><tt class="py-op">,</tt> <tt class="py-param">action</tt><tt class="py-op">=</tt><tt class="py-string">'add'</tt><tt class="py-op">,</tt> <tt class="py-param">packet_type</tt><tt class="py-op">=</tt><tt class="py-string">''</tt><tt class="py-op">,</tt> </tt> |
| 1867 | <a name="L1703"></a><tt class="py-lineno">1703</tt> <tt class="py-line"> <tt class="py-param">direction</tt><tt class="py-op">=</tt><tt class="py-string">'INPUT'</tt><tt class="py-op">,</tt> <tt class="py-param">rule</tt><tt class="py-op">=</tt><tt class="py-string">'DROP'</tt><tt class="py-op">,</tt> <tt class="py-param">states</tt><tt class="py-op">=</tt><tt class="py-name">True</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1868 | </div><div id="OnosDriver.setIpTables-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.setIpTables-expanded"><a name="L1704"></a><tt class="py-lineno">1704</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1869 | <a name="L1705"></a><tt class="py-lineno">1705</tt> <tt class="py-line"><tt class="py-docstring"> Description:</tt> </tt> |
| 1870 | <a name="L1706"></a><tt class="py-lineno">1706</tt> <tt class="py-line"><tt class="py-docstring"> add or remove iptables rule to DROP (default) packets from</tt> </tt> |
| 1871 | <a name="L1707"></a><tt class="py-lineno">1707</tt> <tt class="py-line"><tt class="py-docstring"> specific IP and PORT</tt> </tt> |
| 1872 | <a name="L1708"></a><tt class="py-lineno">1708</tt> <tt class="py-line"><tt class="py-docstring"> Usage:</tt> </tt> |
| 1873 | <a name="L1709"></a><tt class="py-lineno">1709</tt> <tt class="py-line"><tt class="py-docstring"> * specify action ('add' or 'remove')</tt> </tt> |
| 1874 | <a name="L1710"></a><tt class="py-lineno">1710</tt> <tt class="py-line"><tt class="py-docstring"> when removing, pass in the same argument as you would add. It will</tt> </tt> |
| 1875 | <a name="L1711"></a><tt class="py-lineno">1711</tt> <tt class="py-line"><tt class="py-docstring"> delete that specific rule.</tt> </tt> |
| 1876 | <a name="L1712"></a><tt class="py-lineno">1712</tt> <tt class="py-line"><tt class="py-docstring"> * specify the ip to block</tt> </tt> |
| 1877 | <a name="L1713"></a><tt class="py-lineno">1713</tt> <tt class="py-line"><tt class="py-docstring"> * specify the destination port to block (defaults to all ports)</tt> </tt> |
| 1878 | <a name="L1714"></a><tt class="py-lineno">1714</tt> <tt class="py-line"><tt class="py-docstring"> * optional packet type to block (default tcp)</tt> </tt> |
| 1879 | <a name="L1715"></a><tt class="py-lineno">1715</tt> <tt class="py-line"><tt class="py-docstring"> * optional iptables rule (default DROP)</tt> </tt> |
| 1880 | <a name="L1716"></a><tt class="py-lineno">1716</tt> <tt class="py-line"><tt class="py-docstring"> * optional direction to block (default 'INPUT')</tt> </tt> |
| 1881 | <a name="L1717"></a><tt class="py-lineno">1717</tt> <tt class="py-line"><tt class="py-docstring"> * States boolean toggles adding all supported tcp states to the</tt> </tt> |
| 1882 | <a name="L1718"></a><tt class="py-lineno">1718</tt> <tt class="py-line"><tt class="py-docstring"> firewall rule</tt> </tt> |
| 1883 | <a name="L1719"></a><tt class="py-lineno">1719</tt> <tt class="py-line"><tt class="py-docstring"> Returns:</tt> </tt> |
| 1884 | <a name="L1720"></a><tt class="py-lineno">1720</tt> <tt class="py-line"><tt class="py-docstring"> main.TRUE on success or</tt> </tt> |
| 1885 | <a name="L1721"></a><tt class="py-lineno">1721</tt> <tt class="py-line"><tt class="py-docstring"> main.FALSE if given invalid input or</tt> </tt> |
| 1886 | <a name="L1722"></a><tt class="py-lineno">1722</tt> <tt class="py-line"><tt class="py-docstring"> main.ERROR if there is an error in response from iptables</tt> </tt> |
| 1887 | <a name="L1723"></a><tt class="py-lineno">1723</tt> <tt class="py-line"><tt class="py-docstring"> WARNING:</tt> </tt> |
| 1888 | <a name="L1724"></a><tt class="py-lineno">1724</tt> <tt class="py-line"><tt class="py-docstring"> * This function uses root privilege iptables command which may result</tt> </tt> |
| 1889 | <a name="L1725"></a><tt class="py-lineno">1725</tt> <tt class="py-line"><tt class="py-docstring"> in unwanted network errors. USE WITH CAUTION</tt> </tt> |
| 1890 | <a name="L1726"></a><tt class="py-lineno">1726</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1891 | <a name="L1727"></a><tt class="py-lineno">1727</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">time</tt> </tt> |
| 1892 | <a name="L1728"></a><tt class="py-lineno">1728</tt> <tt class="py-line"> </tt> |
| 1893 | <a name="L1729"></a><tt class="py-lineno">1729</tt> <tt class="py-line"> <tt class="py-comment"># NOTE*********</tt> </tt> |
| 1894 | <a name="L1730"></a><tt class="py-lineno">1730</tt> <tt class="py-line"> <tt class="py-comment"># The strict checking methods of this driver function is intentional</tt> </tt> |
| 1895 | <a name="L1731"></a><tt class="py-lineno">1731</tt> <tt class="py-line"> <tt class="py-comment"># to discourage any misuse or error of iptables, which can cause</tt> </tt> |
| 1896 | <a name="L1732"></a><tt class="py-lineno">1732</tt> <tt class="py-line"> <tt class="py-comment"># severe network errors</tt> </tt> |
| 1897 | <a name="L1733"></a><tt class="py-lineno">1733</tt> <tt class="py-line"> <tt class="py-comment"># *************</tt> </tt> |
| 1898 | <a name="L1734"></a><tt class="py-lineno">1734</tt> <tt class="py-line"> </tt> |
| 1899 | <a name="L1735"></a><tt class="py-lineno">1735</tt> <tt class="py-line"> <tt class="py-comment"># NOTE: Sleep needed to give some time for rule to be added and</tt> </tt> |
| 1900 | <a name="L1736"></a><tt class="py-lineno">1736</tt> <tt class="py-line"> <tt class="py-comment"># registered to the instance. If you are calling this function</tt> </tt> |
| 1901 | <a name="L1737"></a><tt class="py-lineno">1737</tt> <tt class="py-line"> <tt class="py-comment"># multiple times this sleep will prevent any errors.</tt> </tt> |
| 1902 | <a name="L1738"></a><tt class="py-lineno">1738</tt> <tt class="py-line"> <tt class="py-comment"># DO NOT REMOVE</tt> </tt> |
| 1903 | <a name="L1739"></a><tt class="py-lineno">1739</tt> <tt class="py-line"> <tt class="py-comment"># time.sleep( 5 )</tt> </tt> |
| 1904 | <a name="L1740"></a><tt class="py-lineno">1740</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1905 | <a name="L1741"></a><tt class="py-lineno">1741</tt> <tt class="py-line"> <tt class="py-comment"># input validation</tt> </tt> |
| 1906 | <a name="L1742"></a><tt class="py-lineno">1742</tt> <tt class="py-line"> <tt class="py-name">action_type</tt> <tt class="py-op">=</tt> <tt class="py-name">action</tt><tt class="py-op">.</tt><tt class="py-name">lower</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1907 | <a name="L1743"></a><tt class="py-lineno">1743</tt> <tt class="py-line"> <tt class="py-name">rule</tt> <tt class="py-op">=</tt> <tt class="py-name">rule</tt><tt class="py-op">.</tt><tt class="py-name">upper</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1908 | <a name="L1744"></a><tt class="py-lineno">1744</tt> <tt class="py-line"> <tt class="py-name">direction</tt> <tt class="py-op">=</tt> <tt class="py-name">direction</tt><tt class="py-op">.</tt><tt class="py-name">upper</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1909 | <a name="L1745"></a><tt class="py-lineno">1745</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">action_type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'add'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">action_type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'remove'</tt><tt class="py-op">:</tt> </tt> |
| 1910 | <a name="L1746"></a><tt class="py-lineno">1746</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-576" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-576', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-577" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-577', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Invalid action type. Use 'add' or "</tt> </tt> |
| 1911 | <a name="L1747"></a><tt class="py-lineno">1747</tt> <tt class="py-line"> <tt class="py-string">"'remove' table rule"</tt> <tt class="py-op">)</tt> </tt> |
| 1912 | <a name="L1748"></a><tt class="py-lineno">1748</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">rule</tt> <tt class="py-op">!=</tt> <tt class="py-string">'DROP'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">rule</tt> <tt class="py-op">!=</tt> <tt class="py-string">'ACCEPT'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">rule</tt> <tt class="py-op">!=</tt> <tt class="py-string">'LOG'</tt><tt class="py-op">:</tt> </tt> |
| 1913 | <a name="L1749"></a><tt class="py-lineno">1749</tt> <tt class="py-line"> <tt class="py-comment"># NOTE Currently only supports rules DROP, ACCEPT, and LOG</tt> </tt> |
| 1914 | <a name="L1750"></a><tt class="py-lineno">1750</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-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-579" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-579', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Invalid rule. Valid rules are 'DROP' or "</tt> </tt> |
| 1915 | <a name="L1751"></a><tt class="py-lineno">1751</tt> <tt class="py-line"> <tt class="py-string">"'ACCEPT' or 'LOG' only."</tt> <tt class="py-op">)</tt> </tt> |
| 1916 | <a name="L1752"></a><tt class="py-lineno">1752</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">direction</tt> <tt class="py-op">!=</tt> <tt class="py-string">'INPUT'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">direction</tt> <tt class="py-op">!=</tt> <tt class="py-string">'OUTPUT'</tt><tt class="py-op">:</tt> </tt> |
| 1917 | <a name="L1753"></a><tt class="py-lineno">1753</tt> <tt class="py-line"> <tt class="py-comment"># NOTE currently only supports rules INPUT and OUPTUT</tt> </tt> |
| 1918 | <a name="L1754"></a><tt class="py-lineno">1754</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-580" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-580', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-581" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-581', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Invalid rule. Valid directions are"</tt> </tt> |
| 1919 | <a name="L1755"></a><tt class="py-lineno">1755</tt> <tt class="py-line"> <tt class="py-string">" 'OUTPUT' or 'INPUT'"</tt> <tt class="py-op">)</tt> </tt> |
| 1920 | <a name="L1756"></a><tt class="py-lineno">1756</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1921 | <a name="L1757"></a><tt class="py-lineno">1757</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1922 | <a name="L1758"></a><tt class="py-lineno">1758</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 1923 | <a name="L1759"></a><tt class="py-lineno">1759</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">action_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'add'</tt><tt class="py-op">:</tt> </tt> |
| 1924 | <a name="L1760"></a><tt class="py-lineno">1760</tt> <tt class="py-line"> <tt class="py-comment"># -A is the 'append' action of iptables</tt> </tt> |
| 1925 | <a name="L1761"></a><tt class="py-lineno">1761</tt> <tt class="py-line"> <tt class="py-name">actionFlag</tt> <tt class="py-op">=</tt> <tt class="py-string">'-A'</tt> </tt> |
| 1926 | <a name="L1762"></a><tt class="py-lineno">1762</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">action_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'remove'</tt><tt class="py-op">:</tt> </tt> |
| 1927 | <a name="L1763"></a><tt class="py-lineno">1763</tt> <tt class="py-line"> <tt class="py-comment"># -D is the 'delete' rule of iptables</tt> </tt> |
| 1928 | <a name="L1764"></a><tt class="py-lineno">1764</tt> <tt class="py-line"> <tt class="py-name">actionFlag</tt> <tt class="py-op">=</tt> <tt class="py-string">'-D'</tt> </tt> |
| 1929 | <a name="L1765"></a><tt class="py-lineno">1765</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-582" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-582', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1930 | <a name="L1766"></a><tt class="py-lineno">1766</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1931 | <a name="L1767"></a><tt class="py-lineno">1767</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"sudo iptables "</tt> <tt class="py-op">+</tt> <tt class="py-name">actionFlag</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt>\ </tt> |
| 1932 | <a name="L1768"></a><tt class="py-lineno">1768</tt> <tt class="py-line"> <tt class="py-name">direction</tt> <tt class="py-op">+</tt>\ </tt> |
| 1933 | <a name="L1769"></a><tt class="py-lineno">1769</tt> <tt class="py-line"> <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">ip</tt> <tt class="py-op">)</tt> </tt> |
| 1934 | <a name="L1770"></a><tt class="py-lineno">1770</tt> <tt class="py-line"> <tt class="py-comment"># " -p " + str( packet_type ) +\</tt> </tt> |
| 1935 | <a name="L1771"></a><tt class="py-lineno">1771</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">packet_type</tt><tt class="py-op">:</tt> </tt> |
| 1936 | <a name="L1772"></a><tt class="py-lineno">1772</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">" -p "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">packet_type</tt> <tt class="py-op">)</tt> </tt> |
| 1937 | <a name="L1773"></a><tt class="py-lineno">1773</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">port</tt><tt class="py-op">:</tt> </tt> |
| 1938 | <a name="L1774"></a><tt class="py-lineno">1774</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">" --dport "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">port</tt> <tt class="py-op">)</tt> </tt> |
| 1939 | <a name="L1775"></a><tt class="py-lineno">1775</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">states</tt><tt class="py-op">:</tt> </tt> |
| 1940 | <a name="L1776"></a><tt class="py-lineno">1776</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">" -m state --state="</tt> </tt> |
| 1941 | <a name="L1777"></a><tt class="py-lineno">1777</tt> <tt class="py-line"> <tt class="py-comment">#FIXME- Allow user to configure which states to block</tt> </tt> |
| 1942 | <a name="L1778"></a><tt class="py-lineno">1778</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">"INVALID,ESTABLISHED,NEW,RELATED,UNTRACKED"</tt> </tt> |
| 1943 | <a name="L1779"></a><tt class="py-lineno">1779</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">+=</tt> <tt class="py-string">" -j "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">rule</tt> <tt class="py-op">)</tt> </tt> |
| 1944 | <a name="L1780"></a><tt class="py-lineno">1780</tt> <tt class="py-line"> </tt> |
| 1945 | <a name="L1781"></a><tt class="py-lineno">1781</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-583" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-583', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 1946 | <a name="L1782"></a><tt class="py-lineno">1782</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1947 | <a name="L1783"></a><tt class="py-lineno">1783</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1948 | <a name="L1784"></a><tt class="py-lineno">1784</tt> <tt class="py-line"> </tt> |
| 1949 | <a name="L1785"></a><tt class="py-lineno">1785</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">=</tt> <tt class="py-string">"On "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">)</tt> </tt> |
| 1950 | <a name="L1786"></a><tt class="py-lineno">1786</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">+=</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">action_type</tt> <tt class="py-op">)</tt> </tt> |
| 1951 | <a name="L1787"></a><tt class="py-lineno">1787</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">+=</tt> <tt class="py-string">" iptable rule [ "</tt> </tt> |
| 1952 | <a name="L1788"></a><tt class="py-lineno">1788</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">+=</tt> <tt class="py-string">" IP: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">ip</tt> <tt class="py-op">)</tt> </tt> |
| 1953 | <a name="L1789"></a><tt class="py-lineno">1789</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">+=</tt> <tt class="py-string">" Port: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">port</tt> <tt class="py-op">)</tt> </tt> |
| 1954 | <a name="L1790"></a><tt class="py-lineno">1790</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">+=</tt> <tt class="py-string">" Rule: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">rule</tt> <tt class="py-op">)</tt> </tt> |
| 1955 | <a name="L1791"></a><tt class="py-lineno">1791</tt> <tt class="py-line"> <tt class="py-name">info_string</tt> <tt class="py-op">+=</tt> <tt class="py-string">" Direction: "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">direction</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">" ]"</tt> </tt> |
| 1956 | <a name="L1792"></a><tt class="py-lineno">1792</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-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">info_string</tt> <tt class="py-op">)</tt> </tt> |
| 1957 | <a name="L1793"></a><tt class="py-lineno">1793</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 1958 | <a name="L1794"></a><tt class="py-lineno">1794</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">:</tt> </tt> |
| 1959 | <a name="L1795"></a><tt class="py-lineno">1795</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.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-586', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Timeout exception in "</tt> </tt> |
| 1960 | <a name="L1796"></a><tt class="py-lineno">1796</tt> <tt class="py-line"> <tt class="py-string">"setIpTables function"</tt> <tt class="py-op">)</tt> </tt> |
| 1961 | <a name="L1797"></a><tt class="py-lineno">1797</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">ERROR</tt> </tt> |
| 1962 | <a name="L1798"></a><tt class="py-lineno">1798</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 1963 | <a name="L1799"></a><tt class="py-lineno">1799</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-587" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-587', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-588" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-588', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 1964 | <a name="L1800"></a><tt class="py-lineno">1800</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-589" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-589', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-590" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-590', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 1965 | <a name="L1801"></a><tt class="py-lineno">1801</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-591" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-591', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1966 | <a name="L1802"></a><tt class="py-lineno">1802</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.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-592', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1967 | <a name="L1803"></a><tt class="py-lineno">1803</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 1968 | <a name="L1804"></a><tt class="py-lineno">1804</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-593" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-593', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 1969 | <a name="L1805"></a><tt class="py-lineno">1805</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-594" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-594', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1970 | <a name="L1806"></a><tt class="py-lineno">1806</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-595" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-595', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 1971 | </div><a name="L1807"></a><tt class="py-lineno">1807</tt> <tt class="py-line"> </tt> |
| 1972 | <a name="OnosDriver.detailed_status"></a><div id="OnosDriver.detailed_status-def"><a name="L1808"></a><tt class="py-lineno">1808</tt> <a class="py-toggle" href="#" id="OnosDriver.detailed_status-toggle" onclick="return toggle('OnosDriver.detailed_status');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#detailed_status">detailed_status</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">log_filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1973 | </div><div id="OnosDriver.detailed_status-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.detailed_status-expanded"><a name="L1809"></a><tt class="py-lineno">1809</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 1974 | <a name="L1810"></a><tt class="py-lineno">1810</tt> <tt class="py-line"><tt class="py-docstring"> This method is used by STS to check the status of the controller</tt> </tt> |
| 1975 | <a name="L1811"></a><tt class="py-lineno">1811</tt> <tt class="py-line"><tt class="py-docstring"> Reports RUNNING, STARTING, STOPPED, FROZEN, ERROR (and reason)</tt> </tt> |
| 1976 | <a name="L1812"></a><tt class="py-lineno">1812</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 1977 | <a name="L1813"></a><tt class="py-lineno">1813</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt> |
| 1978 | <a name="L1814"></a><tt class="py-lineno">1814</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 1979 | <a name="L1815"></a><tt class="py-lineno">1815</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-596" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-596', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 1980 | <a name="L1816"></a><tt class="py-lineno">1816</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1981 | <a name="L1817"></a><tt class="py-lineno">1817</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-597" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-597', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"cd "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">)</tt> </tt> |
| 1982 | <a name="L1818"></a><tt class="py-lineno">1818</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1983 | <a name="L1819"></a><tt class="py-lineno">1819</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-598" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-598', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">"service onos status"</tt> <tt class="py-op">)</tt> </tt> |
| 1984 | <a name="L1820"></a><tt class="py-lineno">1820</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 1985 | <a name="L1821"></a><tt class="py-lineno">1821</tt> <tt class="py-line"> <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 1986 | <a name="L1822"></a><tt class="py-lineno">1822</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">"onos start/running"</tt><tt class="py-op">,</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1987 | <a name="L1823"></a><tt class="py-lineno">1823</tt> <tt class="py-line"> <tt class="py-comment"># onos start/running, process 10457</tt> </tt> |
| 1988 | <a name="L1824"></a><tt class="py-lineno">1824</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'RUNNING'</tt> </tt> |
| 1989 | <a name="L1825"></a><tt class="py-lineno">1825</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: Implement this case</tt> </tt> |
| 1990 | <a name="L1826"></a><tt class="py-lineno">1826</tt> <tt class="py-line"> <tt class="py-comment"># elif re.search( pattern, response ):</tt> </tt> |
| 1991 | <a name="L1827"></a><tt class="py-lineno">1827</tt> <tt class="py-line"> <tt class="py-comment"># return 'STARTING'</tt> </tt> |
| 1992 | <a name="L1828"></a><tt class="py-lineno">1828</tt> <tt class="py-line"> <tt class="py-keyword">elif</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">"onos stop/"</tt><tt class="py-op">,</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 1993 | <a name="L1829"></a><tt class="py-lineno">1829</tt> <tt class="py-line"> <tt class="py-comment"># onos stop/waiting</tt> </tt> |
| 1994 | <a name="L1830"></a><tt class="py-lineno">1830</tt> <tt class="py-line"> <tt class="py-comment"># FIXME handle this differently?: onos stop/pre-stop</tt> </tt> |
| 1995 | <a name="L1831"></a><tt class="py-lineno">1831</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'STOPPED'</tt> </tt> |
| 1996 | <a name="L1832"></a><tt class="py-lineno">1832</tt> <tt class="py-line"> <tt class="py-comment"># FIXME: Implement this case</tt> </tt> |
| 1997 | <a name="L1833"></a><tt class="py-lineno">1833</tt> <tt class="py-line"> <tt class="py-comment"># elif re.search( pattern, response ):</tt> </tt> |
| 1998 | <a name="L1834"></a><tt class="py-lineno">1834</tt> <tt class="py-line"> <tt class="py-comment"># return 'FROZEN'</tt> </tt> |
| 1999 | <a name="L1835"></a><tt class="py-lineno">1835</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 2000 | <a name="L1836"></a><tt class="py-lineno">1836</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-599" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-599', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> </tt> |
| 2001 | <a name="L1837"></a><tt class="py-lineno">1837</tt> <tt class="py-line"> <tt class="py-string">" WARNING: status received unknown response"</tt> <tt class="py-op">)</tt> </tt> |
| 2002 | <a name="L1838"></a><tt class="py-lineno">1838</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-600" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-600', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">warn</tt><tt class="py-op">(</tt> <tt class="py-name">response</tt> <tt class="py-op">)</tt> </tt> |
| 2003 | <a name="L1839"></a><tt class="py-lineno">1839</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'ERROR'</tt><tt class="py-op">,</tt> <tt class="py-string">"Unknown response: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">response</tt> </tt> |
| 2004 | <a name="L1840"></a><tt class="py-lineno">1840</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">:</tt> </tt> |
| 2005 | <a name="L1841"></a><tt class="py-lineno">1841</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-601" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-601', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Timeout exception in "</tt> </tt> |
| 2006 | <a name="L1842"></a><tt class="py-lineno">1842</tt> <tt class="py-line"> <tt class="py-string">"setIpTables function"</tt> <tt class="py-op">)</tt> </tt> |
| 2007 | <a name="L1843"></a><tt class="py-lineno">1843</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'ERROR'</tt><tt class="py-op">,</tt> <tt class="py-string">"Pexpect Timeout"</tt> </tt> |
| 2008 | <a name="L1844"></a><tt class="py-lineno">1844</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 2009 | <a name="L1845"></a><tt class="py-lineno">1845</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-602" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-602', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-603" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-603', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 2010 | <a name="L1846"></a><tt class="py-lineno">1846</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-604" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-604', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-605" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-605', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 2011 | <a name="L1847"></a><tt class="py-lineno">1847</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-606" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-606', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2012 | <a name="L1848"></a><tt class="py-lineno">1848</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-607" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-607', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2013 | <a name="L1849"></a><tt class="py-lineno">1849</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 2014 | <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 id="link-608" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-608', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 2015 | <a name="L1851"></a><tt class="py-lineno">1851</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-609" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-609', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2016 | <a name="L1852"></a><tt class="py-lineno">1852</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-610" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-610', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2017 | </div><a name="L1853"></a><tt class="py-lineno">1853</tt> <tt class="py-line"> </tt> |
| 2018 | <a name="OnosDriver.createLinkGraphFile"></a><div id="OnosDriver.createLinkGraphFile-def"><a name="L1854"></a><tt class="py-lineno">1854</tt> <a class="py-toggle" href="#" id="OnosDriver.createLinkGraphFile-toggle" onclick="return toggle('OnosDriver.createLinkGraphFile');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#createLinkGraphFile">createLinkGraphFile</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">benchIp</tt><tt class="py-op">,</tt> <tt class="py-param">ONOSIpList</tt><tt class="py-op">,</tt> <tt class="py-param">deviceCount</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2019 | </div><div id="OnosDriver.createLinkGraphFile-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.createLinkGraphFile-expanded"><a name="L1855"></a><tt class="py-lineno">1855</tt> <tt class="py-line"> <tt class="py-docstring">'''</tt> </tt> |
| 2020 | <a name="L1856"></a><tt class="py-lineno">1856</tt> <tt class="py-line"><tt class="py-docstring"> Create/formats the LinkGraph.cfg file based on arguments</tt> </tt> |
| 2021 | <a name="L1857"></a><tt class="py-lineno">1857</tt> <tt class="py-line"><tt class="py-docstring"> -only creates a linear topology and connects islands</tt> </tt> |
| 2022 | <a name="L1858"></a><tt class="py-lineno">1858</tt> <tt class="py-line"><tt class="py-docstring"> -evenly distributes devices</tt> </tt> |
| 2023 | <a name="L1859"></a><tt class="py-lineno">1859</tt> <tt class="py-line"><tt class="py-docstring"> -must be called by ONOSbench</tt> </tt> |
| 2024 | <a name="L1860"></a><tt class="py-lineno">1860</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 2025 | <a name="L1861"></a><tt class="py-lineno">1861</tt> <tt class="py-line"><tt class="py-docstring"> ONOSIpList - list of all of the node IPs to be used</tt> </tt> |
| 2026 | <a name="L1862"></a><tt class="py-lineno">1862</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 2027 | <a name="L1863"></a><tt class="py-lineno">1863</tt> <tt class="py-line"><tt class="py-docstring"> deviceCount - number of switches to be assigned</tt> </tt> |
| 2028 | <a name="L1864"></a><tt class="py-lineno">1864</tt> <tt class="py-line"><tt class="py-docstring"> '''</tt> </tt> |
| 2029 | <a name="L1865"></a><tt class="py-lineno">1865</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-611" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-611', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-612" 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-612', 'step', 'link-612');">step</a></tt><tt class="py-op">(</tt><tt class="py-string">"Creating link graph configuration file."</tt> <tt class="py-op">)</tt> </tt> |
| 2030 | <a name="L1866"></a><tt class="py-lineno">1866</tt> <tt class="py-line"> <tt class="py-name">linkGraphPath</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">home</tt> <tt class="py-op">+</tt> <tt class="py-string">"/tools/package/etc/linkGraph.cfg"</tt> </tt> |
| 2031 | <a name="L1867"></a><tt class="py-lineno">1867</tt> <tt class="py-line"> <tt class="py-name">tempFile</tt> <tt class="py-op">=</tt> <tt class="py-string">"/tmp/linkGraph.cfg"</tt> </tt> |
| 2032 | <a name="L1868"></a><tt class="py-lineno">1868</tt> <tt class="py-line"> </tt> |
| 2033 | <a name="L1869"></a><tt class="py-lineno">1869</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">tempFile</tt><tt class="py-op">,</tt> <tt class="py-string">'w+'</tt><tt class="py-op">)</tt> </tt> |
| 2034 | <a name="L1870"></a><tt class="py-lineno">1870</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"# NullLinkProvider topology description (config file).\n"</tt><tt class="py-op">)</tt> </tt> |
| 2035 | <a name="L1871"></a><tt class="py-lineno">1871</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"# The NodeId is only added if the destination is another node's device.\n"</tt><tt class="py-op">)</tt> </tt> |
| 2036 | <a name="L1872"></a><tt class="py-lineno">1872</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"# Bugs: Comments cannot be appended to a line to be read.\n"</tt><tt class="py-op">)</tt> </tt> |
| 2037 | <a name="L1873"></a><tt class="py-lineno">1873</tt> <tt class="py-line"> </tt> |
| 2038 | <a name="L1874"></a><tt class="py-lineno">1874</tt> <tt class="py-line"> <tt class="py-name">clusterCount</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIpList</tt><tt class="py-op">)</tt> </tt> |
| 2039 | <a name="L1875"></a><tt class="py-lineno">1875</tt> <tt class="py-line"> </tt> |
| 2040 | <a name="L1876"></a><tt class="py-lineno">1876</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">int</tt> <tt class="py-keyword">or</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">str</tt><tt class="py-op">:</tt> </tt> |
| 2041 | <a name="L1877"></a><tt class="py-lineno">1877</tt> <tt class="py-line"> <tt class="py-name">deviceCount</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> </tt> |
| 2042 | <a name="L1878"></a><tt class="py-lineno">1878</tt> <tt class="py-line"> <tt class="py-name">switchList</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">clusterCount</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> |
| 2043 | <a name="L1879"></a><tt class="py-lineno">1879</tt> <tt class="py-line"> <tt class="py-name">baselineSwitchCount</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceCount</tt><tt class="py-op">/</tt><tt class="py-name">clusterCount</tt> </tt> |
| 2044 | <a name="L1880"></a><tt class="py-lineno">1880</tt> <tt class="py-line"> </tt> |
| 2045 | <a name="L1881"></a><tt class="py-lineno">1881</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">clusterCount</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2046 | <a name="L1882"></a><tt class="py-lineno">1882</tt> <tt class="py-line"> <tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">baselineSwitchCount</tt> </tt> |
| 2047 | <a name="L1883"></a><tt class="py-lineno">1883</tt> <tt class="py-line"> </tt> |
| 2048 | <a name="L1884"></a><tt class="py-lineno">1884</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">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">deviceCount</tt><tt class="py-op">%</tt><tt class="py-name">clusterCount</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> |
| 2049 | <a name="L1885"></a><tt class="py-lineno">1885</tt> <tt class="py-line"> <tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> |
| 2050 | <a name="L1886"></a><tt class="py-lineno">1886</tt> <tt class="py-line"> </tt> |
| 2051 | <a name="L1887"></a><tt class="py-lineno">1887</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">list</tt><tt class="py-op">:</tt> </tt> |
| 2052 | <a name="L1888"></a><tt class="py-lineno">1888</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-613" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-613', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Using provided device distribution"</tt><tt class="py-op">)</tt> </tt> |
| 2053 | <a name="L1889"></a><tt class="py-lineno">1889</tt> <tt class="py-line"> <tt class="py-name">switchList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt> |
| 2054 | <a name="L1890"></a><tt class="py-lineno">1890</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">deviceCount</tt><tt class="py-op">:</tt> </tt> |
| 2055 | <a name="L1891"></a><tt class="py-lineno">1891</tt> <tt class="py-line"> <tt class="py-name">switchList</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> |
| 2056 | <a name="L1892"></a><tt class="py-lineno">1892</tt> <tt class="py-line"> </tt> |
| 2057 | <a name="L1893"></a><tt class="py-lineno">1893</tt> <tt class="py-line"> <tt class="py-name">tempList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'0'</tt><tt class="py-op">]</tt> </tt> |
| 2058 | <a name="L1894"></a><tt class="py-lineno">1894</tt> <tt class="py-line"> <tt class="py-name">tempList</tt><tt class="py-op">.</tt><tt class="py-name">extend</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIpList</tt><tt class="py-op">)</tt> </tt> |
| 2059 | <a name="L1895"></a><tt class="py-lineno">1895</tt> <tt class="py-line"> <tt class="py-name">ONOSIpList</tt> <tt class="py-op">=</tt> <tt class="py-name">tempList</tt> </tt> |
| 2060 | <a name="L1896"></a><tt class="py-lineno">1896</tt> <tt class="py-line"> </tt> |
| 2061 | <a name="L1897"></a><tt class="py-lineno">1897</tt> <tt class="py-line"> <tt class="py-name">myPort</tt> <tt class="py-op">=</tt> <tt class="py-number">6</tt> </tt> |
| 2062 | <a name="L1898"></a><tt class="py-lineno">1898</tt> <tt class="py-line"> <tt class="py-name">lastSwitch</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> |
| 2063 | <a name="L1899"></a><tt class="py-lineno">1899</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">clusterCount</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2064 | <a name="L1900"></a><tt class="py-lineno">1900</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 2065 | <a name="L1901"></a><tt class="py-lineno">1901</tt> <tt class="py-line"> <tt class="py-keyword">continue</tt> </tt> |
| 2066 | <a name="L1902"></a><tt class="py-lineno">1902</tt> <tt class="py-line"> </tt> |
| 2067 | <a name="L1903"></a><tt class="py-lineno">1903</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"graph "</tt> <tt class="py-op">+</tt> <tt class="py-name">ONOSIpList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">" {\n"</tt><tt class="py-op">)</tt> </tt> |
| 2068 | <a name="L1904"></a><tt class="py-lineno">1904</tt> <tt class="py-line"> </tt> |
| 2069 | <a name="L1905"></a><tt class="py-lineno">1905</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">node</tt> <tt class="py-op">></tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 2070 | <a name="L1906"></a><tt class="py-lineno">1906</tt> <tt class="py-line"> <tt class="py-comment">#connect to last device on previous node</tt> </tt> |
| 2071 | <a name="L1907"></a><tt class="py-lineno">1907</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"\t0:5 -> "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">lastSwitch</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">":6:"</tt> <tt class="py-op">+</tt> <tt class="py-name">lastIp</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt><tt class="py-op">)</tt> <tt class="py-comment">#ONOSIpList[node-1]</tt> </tt> |
| 2072 | <a name="L1908"></a><tt class="py-lineno">1908</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt> </tt> |
| 2073 | <a name="L1909"></a><tt class="py-lineno">1909</tt> <tt class="py-line"> </tt> |
| 2074 | <a name="L1910"></a><tt class="py-lineno">1910</tt> <tt class="py-line"> <tt class="py-name">lastSwitch</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> |
| 2075 | <a name="L1911"></a><tt class="py-lineno">1911</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">range</tt> <tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</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> |
| 2076 | <a name="L1912"></a><tt class="py-lineno">1912</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt> </tt> |
| 2077 | <a name="L1913"></a><tt class="py-lineno">1913</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"\t"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">switch</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">myPort</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> |
| 2078 | <a name="L1914"></a><tt class="py-lineno">1914</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">+=</tt> <tt class="py-string">" -- "</tt> </tt> |
| 2079 | <a name="L1915"></a><tt class="py-lineno">1915</tt> <tt class="py-line"> <tt class="py-name">line</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">switch</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">myPort</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt><tt class="py-op">)</tt> </tt> |
| 2080 | <a name="L1916"></a><tt class="py-lineno">1916</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt> </tt> |
| 2081 | <a name="L1917"></a><tt class="py-lineno">1917</tt> <tt class="py-line"> <tt class="py-name">lastSwitch</tt> <tt class="py-op">=</tt> <tt class="py-name">switch</tt><tt class="py-op">+</tt><tt class="py-number">1</tt> </tt> |
| 2082 | <a name="L1918"></a><tt class="py-lineno">1918</tt> <tt class="py-line"> <tt class="py-name">lastIp</tt> <tt class="py-op">=</tt> <tt class="py-name">ONOSIpList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> </tt> |
| 2083 | <a name="L1919"></a><tt class="py-lineno">1919</tt> <tt class="py-line"> </tt> |
| 2084 | <a name="L1920"></a><tt class="py-lineno">1920</tt> <tt class="py-line"> <tt class="py-comment">#lastSwitch += 1</tt> </tt> |
| 2085 | <a name="L1921"></a><tt class="py-lineno">1921</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">node</tt> <tt class="py-op"><</tt> <tt class="py-op">(</tt><tt class="py-name">clusterCount</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2086 | <a name="L1922"></a><tt class="py-lineno">1922</tt> <tt class="py-line"> <tt class="py-comment">#connect to first device on the next node</tt> </tt> |
| 2087 | <a name="L1923"></a><tt class="py-lineno">1923</tt> <tt class="py-line"> <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"\t"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">lastSwitch</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">":6 -> 0:5:"</tt> <tt class="py-op">+</tt> <tt class="py-name">ONOSIpList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt><tt class="py-op">)</tt> </tt> |
| 2088 | <a name="L1924"></a><tt class="py-lineno">1924</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt> </tt> |
| 2089 | <a name="L1925"></a><tt class="py-lineno">1925</tt> <tt class="py-line"> </tt> |
| 2090 | <a name="L1926"></a><tt class="py-lineno">1926</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"}\n"</tt><tt class="py-op">)</tt> </tt> |
| 2091 | <a name="L1927"></a><tt class="py-lineno">1927</tt> <tt class="py-line"> <tt class="py-name">linkGraph</tt><tt class="py-op">.</tt><tt class="py-name">close</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2092 | <a name="L1928"></a><tt class="py-lineno">1928</tt> <tt class="py-line"> </tt> |
| 2093 | <a name="L1929"></a><tt class="py-lineno">1929</tt> <tt class="py-line"> <tt class="py-comment">#SCP</tt> </tt> |
| 2094 | <a name="L1930"></a><tt class="py-lineno">1930</tt> <tt class="py-line"> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">system</tt><tt class="py-op">(</tt> <tt class="py-string">"scp "</tt> <tt class="py-op">+</tt> <tt class="py-name">tempFile</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">user_name</tt> <tt class="py-op">+</tt> <tt class="py-string">"@"</tt> <tt class="py-op">+</tt> <tt class="py-name">benchIp</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">linkGraphPath</tt><tt class="py-op">)</tt> </tt> |
| 2095 | <a name="L1931"></a><tt class="py-lineno">1931</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-614" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-614', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"linkGraph.cfg creation complete"</tt><tt class="py-op">)</tt> </tt> |
| 2096 | </div><a name="L1932"></a><tt class="py-lineno">1932</tt> <tt class="py-line"> </tt> |
| 2097 | <a name="OnosDriver.configNullDev"></a><div id="OnosDriver.configNullDev-def"><a name="L1933"></a><tt class="py-lineno">1933</tt> <a class="py-toggle" href="#" id="OnosDriver.configNullDev-toggle" onclick="return toggle('OnosDriver.configNullDev');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#configNullDev">configNullDev</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ONOSIpList</tt><tt class="py-op">,</tt> <tt class="py-param">deviceCount</tt><tt class="py-op">,</tt> <tt class="py-param">numPorts</tt><tt class="py-op">=</tt><tt class="py-number">10</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2098 | </div><div id="OnosDriver.configNullDev-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.configNullDev-expanded"><a name="L1934"></a><tt class="py-lineno">1934</tt> <tt class="py-line"> </tt> |
| 2099 | <a name="L1935"></a><tt class="py-lineno">1935</tt> <tt class="py-line"> <tt class="py-docstring">'''</tt> </tt> |
| 2100 | <a name="L1936"></a><tt class="py-lineno">1936</tt> <tt class="py-line"><tt class="py-docstring"> ONOSIpList = list of Ip addresses of nodes switches will be devided amongst</tt> </tt> |
| 2101 | <a name="L1937"></a><tt class="py-lineno">1937</tt> <tt class="py-line"><tt class="py-docstring"> deviceCount = number of switches to distribute, or list of values to use as custom distribution</tt> </tt> |
| 2102 | <a name="L1938"></a><tt class="py-lineno">1938</tt> <tt class="py-line"><tt class="py-docstring"> numPorts = number of ports per device. Defaults to 10 both in this function and in ONOS. Optional arg</tt> </tt> |
| 2103 | <a name="L1939"></a><tt class="py-lineno">1939</tt> <tt class="py-line"><tt class="py-docstring"> '''</tt> </tt> |
| 2104 | <a name="L1940"></a><tt class="py-lineno">1940</tt> <tt class="py-line"> </tt> |
| 2105 | <a name="L1941"></a><tt class="py-lineno">1941</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-615" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-615', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-616" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-616', 'step', 'link-612');">step</a></tt><tt class="py-op">(</tt><tt class="py-string">"Configuring Null Device Provider"</tt> <tt class="py-op">)</tt> </tt> |
| 2106 | <a name="L1942"></a><tt class="py-lineno">1942</tt> <tt class="py-line"> <tt class="py-name">clusterCount</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIpList</tt><tt class="py-op">)</tt> </tt> |
| 2107 | <a name="L1943"></a><tt class="py-lineno">1943</tt> <tt class="py-line"> </tt> |
| 2108 | <a name="L1944"></a><tt class="py-lineno">1944</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 2109 | <a name="L1945"></a><tt class="py-lineno">1945</tt> <tt class="py-line"> </tt> |
| 2110 | <a name="L1946"></a><tt class="py-lineno">1946</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">int</tt> <tt class="py-keyword">or</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">str</tt><tt class="py-op">:</tt> </tt> |
| 2111 | <a name="L1947"></a><tt class="py-lineno">1947</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-617" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-617', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-618" class="py-name"><a title="TestON.core.teston.TestON.step" class="py-name" href="#" onclick="return doclink('link-618', 'step', 'link-612');">step</a></tt><tt class="py-op">(</tt><tt class="py-string">"Creating device distribution"</tt><tt class="py-op">)</tt> </tt> |
| 2112 | <a name="L1948"></a><tt class="py-lineno">1948</tt> <tt class="py-line"> <tt class="py-name">deviceCount</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> </tt> |
| 2113 | <a name="L1949"></a><tt class="py-lineno">1949</tt> <tt class="py-line"> <tt class="py-name">switchList</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">clusterCount</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> |
| 2114 | <a name="L1950"></a><tt class="py-lineno">1950</tt> <tt class="py-line"> <tt class="py-name">baselineSwitchCount</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceCount</tt><tt class="py-op">/</tt><tt class="py-name">clusterCount</tt> </tt> |
| 2115 | <a name="L1951"></a><tt class="py-lineno">1951</tt> <tt class="py-line"> </tt> |
| 2116 | <a name="L1952"></a><tt class="py-lineno">1952</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">clusterCount</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2117 | <a name="L1953"></a><tt class="py-lineno">1953</tt> <tt class="py-line"> <tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">baselineSwitchCount</tt> </tt> |
| 2118 | <a name="L1954"></a><tt class="py-lineno">1954</tt> <tt class="py-line"> </tt> |
| 2119 | <a name="L1955"></a><tt class="py-lineno">1955</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">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">deviceCount</tt><tt class="py-op">%</tt><tt class="py-name">clusterCount</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> |
| 2120 | <a name="L1956"></a><tt class="py-lineno">1956</tt> <tt class="py-line"> <tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> |
| 2121 | <a name="L1957"></a><tt class="py-lineno">1957</tt> <tt class="py-line"> </tt> |
| 2122 | <a name="L1958"></a><tt class="py-lineno">1958</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">list</tt><tt class="py-op">:</tt> </tt> |
| 2123 | <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-619" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-619', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Using provided device distribution"</tt><tt class="py-op">)</tt> </tt> |
| 2124 | <a name="L1960"></a><tt class="py-lineno">1960</tt> <tt class="py-line"> </tt> |
| 2125 | <a name="L1961"></a><tt class="py-lineno">1961</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">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">clusterCount</tt><tt class="py-op">:</tt> </tt> |
| 2126 | <a name="L1962"></a><tt class="py-lineno">1962</tt> <tt class="py-line"> <tt class="py-name">switchList</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'0'</tt><tt class="py-op">]</tt> </tt> |
| 2127 | <a name="L1963"></a><tt class="py-lineno">1963</tt> <tt class="py-line"> <tt class="py-name">switchList</tt><tt class="py-op">.</tt><tt class="py-name">extend</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</tt><tt class="py-op">)</tt> </tt> |
| 2128 | <a name="L1964"></a><tt class="py-lineno">1964</tt> <tt class="py-line"> </tt> |
| 2129 | <a name="L1965"></a><tt class="py-lineno">1965</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">deviceCount</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-op">(</tt><tt class="py-name">clusterCount</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2130 | <a name="L1966"></a><tt class="py-lineno">1966</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">deviceCount</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-string">'0'</tt> <tt class="py-keyword">or</tt> <tt class="py-name">deviceCount</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-number">0</tt><tt class="py-op">:</tt> </tt> |
| 2131 | <a name="L1967"></a><tt class="py-lineno">1967</tt> <tt class="py-line"> <tt class="py-name">switchList</tt> <tt class="py-op">=</tt> <tt class="py-name">deviceCount</tt> </tt> |
| 2132 | <a name="L1968"></a><tt class="py-lineno">1968</tt> <tt class="py-line"> </tt> |
| 2133 | <a name="L1969"></a><tt class="py-lineno">1969</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">switchList</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-op">(</tt><tt class="py-name">clusterCount</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> |
| 2134 | <a name="L1970"></a><tt class="py-lineno">1970</tt> <tt class="py-line"> </tt> |
| 2135 | <a name="L1971"></a><tt class="py-lineno">1971</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">AssertionError</tt><tt class="py-op">:</tt> </tt> |
| 2136 | <a name="L1972"></a><tt class="py-lineno">1972</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-620" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-620', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-621" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-621', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-string">"Bad device/Ip list match"</tt><tt class="py-op">)</tt> </tt> |
| 2137 | <a name="L1973"></a><tt class="py-lineno">1973</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">TypeError</tt><tt class="py-op">:</tt> </tt> |
| 2138 | <a name="L1974"></a><tt class="py-lineno">1974</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-622" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-622', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Object not as expected"</tt> <tt class="py-op">)</tt> </tt> |
| 2139 | <a name="L1975"></a><tt class="py-lineno">1975</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt> |
| 2140 | <a name="L1976"></a><tt class="py-lineno">1976</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 2141 | <a name="L1977"></a><tt class="py-lineno">1977</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-623" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-623', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 2142 | <a name="L1978"></a><tt class="py-lineno">1978</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-624" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-624', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2143 | <a name="L1979"></a><tt class="py-lineno">1979</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-625" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-625', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2144 | <a name="L1980"></a><tt class="py-lineno">1980</tt> <tt class="py-line"> </tt> |
| 2145 | <a name="L1981"></a><tt class="py-lineno">1981</tt> <tt class="py-line"> </tt> |
| 2146 | <a name="L1982"></a><tt class="py-lineno">1982</tt> <tt class="py-line"> <tt class="py-name">ONOSIp</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt> |
| 2147 | <a name="L1983"></a><tt class="py-lineno">1983</tt> <tt class="py-line"> <tt class="py-name">ONOSIp</tt><tt class="py-op">.</tt><tt class="py-name">extend</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIpList</tt><tt class="py-op">)</tt> </tt> |
| 2148 | <a name="L1984"></a><tt class="py-lineno">1984</tt> <tt class="py-line"> </tt> |
| 2149 | <a name="L1985"></a><tt class="py-lineno">1985</tt> <tt class="py-line"> <tt class="py-name">devicesString</tt> <tt class="py-op">=</tt> <tt class="py-string">"devConfigs = "</tt> </tt> |
| 2150 | <a name="L1986"></a><tt class="py-lineno">1986</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">node</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">ONOSIp</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2151 | <a name="L1987"></a><tt class="py-lineno">1987</tt> <tt class="py-line"> <tt class="py-name">devicesString</tt> <tt class="py-op">+=</tt> <tt class="py-op">(</tt><tt class="py-name">ONOSIp</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">switchList</tt><tt class="py-op">[</tt><tt class="py-name">node</tt><tt class="py-op">]</tt> <tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> |
| 2152 | <a name="L1988"></a><tt class="py-lineno">1988</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">node</tt> <tt class="py-op"><</tt> <tt class="py-name">clusterCount</tt><tt class="py-op">:</tt> </tt> |
| 2153 | <a name="L1989"></a><tt class="py-lineno">1989</tt> <tt class="py-line"> <tt class="py-name">devicesString</tt> <tt class="py-op">+=</tt> <tt class="py-op">(</tt><tt class="py-string">","</tt><tt class="py-op">)</tt> </tt> |
| 2154 | <a name="L1990"></a><tt class="py-lineno">1990</tt> <tt class="py-line"> </tt> |
| 2155 | <a name="L1991"></a><tt class="py-lineno">1991</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 2156 | <a name="L1992"></a><tt class="py-lineno">1992</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-626" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-626', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg set org.onosproject.provider.nil.device.impl.NullDeviceProvider devConfigs "</tt> <tt class="py-op">+</tt> <tt class="py-name">devicesString</tt> <tt class="py-op">)</tt> </tt> |
| 2157 | <a name="L1993"></a><tt class="py-lineno">1993</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2158 | <a name="L1994"></a><tt class="py-lineno">1994</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-627" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-627', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg set org.onosproject.provider.nil.device.impl.NullDeviceProvider numPorts "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">numPorts</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 2159 | <a name="L1995"></a><tt class="py-lineno">1995</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2160 | <a name="L1996"></a><tt class="py-lineno">1996</tt> <tt class="py-line"> </tt> |
| 2161 | <a name="L1997"></a><tt class="py-lineno">1997</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">10</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2162 | <a name="L1998"></a><tt class="py-lineno">1998</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-628" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-628', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg get org.onosproject.provider.nil.device.impl.NullDeviceProvider"</tt><tt class="py-op">)</tt> </tt> |
| 2163 | <a name="L1999"></a><tt class="py-lineno">1999</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2164 | <a name="L2000"></a><tt class="py-lineno">2000</tt> <tt class="py-line"> <tt class="py-name">verification</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 2165 | <a name="L2001"></a><tt class="py-lineno">2001</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt class="py-string">" value="</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">numPorts</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-string">" value="</tt> <tt class="py-op">+</tt> <tt class="py-name">devicesString</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt><tt class="py-op">:</tt> </tt> |
| 2166 | <a name="L2002"></a><tt class="py-lineno">2002</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt> |
| 2167 | <a name="L2003"></a><tt class="py-lineno">2003</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 2168 | <a name="L2004"></a><tt class="py-lineno">2004</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> |
| 2169 | <a name="L2005"></a><tt class="py-lineno">2005</tt> <tt class="py-line"> </tt> |
| 2170 | <a name="L2006"></a><tt class="py-lineno">2006</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-op">(</tt><tt class="py-string">"value="</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">numPorts</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-string">" value="</tt> <tt class="py-op">+</tt> <tt class="py-name">devicesString</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt> </tt> |
| 2171 | <a name="L2007"></a><tt class="py-lineno">2007</tt> <tt class="py-line"> </tt> |
| 2172 | <a name="L2008"></a><tt class="py-lineno">2008</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">AssertionError</tt><tt class="py-op">:</tt> </tt> |
| 2173 | <a name="L2009"></a><tt class="py-lineno">2009</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-629" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-629', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-630" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-630', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt><tt class="py-string">"Incorrect Config settings: "</tt> <tt class="py-op">+</tt> <tt class="py-name">verification</tt><tt class="py-op">)</tt> </tt> |
| 2174 | <a name="L2010"></a><tt class="py-lineno">2010</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 2175 | <a name="L2011"></a><tt class="py-lineno">2011</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-631" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-631', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 2176 | <a name="L2012"></a><tt class="py-lineno">2012</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-632" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-632', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2177 | <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-633" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-633', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2178 | </div><a name="L2014"></a><tt class="py-lineno">2014</tt> <tt class="py-line"> </tt> |
| 2179 | <a name="OnosDriver.configNullLink"></a><div id="OnosDriver.configNullLink-def"><a name="L2015"></a><tt class="py-lineno">2015</tt> <a class="py-toggle" href="#" id="OnosDriver.configNullLink-toggle" onclick="return toggle('OnosDriver.configNullLink');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#configNullLink">configNullLink</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">fileName</tt><tt class="py-op">=</tt><tt class="py-string">"/opt/onos/apache-karaf-3.0.3/etc/linkGraph.cfg"</tt><tt class="py-op">,</tt> <tt class="py-param">eventRate</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2180 | </div><div id="OnosDriver.configNullLink-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.configNullLink-expanded"><a name="L2016"></a><tt class="py-lineno">2016</tt> <tt class="py-line"> <tt class="py-docstring">'''</tt> </tt> |
| 2181 | <a name="L2017"></a><tt class="py-lineno">2017</tt> <tt class="py-line"><tt class="py-docstring"> fileName default is currently the same as the default on ONOS, specify alternate file if</tt> </tt> |
| 2182 | <a name="L2018"></a><tt class="py-lineno">2018</tt> <tt class="py-line"><tt class="py-docstring"> you want to use a different topology file than linkGraph.cfg</tt> </tt> |
| 2183 | <a name="L2019"></a><tt class="py-lineno">2019</tt> <tt class="py-line"><tt class="py-docstring"> '''</tt> </tt> |
| 2184 | <a name="L2020"></a><tt class="py-lineno">2020</tt> <tt class="py-line"> </tt> |
| 2185 | <a name="L2021"></a><tt class="py-lineno">2021</tt> <tt class="py-line"> </tt> |
| 2186 | <a name="L2022"></a><tt class="py-lineno">2022</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 2187 | <a name="L2023"></a><tt class="py-lineno">2023</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-634" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-634', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg set org.onosproject.provider.nil.link.impl.NullLinkProvider eventRate "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">eventRate</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> |
| 2188 | <a name="L2024"></a><tt class="py-lineno">2024</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2189 | <a name="L2025"></a><tt class="py-lineno">2025</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-635" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-635', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg set org.onosproject.provider.nil.link.impl.NullLinkProvider cfgFile "</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> <tt class="py-op">)</tt> </tt> |
| 2190 | <a name="L2026"></a><tt class="py-lineno">2026</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2191 | <a name="L2027"></a><tt class="py-lineno">2027</tt> <tt class="py-line"> </tt> |
| 2192 | <a name="L2028"></a><tt class="py-lineno">2028</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">10</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2193 | <a name="L2029"></a><tt class="py-lineno">2029</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-636" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-636', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos $OC1 cfg get org.onosproject.provider.nil.link.impl.NullLinkProvider"</tt><tt class="py-op">)</tt> </tt> |
| 2194 | <a name="L2030"></a><tt class="py-lineno">2030</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2195 | <a name="L2031"></a><tt class="py-lineno">2031</tt> <tt class="py-line"> <tt class="py-name">verification</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 2196 | <a name="L2032"></a><tt class="py-lineno">2032</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt class="py-string">" value="</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">eventRate</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-string">" value="</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt><tt class="py-op">:</tt> </tt> |
| 2197 | <a name="L2033"></a><tt class="py-lineno">2033</tt> <tt class="py-line"> <tt class="py-keyword">break</tt> </tt> |
| 2198 | <a name="L2034"></a><tt class="py-lineno">2034</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 2199 | <a name="L2035"></a><tt class="py-lineno">2035</tt> <tt class="py-line"> <tt class="py-name">time</tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> |
| 2200 | <a name="L2036"></a><tt class="py-lineno">2036</tt> <tt class="py-line"> </tt> |
| 2201 | <a name="L2037"></a><tt class="py-lineno">2037</tt> <tt class="py-line"> <tt class="py-keyword">assert</tt> <tt class="py-op">(</tt><tt class="py-string">"value="</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">eventRate</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-string">" value="</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">verification</tt> </tt> |
| 2202 | <a name="L2038"></a><tt class="py-lineno">2038</tt> <tt class="py-line"> </tt> |
| 2203 | <a name="L2039"></a><tt class="py-lineno">2039</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 2204 | <a name="L2040"></a><tt class="py-lineno">2040</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-637" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-637', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-638" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-638', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 2205 | <a name="L2041"></a><tt class="py-lineno">2041</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-639" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-639', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-640" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-640', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 2206 | <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-641" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-641', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2207 | <a name="L2043"></a><tt class="py-lineno">2043</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-642" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-642', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2208 | <a name="L2044"></a><tt class="py-lineno">2044</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">AssertionError</tt><tt class="py-op">:</tt> </tt> |
| 2209 | <a name="L2045"></a><tt class="py-lineno">2045</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-643" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-643', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"Settings did not post to ONOS"</tt><tt class="py-op">)</tt> </tt> |
| 2210 | <a name="L2046"></a><tt class="py-lineno">2046</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-644" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-644', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-645" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-645', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt><tt class="py-name">varification</tt><tt class="py-op">)</tt> </tt> |
| 2211 | <a name="L2047"></a><tt class="py-lineno">2047</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">:</tt> </tt> |
| 2212 | <a name="L2048"></a><tt class="py-lineno">2048</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-646" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-646', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">exception</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Uncaught exception!"</tt> <tt class="py-op">)</tt> </tt> |
| 2213 | <a name="L2049"></a><tt class="py-lineno">2049</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-647" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-647', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-648" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-648', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt><tt class="py-name">varification</tt><tt class="py-op">)</tt> </tt> |
| 2214 | <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-649" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-649', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2215 | <a name="L2051"></a><tt class="py-lineno">2051</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-650" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-650', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2216 | </div><a name="L2052"></a><tt class="py-lineno">2052</tt> <tt class="py-line"> </tt> |
| 2217 | <a name="OnosDriver.getOnosIps"></a><div id="OnosDriver.getOnosIps-def"><a name="L2053"></a><tt class="py-lineno">2053</tt> <a class="py-toggle" href="#" id="OnosDriver.getOnosIps-toggle" onclick="return toggle('OnosDriver.getOnosIps');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#getOnosIps">getOnosIps</a><tt class="py-op">(</tt> <tt class="py-param">self</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2218 | </div><div id="OnosDriver.getOnosIps-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.getOnosIps-expanded"><a name="L2054"></a><tt class="py-lineno">2054</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 2219 | <a name="L2055"></a><tt class="py-lineno">2055</tt> <tt class="py-line"><tt class="py-docstring"> Get all onos IPs stored in</tt> </tt> |
| 2220 | <a name="L2056"></a><tt class="py-lineno">2056</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 2221 | <a name="L2057"></a><tt class="py-lineno">2057</tt> <tt class="py-line"> </tt> |
| 2222 | <a name="L2058"></a><tt class="py-lineno">2058</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">sorted</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">onosIps</tt><tt class="py-op">.</tt><tt class="py-name">values</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 2223 | </div><a name="L2059"></a><tt class="py-lineno">2059</tt> <tt class="py-line"> </tt> |
| 2224 | <a name="OnosDriver.logReport"></a><div id="OnosDriver.logReport-def"><a name="L2060"></a><tt class="py-lineno">2060</tt> <a class="py-toggle" href="#" id="OnosDriver.logReport-toggle" onclick="return toggle('OnosDriver.logReport');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#logReport">logReport</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">nodeIp</tt><tt class="py-op">,</tt> <tt class="py-param">searchTerms</tt><tt class="py-op">,</tt> <tt class="py-param">outputMode</tt><tt class="py-op">=</tt><tt class="py-string">"s"</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2225 | </div><div id="OnosDriver.logReport-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.logReport-expanded"><a name="L2061"></a><tt class="py-lineno">2061</tt> <tt class="py-line"> <tt class="py-docstring">'''</tt> </tt> |
| 2226 | <a name="L2062"></a><tt class="py-lineno">2062</tt> <tt class="py-line"><tt class="py-docstring"> - accepts either a list or a string for "searchTerms" these</tt> </tt> |
| 2227 | <a name="L2063"></a><tt class="py-lineno">2063</tt> <tt class="py-line"><tt class="py-docstring"> terms will be searched for in the log and have their</tt> </tt> |
| 2228 | <a name="L2064"></a><tt class="py-lineno">2064</tt> <tt class="py-line"><tt class="py-docstring"> instances counted</tt> </tt> |
| 2229 | <a name="L2065"></a><tt class="py-lineno">2065</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 2230 | <a name="L2066"></a><tt class="py-lineno">2066</tt> <tt class="py-line"><tt class="py-docstring"> - nodeIp is the ip of the node whos log is to be scanned</tt> </tt> |
| 2231 | <a name="L2067"></a><tt class="py-lineno">2067</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 2232 | <a name="L2068"></a><tt class="py-lineno">2068</tt> <tt class="py-line"><tt class="py-docstring"> - output modes:</tt> </tt> |
| 2233 | <a name="L2069"></a><tt class="py-lineno">2069</tt> <tt class="py-line"><tt class="py-docstring"> "s" - Simple. Quiet output mode that just prints</tt> </tt> |
| 2234 | <a name="L2070"></a><tt class="py-lineno">2070</tt> <tt class="py-line"><tt class="py-docstring"> the occurences of each search term</tt> </tt> |
| 2235 | <a name="L2071"></a><tt class="py-lineno">2071</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 2236 | <a name="L2072"></a><tt class="py-lineno">2072</tt> <tt class="py-line"><tt class="py-docstring"> "d" - Detailed. Prints number of occurences as well as the entire</tt> </tt> |
| 2237 | <a name="L2073"></a><tt class="py-lineno">2073</tt> <tt class="py-line"><tt class="py-docstring"> line for each of the last 5 occurences</tt> </tt> |
| 2238 | <a name="L2074"></a><tt class="py-lineno">2074</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> |
| 2239 | <a name="L2075"></a><tt class="py-lineno">2075</tt> <tt class="py-line"><tt class="py-docstring"> - returns total of the number of instances of all search terms</tt> </tt> |
| 2240 | <a name="L2076"></a><tt class="py-lineno">2076</tt> <tt class="py-line"><tt class="py-docstring"> '''</tt> </tt> |
| 2241 | <a name="L2077"></a><tt class="py-lineno">2077</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-651" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-651', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"========================== Log Report ===========================\n"</tt><tt class="py-op">)</tt> </tt> |
| 2242 | <a name="L2078"></a><tt class="py-lineno">2078</tt> <tt class="py-line"> </tt> |
| 2243 | <a name="L2079"></a><tt class="py-lineno">2079</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">searchTerms</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">str</tt><tt class="py-op">:</tt> </tt> |
| 2244 | <a name="L2080"></a><tt class="py-lineno">2080</tt> <tt class="py-line"> <tt class="py-name">searchTerms</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">searchTerms</tt><tt class="py-op">]</tt> </tt> |
| 2245 | <a name="L2081"></a><tt class="py-lineno">2081</tt> <tt class="py-line"> </tt> |
| 2246 | <a name="L2082"></a><tt class="py-lineno">2082</tt> <tt class="py-line"> <tt class="py-name">logLines</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-op">[</tt><tt class="py-string">" "</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">searchTerms</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-op">]</tt> </tt> |
| 2247 | <a name="L2083"></a><tt class="py-lineno">2083</tt> <tt class="py-line"> </tt> |
| 2248 | <a name="L2084"></a><tt class="py-lineno">2084</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">term</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">searchTerms</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2249 | <a name="L2085"></a><tt class="py-lineno">2085</tt> <tt class="py-line"> <tt class="py-name">logLines</tt><tt class="py-op">[</tt><tt class="py-name">term</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">searchTerms</tt><tt class="py-op">[</tt><tt class="py-name">term</tt><tt class="py-op">]</tt> </tt> |
| 2250 | <a name="L2086"></a><tt class="py-lineno">2086</tt> <tt class="py-line"> </tt> |
| 2251 | <a name="L2087"></a><tt class="py-lineno">2087</tt> <tt class="py-line"> <tt class="py-name">totalHits</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> |
| 2252 | <a name="L2088"></a><tt class="py-lineno">2088</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">term</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">searchTerms</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2253 | <a name="L2089"></a><tt class="py-lineno">2089</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"onos-ssh "</tt> <tt class="py-op">+</tt> <tt class="py-name">nodeIp</tt> <tt class="py-op">+</tt> <tt class="py-string">" cat /opt/onos/log/karaf.log | grep "</tt> <tt class="py-op">+</tt> <tt class="py-name">searchTerms</tt><tt class="py-op">[</tt><tt class="py-name">term</tt><tt class="py-op">]</tt> </tt> |
| 2254 | <a name="L2090"></a><tt class="py-lineno">2090</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-652" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-652', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-name">cmd</tt><tt class="py-op">)</tt> </tt> |
| 2255 | <a name="L2091"></a><tt class="py-lineno">2091</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2256 | <a name="L2092"></a><tt class="py-lineno">2092</tt> <tt class="py-line"> <tt class="py-name">before</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">splitlines</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2257 | <a name="L2093"></a><tt class="py-lineno">2093</tt> <tt class="py-line"> </tt> |
| 2258 | <a name="L2094"></a><tt class="py-lineno">2094</tt> <tt class="py-line"> <tt class="py-name">count</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">searchTerms</tt><tt class="py-op">[</tt><tt class="py-name">term</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt> |
| 2259 | <a name="L2095"></a><tt class="py-lineno">2095</tt> <tt class="py-line"> </tt> |
| 2260 | <a name="L2096"></a><tt class="py-lineno">2096</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">line</tt> <tt class="py-keyword">in</tt> <tt class="py-name">before</tt><tt class="py-op">:</tt> </tt> |
| 2261 | <a name="L2097"></a><tt class="py-lineno">2097</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">searchTerms</tt><tt class="py-op">[</tt><tt class="py-name">term</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">line</tt> <tt class="py-keyword">and</tt> <tt class="py-string">"grep"</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">line</tt><tt class="py-op">:</tt> </tt> |
| 2262 | <a name="L2098"></a><tt class="py-lineno">2098</tt> <tt class="py-line"> <tt class="py-name">count</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> |
| 2263 | <a name="L2099"></a><tt class="py-lineno">2099</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">before</tt><tt class="py-op">.</tt><tt class="py-name">index</tt><tt class="py-op">(</tt><tt class="py-name">line</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">before</tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">7</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2264 | <a name="L2100"></a><tt class="py-lineno">2100</tt> <tt class="py-line"> <tt class="py-name">logLines</tt><tt class="py-op">[</tt><tt class="py-name">term</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt> </tt> |
| 2265 | <a name="L2101"></a><tt class="py-lineno">2101</tt> <tt class="py-line"> </tt> |
| 2266 | <a name="L2102"></a><tt class="py-lineno">2102</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-653" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-653', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">count</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-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">count</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> |
| 2267 | <a name="L2103"></a><tt class="py-lineno">2103</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">term</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">searchTerms</tt><tt class="py-op">)</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 2268 | <a name="L2104"></a><tt class="py-lineno">2104</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt><tt class="py-string">"\n"</tt><tt class="py-op">)</tt> </tt> |
| 2269 | <a name="L2105"></a><tt class="py-lineno">2105</tt> <tt class="py-line"> <tt class="py-name">totalHits</tt> <tt class="py-op">+=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">count</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt> |
| 2270 | <a name="L2106"></a><tt class="py-lineno">2106</tt> <tt class="py-line"> </tt> |
| 2271 | <a name="L2107"></a><tt class="py-lineno">2107</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">outputMode</tt> <tt class="py-op">!=</tt> <tt class="py-string">"s"</tt> <tt class="py-keyword">and</tt> <tt class="py-name">outputMode</tt> <tt class="py-op">!=</tt> <tt class="py-string">"S"</tt><tt class="py-op">:</tt> </tt> |
| 2272 | <a name="L2108"></a><tt class="py-lineno">2108</tt> <tt class="py-line"> <tt class="py-name">outputString</tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt> </tt> |
| 2273 | <a name="L2109"></a><tt class="py-lineno">2109</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">logLines</tt><tt class="py-op">:</tt> </tt> |
| 2274 | <a name="L2110"></a><tt class="py-lineno">2110</tt> <tt class="py-line"> <tt class="py-name">outputString</tt> <tt class="py-op">=</tt> <tt class="py-name">i</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-string">": \n"</tt> </tt> |
| 2275 | <a name="L2111"></a><tt class="py-lineno">2111</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">x</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">len</tt><tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2276 | <a name="L2112"></a><tt class="py-lineno">2112</tt> <tt class="py-line"> <tt class="py-name">outputString</tt> <tt class="py-op">+=</tt> <tt class="py-op">(</tt> <tt class="py-name">i</tt><tt class="py-op">[</tt><tt class="py-name">x</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n"</tt> <tt class="py-op">)</tt> </tt> |
| 2277 | <a name="L2113"></a><tt class="py-lineno">2113</tt> <tt class="py-line"> </tt> |
| 2278 | <a name="L2114"></a><tt class="py-lineno">2114</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">outputString</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">0</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">": \n"</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2279 | <a name="L2115"></a><tt class="py-lineno">2115</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-654" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-654', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-name">outputString</tt><tt class="py-op">)</tt> </tt> |
| 2280 | <a name="L2116"></a><tt class="py-lineno">2116</tt> <tt class="py-line"> </tt> |
| 2281 | <a name="L2117"></a><tt class="py-lineno">2117</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-655" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-655', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-string">"================================================================\n"</tt><tt class="py-op">)</tt> </tt> |
| 2282 | <a name="L2118"></a><tt class="py-lineno">2118</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">totalHits</tt> </tt> |
| 2283 | </div><a name="L2119"></a><tt class="py-lineno">2119</tt> <tt class="py-line"> </tt> |
| 2284 | <a name="OnosDriver.copyMininetFile"></a><div id="OnosDriver.copyMininetFile-def"><a name="L2120"></a><tt class="py-lineno">2120</tt> <a class="py-toggle" href="#" id="OnosDriver.copyMininetFile-toggle" onclick="return toggle('OnosDriver.copyMininetFile');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#copyMininetFile">copyMininetFile</a><tt class="py-op">(</tt> <tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">fileName</tt><tt class="py-op">,</tt> <tt class="py-param">localPath</tt><tt class="py-op">,</tt> <tt class="py-param">userName</tt><tt class="py-op">,</tt> <tt class="py-param">ip</tt><tt class="py-op">,</tt> </tt> |
| 2285 | <a name="L2121"></a><tt class="py-lineno">2121</tt> <tt class="py-line"> <tt class="py-param">mnPath</tt><tt class="py-op">=</tt><tt class="py-string">'~/mininet/custom/'</tt><tt class="py-op">,</tt> <tt class="py-param">timeout</tt> <tt class="py-op">=</tt> <tt class="py-number">60</tt> <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2286 | </div><div id="OnosDriver.copyMininetFile-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.copyMininetFile-expanded"><a name="L2122"></a><tt class="py-lineno">2122</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> |
| 2287 | <a name="L2123"></a><tt class="py-lineno">2123</tt> <tt class="py-line"><tt class="py-docstring"> Description:</tt> </tt> |
| 2288 | <a name="L2124"></a><tt class="py-lineno">2124</tt> <tt class="py-line"><tt class="py-docstring"> Copy mininet topology file from dependency folder in the test folder</tt> </tt> |
| 2289 | <a name="L2125"></a><tt class="py-lineno">2125</tt> <tt class="py-line"><tt class="py-docstring"> and paste it to the mininet machine's mininet/custom folder</tt> </tt> |
| 2290 | <a name="L2126"></a><tt class="py-lineno">2126</tt> <tt class="py-line"><tt class="py-docstring"> Required:</tt> </tt> |
| 2291 | <a name="L2127"></a><tt class="py-lineno">2127</tt> <tt class="py-line"><tt class="py-docstring"> fileName - Name of the topology file to copy</tt> </tt> |
| 2292 | <a name="L2128"></a><tt class="py-lineno">2128</tt> <tt class="py-line"><tt class="py-docstring"> localPath - File path of the mininet topology file</tt> </tt> |
| 2293 | <a name="L2129"></a><tt class="py-lineno">2129</tt> <tt class="py-line"><tt class="py-docstring"> userName - User name of the mininet machine to send the file to</tt> </tt> |
| 2294 | <a name="L2130"></a><tt class="py-lineno">2130</tt> <tt class="py-line"><tt class="py-docstring"> ip - Ip address of the mininet machine</tt> </tt> |
| 2295 | <a name="L2131"></a><tt class="py-lineno">2131</tt> <tt class="py-line"><tt class="py-docstring"> Optional:</tt> </tt> |
| 2296 | <a name="L2132"></a><tt class="py-lineno">2132</tt> <tt class="py-line"><tt class="py-docstring"> mnPath - of the mininet directory to send the file to</tt> </tt> |
| 2297 | <a name="L2133"></a><tt class="py-lineno">2133</tt> <tt class="py-line"><tt class="py-docstring"> Return:</tt> </tt> |
| 2298 | <a name="L2134"></a><tt class="py-lineno">2134</tt> <tt class="py-line"><tt class="py-docstring"> Return main.TRUE if successfully copied the file otherwise</tt> </tt> |
| 2299 | <a name="L2135"></a><tt class="py-lineno">2135</tt> <tt class="py-line"><tt class="py-docstring"> return main.FALSE</tt> </tt> |
| 2300 | <a name="L2136"></a><tt class="py-lineno">2136</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> |
| 2301 | <a name="L2137"></a><tt class="py-lineno">2137</tt> <tt class="py-line"> </tt> |
| 2302 | <a name="L2138"></a><tt class="py-lineno">2138</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> |
| 2303 | <a name="L2139"></a><tt class="py-lineno">2139</tt> <tt class="py-line"> <tt class="py-name">cmd</tt> <tt class="py-op">=</tt> <tt class="py-string">"scp "</tt> <tt class="py-op">+</tt> <tt class="py-name">localPath</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> <tt class="py-op">+</tt> <tt class="py-string">" "</tt> <tt class="py-op">+</tt> <tt class="py-name">userName</tt> <tt class="py-op">+</tt> <tt class="py-string">"@"</tt> <tt class="py-op">+</tt> \ </tt> |
| 2304 | <a name="L2140"></a><tt class="py-lineno">2140</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt> <tt class="py-name">ip</tt> <tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">":"</tt> <tt class="py-op">+</tt> <tt class="py-name">mnPath</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> </tt> |
| 2305 | <a name="L2141"></a><tt class="py-lineno">2141</tt> <tt class="py-line"> </tt> |
| 2306 | <a name="L2142"></a><tt class="py-lineno">2142</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-656" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-656', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 2307 | <a name="L2143"></a><tt class="py-lineno">2143</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 2308 | <a name="L2144"></a><tt class="py-lineno">2144</tt> <tt class="py-line"> </tt> |
| 2309 | <a name="L2145"></a><tt class="py-lineno">2145</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-657" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-657', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": Execute: "</tt> <tt class="py-op">+</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 2310 | <a name="L2146"></a><tt class="py-lineno">2146</tt> <tt class="py-line"> </tt> |
| 2311 | <a name="L2147"></a><tt class="py-lineno">2147</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-658" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-658', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-name">cmd</tt> <tt class="py-op">)</tt> </tt> |
| 2312 | <a name="L2148"></a><tt class="py-lineno">2148</tt> <tt class="py-line"> </tt> |
| 2313 | <a name="L2149"></a><tt class="py-lineno">2149</tt> <tt class="py-line"> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-op">[</tt> <tt class="py-string">'No such file'</tt><tt class="py-op">,</tt> </tt> |
| 2314 | <a name="L2150"></a><tt class="py-lineno">2150</tt> <tt class="py-line"> <tt class="py-string">"100%"</tt><tt class="py-op">,</tt> </tt> |
| 2315 | <a name="L2151"></a><tt class="py-lineno">2151</tt> <tt class="py-line"> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt> <tt class="py-op">]</tt> <tt class="py-op">)</tt> </tt> |
| 2316 | <a name="L2152"></a><tt class="py-lineno">2152</tt> <tt class="py-line"> </tt> |
| 2317 | <a name="L2153"></a><tt class="py-lineno">2153</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt> |
| 2318 | <a name="L2154"></a><tt class="py-lineno">2154</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-659" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-659', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-660" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-660', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": File "</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> <tt class="py-op">+</tt> </tt> |
| 2319 | <a name="L2155"></a><tt class="py-lineno">2155</tt> <tt class="py-line"> <tt class="py-string">" does not exist!"</tt> <tt class="py-op">)</tt> </tt> |
| 2320 | <a name="L2156"></a><tt class="py-lineno">2156</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">FALSE</tt> </tt> |
| 2321 | <a name="L2157"></a><tt class="py-lineno">2157</tt> <tt class="py-line"> </tt> |
| 2322 | <a name="L2158"></a><tt class="py-lineno">2158</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> |
| 2323 | <a name="L2159"></a><tt class="py-lineno">2159</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-661" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-661', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": File "</tt> <tt class="py-op">+</tt> <tt class="py-name">fileName</tt> <tt class="py-op">+</tt> </tt> |
| 2324 | <a name="L2160"></a><tt class="py-lineno">2160</tt> <tt class="py-line"> <tt class="py-string">" has been copied!"</tt> <tt class="py-op">)</tt> </tt> |
| 2325 | <a name="L2161"></a><tt class="py-lineno">2161</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-662" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-662', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt> <tt class="py-string">""</tt> <tt class="py-op">)</tt> </tt> |
| 2326 | <a name="L2162"></a><tt class="py-lineno">2162</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt> <tt class="py-string">"\$"</tt> <tt class="py-op">)</tt> </tt> |
| 2327 | <a name="L2163"></a><tt class="py-lineno">2163</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TRUE</tt> </tt> |
| 2328 | <a name="L2164"></a><tt class="py-lineno">2164</tt> <tt class="py-line"> </tt> |
| 2329 | <a name="L2165"></a><tt class="py-lineno">2165</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">EOF</tt><tt class="py-op">:</tt> </tt> |
| 2330 | <a name="L2166"></a><tt class="py-lineno">2166</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-663" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-663', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-664" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-664', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": EOF exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 2331 | <a name="L2167"></a><tt class="py-lineno">2167</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-665" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-665', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-666" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-666', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 2332 | <a name="L2168"></a><tt class="py-lineno">2168</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-667" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-667', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2333 | <a name="L2169"></a><tt class="py-lineno">2169</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-668" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-668', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2334 | <a name="L2170"></a><tt class="py-lineno">2170</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">pexpect</tt><tt class="py-op">.</tt><tt class="py-name">TIMEOUT</tt><tt class="py-op">:</tt> </tt> |
| 2335 | <a name="L2171"></a><tt class="py-lineno">2171</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-669" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-669', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-670" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-670', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": TIMEOUT exception found"</tt> <tt class="py-op">)</tt> </tt> |
| 2336 | <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-671" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.log" class="py-name" href="#" onclick="return doclink('link-671', 'log', 'link-7');">log</a></tt><tt class="py-op">.</tt><tt id="link-672" class="py-name"><a title="TestON.bin.cli.error" class="py-name" href="#" onclick="return doclink('link-672', 'error', 'link-12');">error</a></tt><tt class="py-op">(</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name</tt> <tt class="py-op">+</tt> <tt class="py-string">": "</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> <tt class="py-op">)</tt> </tt> |
| 2337 | <a name="L2173"></a><tt class="py-lineno">2173</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-673" class="py-name"><a title="TestON.core.teston.TestON.cleanup" class="py-name" href="#" onclick="return doclink('link-673', 'cleanup', 'link-25');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2338 | <a name="L2174"></a><tt class="py-lineno">2174</tt> <tt class="py-line"> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt id="link-674" class="py-name"><a title="TestON.core.teston.TestON.exit" class="py-name" href="#" onclick="return doclink('link-674', 'exit', 'link-26');">exit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2339 | </div><a name="L2175"></a><tt class="py-lineno">2175</tt> <tt class="py-line"> </tt> |
| 2340 | <a name="OnosDriver.jvmSet"></a><div id="OnosDriver.jvmSet-def"><a name="L2176"></a><tt class="py-lineno">2176</tt> <a class="py-toggle" href="#" id="OnosDriver.jvmSet-toggle" onclick="return toggle('OnosDriver.jvmSet');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#jvmSet">jvmSet</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">memory</tt><tt class="py-op">=</tt><tt class="py-number">8</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2341 | </div><div id="OnosDriver.jvmSet-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.jvmSet-expanded"><a name="L2177"></a><tt class="py-lineno">2177</tt> <tt class="py-line"> </tt> |
| 2342 | <a name="L2178"></a><tt class="py-lineno">2178</tt> <tt class="py-line"> <tt class="py-keyword">import</tt> <tt class="py-name">os</tt> </tt> |
| 2343 | <a name="L2179"></a><tt class="py-lineno">2179</tt> <tt class="py-line"> </tt> |
| 2344 | <a name="L2180"></a><tt class="py-lineno">2180</tt> <tt class="py-line"> <tt class="py-name">homeDir</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt id="link-675" class="py-name"><a title="TestON.bin.cli.path |
| 2345 | TestON.core.teston.path" class="py-name" href="#" onclick="return doclink('link-675', 'path', 'link-0');">path</a></tt><tt class="py-op">.</tt><tt class="py-name">expanduser</tt><tt class="py-op">(</tt><tt class="py-string">'~'</tt><tt class="py-op">)</tt> </tt> |
| 2346 | <a name="L2181"></a><tt class="py-lineno">2181</tt> <tt class="py-line"> <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt class="py-string">"/onos/tools/package/bin/onos-service"</tt> </tt> |
| 2347 | <a name="L2182"></a><tt class="py-lineno">2182</tt> <tt class="py-line"> </tt> |
| 2348 | <a name="L2183"></a><tt class="py-lineno">2183</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">homeDir</tt> <tt class="py-op">+</tt> <tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-string">'w+'</tt><tt class="py-op">)</tt> </tt> |
| 2349 | <a name="L2184"></a><tt class="py-lineno">2184</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"#!/bin/bash\n "</tt><tt class="py-op">)</tt> </tt> |
| 2350 | <a name="L2185"></a><tt class="py-lineno">2185</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"#------------------------------------- \n "</tt><tt class="py-op">)</tt> </tt> |
| 2351 | <a name="L2186"></a><tt class="py-lineno">2186</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"# Starts ONOS Apache Karaf container\n "</tt><tt class="py-op">)</tt> </tt> |
| 2352 | <a name="L2187"></a><tt class="py-lineno">2187</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"#------------------------------------- \n "</tt><tt class="py-op">)</tt> </tt> |
| 2353 | <a name="L2188"></a><tt class="py-lineno">2188</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"#export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-7-openjdk-amd64/}\n "</tt><tt class="py-op">)</tt> </tt> |
| 2354 | <a name="L2189"></a><tt class="py-lineno">2189</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"""export JAVA_OPTS="${JAVA_OPTS:--Xms"""</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">memory</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"G -Xmx"</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">memory</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">"""G}" \n """</tt><tt class="py-op">)</tt> </tt> |
| 2355 | <a name="L2190"></a><tt class="py-lineno">2190</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"[ -d $ONOS_HOME ] && cd $ONOS_HOME || ONOS_HOME=$(dirname $0)/..\n"</tt><tt class="py-op">)</tt> </tt> |
| 2356 | <a name="L2191"></a><tt class="py-lineno">2191</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-string">"""${ONOS_HOME}/apache-karaf-$KARAF_VERSION/bin/karaf "$@" \n """</tt><tt class="py-op">)</tt> </tt> |
| 2357 | <a name="L2192"></a><tt class="py-lineno">2192</tt> <tt class="py-line"> <tt class="py-name">serviceConfig</tt><tt class="py-op">.</tt><tt class="py-name">close</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2358 | </div><a name="L2193"></a><tt class="py-lineno">2193</tt> <tt class="py-line"> </tt> |
| 2359 | <a name="OnosDriver.createDBFile"></a><div id="OnosDriver.createDBFile-def"><a name="L2194"></a><tt class="py-lineno">2194</tt> <a class="py-toggle" href="#" id="OnosDriver.createDBFile-toggle" onclick="return toggle('OnosDriver.createDBFile');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#createDBFile">createDBFile</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">testData</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2360 | </div><div id="OnosDriver.createDBFile-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.createDBFile-expanded"><a name="L2195"></a><tt class="py-lineno">2195</tt> <tt class="py-line"> </tt> |
| 2361 | <a name="L2196"></a><tt class="py-lineno">2196</tt> <tt class="py-line"> <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt class="py-name">main</tt><tt class="py-op">.</tt><tt class="py-name">TEST</tt> <tt class="py-op">+</tt> <tt class="py-string">"DB"</tt> </tt> |
| 2362 | <a name="L2197"></a><tt class="py-lineno">2197</tt> <tt class="py-line"> <tt class="py-name">DBString</tt> <tt class="py-op">=</tt> <tt class="py-string">""</tt> </tt> |
| 2363 | <a name="L2198"></a><tt class="py-lineno">2198</tt> <tt class="py-line"> </tt> |
| 2364 | <a name="L2199"></a><tt class="py-lineno">2199</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">testData</tt><tt class="py-op">:</tt> </tt> |
| 2365 | <a name="L2200"></a><tt class="py-lineno">2200</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">string</tt><tt class="py-op">:</tt> </tt> |
| 2366 | <a name="L2201"></a><tt class="py-lineno">2201</tt> <tt class="py-line"> <tt class="py-name">item</tt> <tt class="py-op">=</tt> <tt class="py-string">"'"</tt> <tt class="py-op">+</tt> <tt class="py-name">item</tt> <tt class="py-op">+</tt> <tt class="py-string">"'"</tt> </tt> |
| 2367 | <a name="L2202"></a><tt class="py-lineno">2202</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">testData</tt><tt class="py-op">.</tt><tt class="py-name">index</tt><tt class="py-op">(</tt><tt class="py-name">item</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">testData</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2368 | <a name="L2203"></a><tt class="py-lineno">2203</tt> <tt class="py-line"> <tt class="py-name">item</tt> <tt class="py-op">+=</tt> <tt class="py-string">","</tt> </tt> |
| 2369 | <a name="L2204"></a><tt class="py-lineno">2204</tt> <tt class="py-line"> <tt class="py-name">DBString</tt> <tt class="py-op">+=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> </tt> |
| 2370 | <a name="L2205"></a><tt class="py-lineno">2205</tt> <tt class="py-line"> </tt> |
| 2371 | <a name="L2206"></a><tt class="py-lineno">2206</tt> <tt class="py-line"> <tt class="py-name">DBFile</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-string">"a"</tt><tt class="py-op">)</tt> </tt> |
| 2372 | <a name="L2207"></a><tt class="py-lineno">2207</tt> <tt class="py-line"> <tt class="py-name">DBFile</tt><tt class="py-op">.</tt><tt class="py-name">write</tt><tt class="py-op">(</tt><tt class="py-name">DBString</tt><tt class="py-op">)</tt> </tt> |
| 2373 | <a name="L2208"></a><tt class="py-lineno">2208</tt> <tt class="py-line"> <tt class="py-name">DBFile</tt><tt class="py-op">.</tt><tt class="py-name">close</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> |
| 2374 | </div><a name="L2209"></a><tt class="py-lineno">2209</tt> <tt class="py-line"> </tt> |
| 2375 | <a name="OnosDriver.verifySummary"></a><div id="OnosDriver.verifySummary-def"><a name="L2210"></a><tt class="py-lineno">2210</tt> <a class="py-toggle" href="#" id="OnosDriver.verifySummary-toggle" onclick="return toggle('OnosDriver.verifySummary');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="TestON.drivers.common.cli.onosdriver.OnosDriver-class.html#verifySummary">verifySummary</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ONOSIp</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-param">deviceCount</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> |
| 2376 | </div><div id="OnosDriver.verifySummary-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OnosDriver.verifySummary-expanded"><a name="L2211"></a><tt class="py-lineno">2211</tt> <tt class="py-line"> </tt> |
| 2377 | <a name="L2212"></a><tt class="py-lineno">2212</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt id="link-676" class="py-name"><a title="TestON.drivers.common.cli.onosclidriver.OnosCliDriver.sendline" class="py-name" href="#" onclick="return doclink('link-676', 'sendline', 'link-19');">sendline</a></tt><tt class="py-op">(</tt><tt class="py-string">"onos "</tt> <tt class="py-op">+</tt> <tt class="py-name">ONOSIp</tt> <tt class="py-op">+</tt> <tt class="py-string">" summary"</tt><tt class="py-op">)</tt> </tt> |
| 2378 | <a name="L2213"></a><tt class="py-lineno">2213</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">expect</tt><tt class="py-op">(</tt><tt class="py-string">":~"</tt><tt class="py-op">)</tt> </tt> |
| 2379 | <a name="L2214"></a><tt class="py-lineno">2214</tt> <tt class="py-line"> </tt> |
| 2380 | <a name="L2215"></a><tt class="py-lineno">2215</tt> <tt class="py-line"> <tt class="py-name">summaryStr</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">handle</tt><tt class="py-op">.</tt><tt class="py-name">before</tt> </tt> |
| 2381 | <a name="L2216"></a><tt class="py-lineno">2216</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"\nSummary\n==============\n"</tt> <tt class="py-op">+</tt> <tt class="py-name">summaryStr</tt> <tt class="py-op">+</tt> <tt class="py-string">"\n\n"</tt> </tt> |
| 2382 | <a name="L2217"></a><tt class="py-lineno">2217</tt> <tt class="py-line"> </tt> |
| 2383 | <a name="L2218"></a><tt class="py-lineno">2218</tt> <tt class="py-line"> <tt class="py-comment">#passed = "SCC(s)=1" in summaryStr</tt> </tt> |
| 2384 | <a name="L2219"></a><tt class="py-lineno">2219</tt> <tt class="py-line"> <tt class="py-comment">#if deviceCount:</tt> </tt> |
| 2385 | <a name="L2220"></a><tt class="py-lineno">2220</tt> <tt class="py-line"> <tt class="py-comment"># passed = "devices=" + str(deviceCount) + "," not in summaryStr</tt> </tt> |
| 2386 | <a name="L2221"></a><tt class="py-lineno">2221</tt> <tt class="py-line"> </tt> |
| 2387 | <a name="L2222"></a><tt class="py-lineno">2222</tt> <tt class="py-line"> </tt> |
| 2388 | <a name="L2223"></a><tt class="py-lineno">2223</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">"SCC(s)=1,"</tt> <tt class="py-keyword">in</tt> <tt class="py-name">summaryStr</tt><tt class="py-op">:</tt> </tt> |
| 2389 | <a name="L2224"></a><tt class="py-lineno">2224</tt> <tt class="py-line"> <tt class="py-name">passed</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> |
| 2390 | <a name="L2225"></a><tt class="py-lineno">2225</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt><tt class="py-string">"Summary is verifed"</tt><tt class="py-op">)</tt> </tt> |
| 2391 | <a name="L2226"></a><tt class="py-lineno">2226</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 2392 | <a name="L2227"></a><tt class="py-lineno">2227</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt><tt class="py-string">"Summary failed"</tt><tt class="py-op">)</tt> </tt> |
| 2393 | <a name="L2228"></a><tt class="py-lineno">2228</tt> <tt class="py-line"> </tt> |
| 2394 | <a name="L2229"></a><tt class="py-lineno">2229</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">deviceCount</tt><tt class="py-op">:</tt> </tt> |
| 2395 | <a name="L2230"></a><tt class="py-lineno">2230</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-string">" ============================="</tt> </tt> |
| 2396 | <a name="L2231"></a><tt class="py-lineno">2231</tt> <tt class="py-line"> <tt class="py-name">checkStr</tt> <tt class="py-op">=</tt> <tt class="py-string">"devices="</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">deviceCount</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-string">","</tt> </tt> |
| 2397 | <a name="L2232"></a><tt class="py-lineno">2232</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"Checkstr: "</tt> <tt class="py-op">+</tt> <tt class="py-name">checkStr</tt> </tt> |
| 2398 | <a name="L2233"></a><tt class="py-lineno">2233</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">checkStr</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">summaryStr</tt><tt class="py-op">:</tt> </tt> |
| 2399 | <a name="L2234"></a><tt class="py-lineno">2234</tt> <tt class="py-line"> <tt class="py-name">passed</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> |
| 2400 | <a name="L2235"></a><tt class="py-lineno">2235</tt> <tt class="py-line"> <tt class="py-keyword">print</tt><tt class="py-op">(</tt><tt class="py-string">"Device count failed"</tt><tt class="py-op">)</tt> </tt> |
| 2401 | <a name="L2236"></a><tt class="py-lineno">2236</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> |
| 2402 | <a name="L2237"></a><tt class="py-lineno">2237</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-string">"device count verified"</tt> </tt> |
| 2403 | <a name="L2238"></a><tt class="py-lineno">2238</tt> <tt class="py-line"> </tt> |
| 2404 | <a name="L2239"></a><tt class="py-lineno">2239</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">passed</tt> </tt> |
| 2405 | </div></div><a name="L2240"></a><tt class="py-lineno">2240</tt> <tt class="py-line"> </tt><script type="text/javascript"> |
| 2406 | <!-- |
| 2407 | expandto(location.href); |
| 2408 | // --> |
| 2409 | </script> |
| 2410 | </pre> |
| 2411 | <br /> |
| 2412 | <!-- ==================== NAVIGATION BAR ==================== --> |
| 2413 | <table class="navbar" border="0" width="100%" cellpadding="0" |
| 2414 | bgcolor="#a0c0ff" cellspacing="0"> |
| 2415 | <tr valign="middle"> |
| 2416 | <!-- Home link --> |
| 2417 | <th> <a |
| 2418 | href="TestON-module.html">Home</a> </th> |
| 2419 | |
| 2420 | <!-- Tree link --> |
| 2421 | <th> <a |
| 2422 | href="module-tree.html">Trees</a> </th> |
| 2423 | |
| 2424 | <!-- Index link --> |
| 2425 | <th> <a |
| 2426 | href="identifier-index.html">Indices</a> </th> |
| 2427 | |
| 2428 | <!-- Help link --> |
| 2429 | <th> <a |
| 2430 | href="help.html">Help</a> </th> |
| 2431 | |
| 2432 | <!-- Project homepage --> |
| 2433 | <th class="navbar" align="right" width="100%"> |
| 2434 | <table border="0" cellpadding="0" cellspacing="0"> |
| 2435 | <tr><th class="navbar" align="center" |
| 2436 | >TestON</th> |
| 2437 | </tr></table></th> |
| 2438 | </tr> |
| 2439 | </table> |
| 2440 | <table border="0" cellpadding="0" cellspacing="0" width="100%%"> |
| 2441 | <tr> |
| 2442 | <td align="left" class="footer"> |
| 2443 | Generated by Epydoc 3.0.1 on Mon Aug 10 11:12:38 2015 |
| 2444 | </td> |
| 2445 | <td align="right" class="footer"> |
| 2446 | <a target="mainFrame" href="http://epydoc.sourceforge.net" |
| 2447 | >http://epydoc.sourceforge.net</a> |
| 2448 | </td> |
| 2449 | </tr> |
| 2450 | </table> |
| 2451 | |
| 2452 | <script type="text/javascript"> |
| 2453 | <!-- |
| 2454 | // Private objects are initially displayed (because if |
| 2455 | // javascript is turned off then we want them to be |
| 2456 | // visible); but by default, we want to hide them. So hide |
| 2457 | // them unless we have a cookie that says to show them. |
| 2458 | checkCookie(); |
| 2459 | // --> |
| 2460 | </script> |
| 2461 | </body> |
| 2462 | </html> |