Merge "Use salt for file management"
diff --git a/tcp_tests/managers/k8smanager.py b/tcp_tests/managers/k8smanager.py
index 2aea092..d229e2f 100644
--- a/tcp_tests/managers/k8smanager.py
+++ b/tcp_tests/managers/k8smanager.py
@@ -356,11 +356,11 @@
raise RuntimeError("Conformance failed")
def move_file_to_root_folder(self, filepath):
- cmd = "mv {0} /root/".format(filepath)
+ # Using || true to avoid salt fails if no file found
+ cmd = "mv {0} /root/ || true".format(filepath)
if self.conformance_node:
- self.__underlay.check_call(
- cmd=cmd, node_name=self.conformance_node,
- raise_on_err=False)
+ LOG.info("Managing results on {}".format(self.conformance_node))
+ self._salt.cmd_run(tgt=self.conformance_node, cmd=cmd)
else:
LOG.info("Node is not properly set")
@@ -437,18 +437,17 @@
else:
node = self.controller_name
LOG.info("Trying to combine xunit at {}".format(node))
- with self.__underlay.remote(node_name=node) as r:
- cmd = ("apt-get install python-setuptools -y; "
- "pip install "
- "https://github.com/mogaika/xunitmerge/archive/master.zip")
- LOG.debug('Installing xunitmerge')
- r.check_call(cmd, raise_on_err=False)
- LOG.debug('Merging xunit')
- cmd = ("cd {0}; arg=''; "
- "for i in $(ls | grep xml); "
- "do arg=\"$arg $i\"; done && "
- "xunitmerge $arg {1}".format(path, output))
- r.check_call(cmd, raise_on_err=False)
+ cmd = ("apt-get install python-setuptools -y; "
+ "pip install "
+ "https://github.com/mogaika/xunitmerge/archive/master.zip")
+ LOG.debug('Installing xunitmerge')
+ self._salt.cmd_run(tgt=node, cmd=cmd)
+ LOG.debug('Merging xunit')
+ cmd = ("cd {0}; arg=''; "
+ "for i in $(ls | grep xml); "
+ "do arg=\"$arg $i\"; done && "
+ "xunitmerge $arg {1} || true".format(path, output))
+ self._salt.cmd_run(tgt=node, cmd=cmd)
def manage_cncf_archive(self):
"""
diff --git a/tcp_tests/managers/saltmanager.py b/tcp_tests/managers/saltmanager.py
index a468b02..8ef817a 100644
--- a/tcp_tests/managers/saltmanager.py
+++ b/tcp_tests/managers/saltmanager.py
@@ -248,6 +248,10 @@
result = self.local(tgt=tgt, fun='service.stop', args=service)
return result['return']
+ def cmd_run(self, tgt, cmd):
+ result = self.local(tgt=tgt, fun='cmd.run', args=cmd)
+ return result['return']
+
@utils.retry(3, exception=libpepper.PepperException)
def sync_time(self, tgt='*'):
LOG.info("NTP time sync on the salt minions '{0}'".format(tgt))