diff options
author | Linda Wang <wangwulin@huawei.com> | 2017-12-29 03:33:26 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@opnfv.org> | 2017-12-29 03:33:26 +0000 |
commit | ba6bd3ef221dc56a1ea2f74a1bc4d32d6fa21465 (patch) | |
tree | 2be480b05138053707ffd8d60adb45731c7cef6b /functest/core | |
parent | b58febe005c60bbd54fd069eecac707072fcdeeb (diff) | |
parent | 77d598a882652801b2ddf480c34d896f745657dc (diff) |
Merge "Execute feature command by subprocess directly"
Diffstat (limited to 'functest/core')
-rw-r--r-- | functest/core/feature.py | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/functest/core/feature.py b/functest/core/feature.py index 2dc3ccbd..3200dad8 100644 --- a/functest/core/feature.py +++ b/functest/core/feature.py @@ -14,10 +14,10 @@ helpers to run any python method or any bash command. """ import logging +import subprocess import time import functest.core.testcase as base -import functest.utils.functest_utils as ft_utils from functest.utils.constants import CONST __author__ = ("Serena Feng <feng.xiaowei@zte.com.cn>, " @@ -123,9 +123,12 @@ class BashFeature(Feature): ret = -1 try: cmd = kwargs["cmd"] - ret = ft_utils.execute_command(cmd, output_file=self.result_file) + with open(self.result_file, 'w+') as f_stdout: + proc = subprocess.Popen(cmd.split(), stdout=f_stdout, + stderr=subprocess.STDOUT) + ret = proc.wait() + if ret != 0: + self.__logger.error("Execute command: %s failed", cmd) except KeyError: self.__logger.error("Please give cmd as arg. kwargs: %s", kwargs) - except Exception: # pylint: disable=broad-except - self.__logger.exception("Execute cmd: %s failed", cmd) return ret |