Commit fab452fa authored by Stefan Behnel's avatar Stefan Behnel

use completely separate workspaces for tests to fix cleanup on failures (and...

use completely separate workspaces for tests to fix cleanup on failures (and to make sharding/parallel test runs straight forward)
parent f5a6bc37
...@@ -426,9 +426,10 @@ class TestBuilder(object): ...@@ -426,9 +426,10 @@ class TestBuilder(object):
def build_test(self, test_class, path, workdir, module, def build_test(self, test_class, path, workdir, module,
language, expect_errors, warning_errors): language, expect_errors, warning_errors):
workdir = os.path.join(workdir, language) language_workdir = os.path.join(workdir, language)
if not os.path.exists(workdir): if not os.path.exists(language_workdir):
os.makedirs(workdir) os.makedirs(language_workdir)
workdir = os.path.join(language_workdir, module)
return test_class(path, workdir, module, return test_class(path, workdir, module,
language=language, language=language,
expect_errors=expect_errors, expect_errors=expect_errors,
...@@ -471,6 +472,8 @@ class CythonCompileTestCase(unittest.TestCase): ...@@ -471,6 +472,8 @@ class CythonCompileTestCase(unittest.TestCase):
self._saved_default_directives = Options.directive_defaults.items() self._saved_default_directives = Options.directive_defaults.items()
Options.warning_errors = self.warning_errors Options.warning_errors = self.warning_errors
if not os.path.exists(self.workdir):
os.makedirs(self.workdir)
if self.workdir not in sys.path: if self.workdir not in sys.path:
sys.path.insert(0, self.workdir) sys.path.insert(0, self.workdir)
...@@ -492,24 +495,25 @@ class CythonCompileTestCase(unittest.TestCase): ...@@ -492,24 +495,25 @@ class CythonCompileTestCase(unittest.TestCase):
cleanup_c_files = WITH_CYTHON and self.cleanup_workdir and cleanup cleanup_c_files = WITH_CYTHON and self.cleanup_workdir and cleanup
cleanup_lib_files = self.cleanup_sharedlibs and cleanup cleanup_lib_files = self.cleanup_sharedlibs and cleanup
if os.path.exists(self.workdir): if os.path.exists(self.workdir):
for rmfile in os.listdir(self.workdir): if cleanup_c_files and cleanup_lib_files:
if not cleanup_c_files: shutil.rmtree(self.workdir, ignore_errors=True)
if (rmfile[-2:] in (".c", ".h") or else:
rmfile[-4:] == ".cpp" or for rmfile in os.listdir(self.workdir):
rmfile.endswith(".html")): if not cleanup_c_files:
if (rmfile[-2:] in (".c", ".h") or
rmfile[-4:] == ".cpp" or
rmfile.endswith(".html")):
continue
if not cleanup_lib_files and (rmfile.endswith(".so") or rmfile.endswith(".dll")):
continue continue
if not cleanup_lib_files and (rmfile.endswith(".so") or rmfile.endswith(".dll")): try:
continue rmfile = os.path.join(self.workdir, rmfile)
try: if os.path.isdir(rmfile):
rmfile = os.path.join(self.workdir, rmfile) shutil.rmtree(rmfile, ignore_errors=True)
if os.path.isdir(rmfile): else:
shutil.rmtree(rmfile, ignore_errors=True) os.remove(rmfile)
else: except IOError:
os.remove(rmfile) pass
except IOError:
pass
else:
os.makedirs(self.workdir)
def runTest(self): def runTest(self):
self.success = False self.success = False
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment