<p>pespin <strong>submitted</strong> this change.</p><p><a href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/24278">View Change</a></p><div style="white-space:pre-wrap">Approvals:
  Jenkins Builder: Verified
  pespin: Looks good to me, approved

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">srs-enb: runs the given list of scripts before and after launching the eNodeB.<br><br>Allows to run given scripts before and after the execution of the SRS<br>eNodeB. The scripts are retrieved as a list from the resource.conf file.<br><br>Change-Id: I5017caae933809b89b32ea132be8552d6554e20e<br>---<br>M src/osmo_gsm_tester/obj/enb_srs.py<br>1 file changed, 72 insertions(+), 0 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/src/osmo_gsm_tester/obj/enb_srs.py b/src/osmo_gsm_tester/obj/enb_srs.py</span><br><span>index 708e63a..703fb2e 100644</span><br><span>--- a/src/osmo_gsm_tester/obj/enb_srs.py</span><br><span>+++ b/src/osmo_gsm_tester/obj/enb_srs.py</span><br><span>@@ -29,6 +29,12 @@</span><br><span> from ..core import schema</span><br><span> </span><br><span> def on_register_schemas():</span><br><span style="color: hsl(120, 100%, 40%);">+    resource_schema = {</span><br><span style="color: hsl(120, 100%, 40%);">+        'prerun_scripts[]': schema.STR,</span><br><span style="color: hsl(120, 100%, 40%);">+        'postrun_scripts[]': schema.STR,</span><br><span style="color: hsl(120, 100%, 40%);">+        }</span><br><span style="color: hsl(120, 100%, 40%);">+    schema.register_resource_schema('enb', resource_schema)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>     config_schema = {</span><br><span>         'enable_pcap': schema.BOOL_STR,</span><br><span>         'enable_tracing': schema.BOOL_STR,</span><br><span>@@ -100,6 +106,10 @@</span><br><span>         # Make sure we give the UE time to tear down</span><br><span>         self.sleep_after_stop()</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+        # Execute the post run tasks.</span><br><span style="color: hsl(120, 100%, 40%);">+        if not self.postrun_tasks():</span><br><span style="color: hsl(120, 100%, 40%);">+            self.log('Could not execute the post run tasks')</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>         # copy back files (may not exist, for instance if there was an early error of process):</span><br><span>         self.scp_back_metrics(raiseException=False)</span><br><span> </span><br><span>@@ -151,11 +161,73 @@</span><br><span>         else:</span><br><span>             self.dbg('Metrics have already been copied back')</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+    def run_task(self, task):</span><br><span style="color: hsl(120, 100%, 40%);">+        # Get the arguments.</span><br><span style="color: hsl(120, 100%, 40%);">+        args_index = task.find('args=')</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        args = ()</span><br><span style="color: hsl(120, 100%, 40%);">+        # No arguments, all the string is the script.</span><br><span style="color: hsl(120, 100%, 40%);">+        if args_index == -1:</span><br><span style="color: hsl(120, 100%, 40%);">+            index = task.rfind('/')</span><br><span style="color: hsl(120, 100%, 40%);">+            task_name = task [index + 1:]</span><br><span style="color: hsl(120, 100%, 40%);">+            run_dir = util.Dir(self.run_dir.new_dir(task_name))</span><br><span style="color: hsl(120, 100%, 40%);">+            args = (task,)</span><br><span style="color: hsl(120, 100%, 40%);">+            self.log(f'task name is: {task_name}')</span><br><span style="color: hsl(120, 100%, 40%);">+            self.log(f'Running the script: {task} in the run dir: {run_dir}')</span><br><span style="color: hsl(120, 100%, 40%);">+        else:</span><br><span style="color: hsl(120, 100%, 40%);">+            ntask = task[:args_index - 1]</span><br><span style="color: hsl(120, 100%, 40%);">+            index = ntask.rfind('/')</span><br><span style="color: hsl(120, 100%, 40%);">+            task_name = ntask [index + 1:]</span><br><span style="color: hsl(120, 100%, 40%);">+            run_dir = util.Dir(self.run_dir.new_dir(task_name))</span><br><span style="color: hsl(120, 100%, 40%);">+            args = (ntask,)</span><br><span style="color: hsl(120, 100%, 40%);">+            args += tuple(task[args_index + 5:].split(','))</span><br><span style="color: hsl(120, 100%, 40%);">+            self.log(f'task name is: {task_name}')</span><br><span style="color: hsl(120, 100%, 40%);">+            self.log(f'Running the script: {task} in the run dir: {run_dir} with args: {args}')</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        proc = process.Process(task_name, run_dir, args)</span><br><span style="color: hsl(120, 100%, 40%);">+        # Set the timeout to a high value 20 minutes.</span><br><span style="color: hsl(120, 100%, 40%);">+        proc.set_default_wait_timeout(1200)</span><br><span style="color: hsl(120, 100%, 40%);">+        returncode = proc.launch_sync()</span><br><span style="color: hsl(120, 100%, 40%);">+        if returncode != 0:</span><br><span style="color: hsl(120, 100%, 40%);">+            raise log.Error('Error executing the pre run scripts. Aborting')</span><br><span style="color: hsl(120, 100%, 40%);">+            return False</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        return True</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    # Runs all the tasks that are intended to run before the execution of the eNodeb.</span><br><span style="color: hsl(120, 100%, 40%);">+    def prerun_tasks(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        prerun_tasklist = self._conf.get('prerun_scripts', None)</span><br><span style="color: hsl(120, 100%, 40%);">+        if not prerun_tasklist:</span><br><span style="color: hsl(120, 100%, 40%);">+            return True</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        for task in prerun_tasklist:</span><br><span style="color: hsl(120, 100%, 40%);">+            if not self.run_task(task):</span><br><span style="color: hsl(120, 100%, 40%);">+                return False</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        return True</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    # Runs all the tasks that are intended to run after the execution of the eNodeb.</span><br><span style="color: hsl(120, 100%, 40%);">+    def postrun_tasks(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        postrun_tasklist = self._conf.get('postrun_scripts', None)</span><br><span style="color: hsl(120, 100%, 40%);">+        if not postrun_tasklist:</span><br><span style="color: hsl(120, 100%, 40%);">+            return True</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        for task in postrun_tasklist:</span><br><span style="color: hsl(120, 100%, 40%);">+            if not self.run_task(task):</span><br><span style="color: hsl(120, 100%, 40%);">+                return False</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        return True</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>     def start(self, epc):</span><br><span>         self.log('Starting srsENB')</span><br><span>         self._epc = epc</span><br><span>         self.run_dir = util.Dir(self.testenv.test().get_run_dir().new_dir(self.name()))</span><br><span>         self.configure()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        if not self.prerun_tasks():</span><br><span style="color: hsl(120, 100%, 40%);">+            self.log('Pre run tasks failed. Aborting')</span><br><span style="color: hsl(120, 100%, 40%);">+            return</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>         if self._run_node.is_local():</span><br><span>             self.start_locally()</span><br><span>         else:</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/24278">change 24278</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.osmocom.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/24278"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: osmo-gsm-tester </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: I5017caae933809b89b32ea132be8552d6554e20e </div>
<div style="display:none"> Gerrit-Change-Number: 24278 </div>
<div style="display:none"> Gerrit-PatchSet: 3 </div>
<div style="display:none"> Gerrit-Owner: alealcon <alejandro.leal@srs.io> </div>
<div style="display:none"> Gerrit-Reviewer: Jenkins Builder </div>
<div style="display:none"> Gerrit-Reviewer: pespin <pespin@sysmocom.de> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>