2010-10-29 02:51:50 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
2010-11-02 05:33:57 +00:00
|
|
|
# We put a fake "pycryptopp-0.5.13" package on the PYTHONPATH so that
|
|
|
|
# the build system thinks pycryptopp-0.5.13 is already installed. Then
|
2010-10-29 02:51:50 +00:00
|
|
|
# we execute run_trial.py. If the build system is too naive/greedy
|
|
|
|
# about finding dependencies, it will latch onto the
|
2010-11-02 05:33:57 +00:00
|
|
|
# "pycryptopp-0.5.13" and then will be unable to satisfy the
|
|
|
|
# requirement (from _auto_deps.py) for pycryptopp >= 0.5.20 (or
|
|
|
|
# pycryptopp >= 0.5.14, depending on machine architecture). This is
|
2010-10-29 02:51:50 +00:00
|
|
|
# currently happening on trunk, see #1190. So with trunk, running
|
|
|
|
# test-with-fake-pkg.py shows a failure, but with the ticket1190
|
|
|
|
# branch, test-with-fake-pkg.py succeeds.
|
|
|
|
|
|
|
|
import glob, os, subprocess, sys
|
|
|
|
|
2010-11-02 05:33:57 +00:00
|
|
|
fakepkgdir = 'misc/build_helpers/fakepkgs'
|
2010-10-29 02:51:50 +00:00
|
|
|
fakepkgname = "pycryptopp"
|
2010-11-02 05:33:57 +00:00
|
|
|
fakepkgversion = "0.5.13"
|
2010-10-29 02:51:50 +00:00
|
|
|
testsuite = "allmydata.test.test_base62"
|
|
|
|
|
2010-11-02 05:33:57 +00:00
|
|
|
pkgdirname = os.path.join(os.getcwd(), fakepkgdir, '%s-%s.egg' % (fakepkgname, fakepkgversion))
|
2010-10-29 02:51:50 +00:00
|
|
|
|
|
|
|
try:
|
|
|
|
os.makedirs(pkgdirname)
|
|
|
|
except OSError:
|
|
|
|
# probably already exists
|
|
|
|
pass
|
|
|
|
os.chdir('src')
|
|
|
|
trial=os.path.join(os.getcwd(), '..', 'misc', 'build_helpers', 'run_trial.py')
|
|
|
|
os.environ['PATH']=os.getcwd()+os.pathsep+os.environ['PATH']
|
2010-10-30 03:43:03 +00:00
|
|
|
eggs = [os.path.realpath(p) for p in glob.glob(os.path.join('..', '*.egg'))]
|
|
|
|
os.environ['PYTHONPATH']=os.pathsep+pkgdirname+os.pathsep+os.pathsep.join(eggs)+os.pathsep+os.environ.get('PYTHONPATH','')
|
2010-10-29 02:51:50 +00:00
|
|
|
sys.exit(subprocess.call([sys.executable, trial, testsuite], env=os.environ))
|