Commit 64574318 authored by Stefan Behnel's avatar Stefan Behnel

fix PYTHONPATH handling for end-to-end tests

parent 2764fcdc
...@@ -1057,14 +1057,14 @@ class EndToEndTest(unittest.TestCase): ...@@ -1057,14 +1057,14 @@ class EndToEndTest(unittest.TestCase):
self.treefile = treefile self.treefile = treefile
self.workdir = os.path.join(workdir, self.name) self.workdir = os.path.join(workdir, self.name)
self.cleanup_workdir = cleanup_workdir self.cleanup_workdir = cleanup_workdir
cython_syspath = self.cython_root cython_syspath = [self.cython_root]
for path in sys.path[::-1]: for path in sys.path:
if path.startswith(self.cython_root): if path.startswith(self.cython_root) and path not in cython_syspath:
# Py3 installation and refnanny build prepend their # Py3 installation and refnanny build prepend their
# fixed paths to sys.path => prefer that over the # fixed paths to sys.path => prefer that over the
# generic one # generic one (cython_root itself goes last)
cython_syspath = path + os.pathsep + cython_syspath cython_syspath.append(path)
self.cython_syspath = cython_syspath self.cython_syspath = os.pathsep.join(cython_syspath[::-1])
unittest.TestCase.__init__(self) unittest.TestCase.__init__(self)
def shortDescription(self): def shortDescription(self):
...@@ -1100,9 +1100,9 @@ class EndToEndTest(unittest.TestCase): ...@@ -1100,9 +1100,9 @@ class EndToEndTest(unittest.TestCase):
commands = (self.commands commands = (self.commands
.replace("CYTHON", "PYTHON %s" % os.path.join(self.cython_root, 'cython.py')) .replace("CYTHON", "PYTHON %s" % os.path.join(self.cython_root, 'cython.py'))
.replace("PYTHON", sys.executable)) .replace("PYTHON", sys.executable))
old_path = os.environ.get('PYTHONPATH')
os.environ['PYTHONPATH'] = self.cython_syspath + os.pathsep + (old_path or '')
try: try:
old_path = os.environ.get('PYTHONPATH')
os.environ['PYTHONPATH'] = self.cython_syspath + os.pathsep + os.path.join(self.cython_syspath, (old_path or ''))
for command in commands.split('\n'): for command in commands.split('\n'):
p = subprocess.Popen(commands, p = subprocess.Popen(commands,
stderr=subprocess.PIPE, stderr=subprocess.PIPE,
......
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