<p>pespin <strong>submitted</strong> this change.</p><p><a href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/17124">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;">Add handlers to run process under a specific netns on a remote host<br><br>It will be used later to run iiperf3-cli connected to srsue on another host.<br><br>Change-Id: I8d223fc302df42446f5876ba020cfbea94be09b9<br>---<br>M src/osmo_gsm_tester/process.py<br>M src/osmo_gsm_tester/remote.py<br>2 files changed, 10 insertions(+), 0 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/src/osmo_gsm_tester/process.py b/src/osmo_gsm_tester/process.py</span><br><span>index 3880630..2735c6a 100644</span><br><span>--- a/src/osmo_gsm_tester/process.py</span><br><span>+++ b/src/osmo_gsm_tester/process.py</span><br><span>@@ -396,6 +396,12 @@</span><br><span>         kill_cmd = ('kill', '-%d' % int(sig), str(self.process_obj.pid))</span><br><span>         run_local_netns_sync(self.run_dir, self.name()+"-kill"+str(sig), self.netns, kill_cmd)</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+class RemoteNetNSProcess(RemoteProcess):</span><br><span style="color: hsl(120, 100%, 40%);">+    NETNS_EXEC_BIN = 'osmo-gsm-tester_netns_exec.sh'</span><br><span style="color: hsl(120, 100%, 40%);">+    def __init__(self, name, run_dir, remote_user, remote_host, remote_cwd, netns, popen_args, **popen_kwargs):</span><br><span style="color: hsl(120, 100%, 40%);">+        args = ['sudo', self.NETNS_EXEC_BIN, self.netns] + list(popen_args)</span><br><span style="color: hsl(120, 100%, 40%);">+        super().__init__(name, run_dir, remote_user, remote_host, remote_cwd, args, **popen_kwargs)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.netns = netns</span><br><span> </span><br><span> def run_local_sync(run_dir, name, popen_args):</span><br><span>     run_dir =run_dir.new_dir(name)</span><br><span>diff --git a/src/osmo_gsm_tester/remote.py b/src/osmo_gsm_tester/remote.py</span><br><span>index 6be0a5e..771f2b8 100644</span><br><span>--- a/src/osmo_gsm_tester/remote.py</span><br><span>+++ b/src/osmo_gsm_tester/remote.py</span><br><span>@@ -93,6 +93,10 @@</span><br><span>         args = (remote_wrapper_script,) + popen_args</span><br><span>         return self.RemoteProcess(name, args, remote_env, **popen_kwargs)</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+    def RemoteNetNSProcess(self, name, netns, popen_args, **popen_kwargs):</span><br><span style="color: hsl(120, 100%, 40%);">+        run_dir = self.run_dir.new_dir(name)</span><br><span style="color: hsl(120, 100%, 40%);">+        return self.RemoteNetNSProcess(name, run_dir, self.user(), self.host(), self.cwd(), netns, popen_args, **popen_kwargs)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>     def run_remote_sync(self, name, popen_args):</span><br><span>         proc = self.RemoteProcess(name, popen_args, remote_env=self.remote_env)</span><br><span>         proc.launch_sync()</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/17124">change 17124</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/+/17124"/><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: I8d223fc302df42446f5876ba020cfbea94be09b9 </div>
<div style="display:none"> Gerrit-Change-Number: 17124 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: pespin <pespin@sysmocom.de> </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>