test: build src/allmydata/_version.py
$(PYTHON) setup.py test $(TRIALARGS) -s $(TEST)
-quicktest: .built .checked-deps
- $(PYTHON) setup.py test $(TRIALARGS) -s $(TEST)
-
fuse-test: .built .checked-deps
$(RUNPP) -d contrib/fuse -p -c runtests.py
rm -f .figleaf
$(PYTHON) setup.py trial --reporter=bwverbose-figleaf -s $(TEST)
-quicktest-figleaf: src/allmydata/_version.py
+quicktest:
+ $(PYTHON) misc/run-with-pythonpath.py trial $(TRIALARGS) $(TEST)
+
+quicktest-figleaf:
rm -f .figleaf
- $(PYTHON) setup.py trial --reporter=bwverbose-figleaf -s $(TEST)
+ $(PYTHON) misc/run-with-pythonpath.py trial --reporter=bwverbose-figleaf $(TEST)
figleaf-output:
$(RUNPP) -p -c "misc/figleaf2html -d coverage-html -r src -x misc/figleaf.excludes"
--- /dev/null
+# -*- python -*-
+# you must invoke this with an explicit python, from the tree root
+
+"""Run an arbitrary command with a PYTHONPATH that will include the Tahoe
+code, including dependent libraries. Run this like:
+
+ python misc/run-with-pythonpath.py python foo.py
+or
+ python misc/run-with-pythonpath.py trial -r poll allmydata.test.test_util
+
+"""
+
+import os, sys, subprocess
+
+# figure out where support/lib/pythonX.X/site-packages is
+# add it to os.environ["PYTHONPATH"]
+# spawn the child process
+
+
+def pylibdir(prefixdir):
+ pyver = "python%d.%d" % (sys.version_info[:2])
+ if sys.platform == "win32":
+ return os.path.join(prefixdir, "Lib", "site-packages")
+ else:
+ return os.path.join(prefixdir, "lib", pyver, "site-packages")
+
+basedir = os.path.dirname(os.path.abspath(__file__))
+supportlib = pylibdir(os.path.abspath("support"))
+
+oldpp = os.environ.get("PYTHONPATH", "").split(os.pathsep)
+if oldpp == [""]:
+ # grr silly split() behavior
+ oldpp = []
+newpp = os.pathsep.join(oldpp + [supportlib,])
+os.environ['PYTHONPATH'] = newpp
+
+command = sys.argv[1:]
+rc = subprocess.call(command)
+sys.exit(rc)