aboutsummaryrefslogtreecommitdiffstats
path: root/functest/core/feature.py
diff options
context:
space:
mode:
Diffstat (limited to 'functest/core/feature.py')
-rw-r--r--functest/core/feature.py23
1 files changed, 20 insertions, 3 deletions
diff --git a/functest/core/feature.py b/functest/core/feature.py
index 29e0e927..bab1d507 100644
--- a/functest/core/feature.py
+++ b/functest/core/feature.py
@@ -1,3 +1,12 @@
+#!/usr/bin/env python
+
+# Copyright (c) 2016 ZTE Corp and others.
+#
+# All rights reserved. This program and the accompanying materials
+# are made available under the terms of the Apache License, Version 2.0
+# which accompanies this distribution, and is available at
+# http://www.apache.org/licenses/LICENSE-2.0
+
import time
import functest.core.testcase as base
@@ -16,6 +25,7 @@ class Feature(base.TestCase):
self.logger = ft_logger.Logger(self.project_name).getLogger()
def execute(self, **kwargs):
+ # pylint: disable=unused-argument,no-self-use
return -1
def run(self, **kwargs):
@@ -23,7 +33,7 @@ class Feature(base.TestCase):
exit_code = base.TestCase.EX_RUN_ERROR
self.criteria = "FAIL"
try:
- if self.execute() == 0:
+ if self.execute(**kwargs) == 0:
exit_code = base.TestCase.EX_OK
self.criteria = 'PASS'
ft_utils.logger_test_results(
@@ -40,5 +50,12 @@ class Feature(base.TestCase):
class BashFeature(Feature):
def execute(self, **kwargs):
- return ft_utils.execute_command(
- self.cmd, output_file=self.result_file)
+ ret = -1
+ try:
+ cmd = kwargs["cmd"]
+ ret = ft_utils.execute_command(cmd, output_file=self.result_file)
+ 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