mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
testCase level logger and testClient class attr
reviewed-by: Chirag Jog Each testCase class will use its own logger to distinguish log messages when multiple suites are run. This will aid debugging Every cloudstackTestCase will also contiain a class level attr of the testClient which was previously available only to setUp/tearDown. Now even setUpClass/tearDownClass can use this attribute.
This commit is contained in:
parent
56dd6e81ac
commit
52202839fb
@ -8,8 +8,6 @@ import os
|
|||||||
import sys
|
import sys
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
module_logger = "testclient.testcase"
|
|
||||||
|
|
||||||
def testCaseLogger(message, logger=None):
|
def testCaseLogger(message, logger=None):
|
||||||
if logger is not None:
|
if logger is not None:
|
||||||
logger.debug(message)
|
logger.debug(message)
|
||||||
@ -18,18 +16,19 @@ class TestCaseExecuteEngine(object):
|
|||||||
def __init__(self, testclient, testCaseFolder, testcaseLogFile=None, testResultLogFile=None):
|
def __init__(self, testclient, testCaseFolder, testcaseLogFile=None, testResultLogFile=None):
|
||||||
self.testclient = testclient
|
self.testclient = testclient
|
||||||
self.testCaseFolder = testCaseFolder
|
self.testCaseFolder = testCaseFolder
|
||||||
self.logger = None
|
self.logformat = logging.Formatter("%(asctime)s - %(levelname)s - %(name)s - %(message)s")
|
||||||
|
|
||||||
if testcaseLogFile is not None:
|
if testcaseLogFile is not None:
|
||||||
logger = logging.getLogger("testclient.testcase.TestCaseExecuteEngine")
|
self.logfile = testcaseLogFile
|
||||||
fh = logging.FileHandler(testcaseLogFile)
|
self.logger = logging.getLogger("TestCaseExecuteEngine")
|
||||||
fh.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(name)s - %(message)s"))
|
fh = logging.FileHandler(self.logfile)
|
||||||
logger.addHandler(fh)
|
fh.setFormatter(self.logformat)
|
||||||
logger.setLevel(logging.DEBUG)
|
self.logger.addHandler(fh)
|
||||||
self.logger = logger
|
self.logger.setLevel(logging.DEBUG)
|
||||||
if testResultLogFile is not None:
|
if testResultLogFile is not None:
|
||||||
ch = logging.StreamHandler()
|
ch = logging.StreamHandler()
|
||||||
ch.setLevel(logging.ERROR)
|
ch.setLevel(logging.ERROR)
|
||||||
ch.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(name)s - %(message)s"))
|
ch.setFormatter(self.logformat)
|
||||||
self.logger.addHandler(ch)
|
self.logger.addHandler(ch)
|
||||||
fp = open(testResultLogFile, "w")
|
fp = open(testResultLogFile, "w")
|
||||||
self.testResultLogFile = fp
|
self.testResultLogFile = fp
|
||||||
@ -41,8 +40,18 @@ class TestCaseExecuteEngine(object):
|
|||||||
if isinstance(test, unittest.BaseTestSuite):
|
if isinstance(test, unittest.BaseTestSuite):
|
||||||
self.injectTestCase(test)
|
self.injectTestCase(test)
|
||||||
else:
|
else:
|
||||||
|
#logger bears the name of the test class
|
||||||
|
testcaselogger = logging.getLogger("testclient.testcase.%s"%test.__class__.__name__)
|
||||||
|
fh = logging.FileHandler(self.logfile)
|
||||||
|
fh.setFormatter(self.logformat)
|
||||||
|
testcaselogger.addHandler(fh)
|
||||||
|
testcaselogger.setLevel(logging.DEBUG)
|
||||||
|
|
||||||
|
#inject testclient and logger into each unittest
|
||||||
setattr(test, "testClient", self.testclient)
|
setattr(test, "testClient", self.testclient)
|
||||||
setattr(test, "debug", partial(testCaseLogger, logger=self.logger))
|
setattr(test, "debug", partial(testCaseLogger, logger=testcaselogger))
|
||||||
|
setattr(test.__class__, "clstestclient", self.testclient)
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
loader = unittest.loader.TestLoader()
|
loader = unittest.loader.TestLoader()
|
||||||
suite = loader.discover(self.testCaseFolder)
|
suite = loader.discover(self.testCaseFolder)
|
||||||
|
|||||||
@ -6,6 +6,12 @@ except ImportError:
|
|||||||
import cloudstackTestClient
|
import cloudstackTestClient
|
||||||
|
|
||||||
class cloudstackTestCase(unittest.case.TestCase):
|
class cloudstackTestCase(unittest.case.TestCase):
|
||||||
|
clstestclient = None
|
||||||
|
|
||||||
def __init__(self, args):
|
def __init__(self, args):
|
||||||
unittest.case.TestCase.__init__(self, args)
|
unittest.case.TestCase.__init__(self, args)
|
||||||
self.testClient = cloudstackTestClient.cloudstackTestClient()
|
self.testClient = cloudstackTestClient.cloudstackTestClient()
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def getClsTestClient(cls):
|
||||||
|
return cls.clstestclient
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user