Fixed two of the failing tests mentioned in issue 9

This commit is contained in:
vladlosev
2008-11-22 02:26:23 +00:00
parent d4e57d12d4
commit 514265c415
3 changed files with 34 additions and 9 deletions

View File

@@ -116,6 +116,31 @@ def GetExitStatus(exit_code):
return -1 return -1
def RunCommandSuppressOutput(command, working_dir=None):
"""Changes into a specified directory, if provided, and executes a command.
Restores the old directory afterwards.
Args:
command: A command to run.
working_dir: A directory to change into.
"""
old_dir = None
try:
if working_dir is not None:
old_dir = os.getcwd()
os.chdir(working_dir)
f = os.popen(command, 'r')
f.read()
ret_code = f.close()
finally:
if old_dir is not None:
os.chdir(old_dir)
if ret_code is None:
ret_code = 0
return ret_code
def Main(): def Main():
"""Runs the unit test.""" """Runs the unit test."""

View File

@@ -100,9 +100,10 @@ class GTestXMLOutFilesTest(gtest_xml_test_utils.GTestXMLTestCase):
def _TestOutFile(self, test_name, expected_xml): def _TestOutFile(self, test_name, expected_xml):
gtest_prog_path = os.path.join(gtest_test_utils.GetBuildDir(), gtest_prog_path = os.path.join(gtest_test_utils.GetBuildDir(),
test_name) test_name)
command = "cd %s && %s --gtest_output=xml:%s &> /dev/null" % ( command = "%s --gtest_output=xml:%s" % (gtest_prog_path, self.output_dir_)
tempfile.mkdtemp(), gtest_prog_path, self.output_dir_) status = gtest_test_utils.RunCommandSuppressOutput(
status = os.system(command) command,
working_dir=tempfile.mkdtemp())
self.assertEquals(0, gtest_test_utils.GetExitStatus(status)) self.assertEquals(0, gtest_test_utils.GetExitStatus(status))
# TODO(wan@google.com): libtool causes the built test binary to be # TODO(wan@google.com): libtool causes the built test binary to be

View File

@@ -131,9 +131,9 @@ class GTestXMLOutputUnitTest(gtest_xml_test_utils.GTestXMLTestCase):
if e.errno != errno.ENOENT: if e.errno != errno.ENOENT:
raise raise
status = os.system("cd %s && %s %s=xml &> /dev/null" status = gtest_test_utils.RunCommandSuppressOutput(
% (temp_dir, gtest_prog_path, "%s %s=xml" % (gtest_prog_path, GTEST_OUTPUT_FLAG),
GTEST_OUTPUT_FLAG)) working_dir=temp_dir)
self.assertEquals(0, gtest_test_utils.GetExitStatus(status)) self.assertEquals(0, gtest_test_utils.GetExitStatus(status))
self.assert_(os.path.isfile(output_file)) self.assert_(os.path.isfile(output_file))
@@ -150,9 +150,8 @@ class GTestXMLOutputUnitTest(gtest_xml_test_utils.GTestXMLTestCase):
gtest_prog_path = os.path.join(gtest_test_utils.GetBuildDir(), gtest_prog_path = os.path.join(gtest_test_utils.GetBuildDir(),
gtest_prog_name) gtest_prog_name)
command = ("%s %s=xml:%s &> /dev/null" command = ("%s %s=xml:%s" % (gtest_prog_path, GTEST_OUTPUT_FLAG, xml_path))
% (gtest_prog_path, GTEST_OUTPUT_FLAG, xml_path)) status = gtest_test_utils.RunCommandSuppressOutput(command)
status = os.system(command)
if os.WIFSIGNALED(status): if os.WIFSIGNALED(status):
signal = os.WTERMSIG(status) signal = os.WTERMSIG(status)
self.assert_(False, self.assert_(False,