aboutsummaryrefslogtreecommitdiffstats
path: root/python/mach_bootstrap.py
diff options
context:
space:
mode:
authorCorey Farwell <coreyf@rwell.org>2015-08-09 13:17:26 -0400
committerCorey Farwell <coreyf@rwell.org>2015-09-02 09:34:01 -0400
commite38df50bbf2d8c33aa53ce8ce1fc2b84e9b22814 (patch)
treebd4c83e8e6f185bcaa5665e25084967f854ce99b /python/mach_bootstrap.py
parent759c52d7eb62f69f31258927558eb5cb985ef47c (diff)
downloadservo-e38df50bbf2d8c33aa53ce8ce1fc2b84e9b22814.tar.gz
servo-e38df50bbf2d8c33aa53ce8ce1fc2b84e9b22814.zip
Revert "Revert "Auto merge of #7103 - frewsxcv:python-venv, r=metajack" for breaking web-platform-tests."
This reverts commit 47d6d958f58f5011742a18abcdd5a76bf4390966.
Diffstat (limited to 'python/mach_bootstrap.py')
-rw-r--r--python/mach_bootstrap.py37
1 files changed, 37 insertions, 0 deletions
diff --git a/python/mach_bootstrap.py b/python/mach_bootstrap.py
index 84de5b22b25..e04d1781bdd 100644
--- a/python/mach_bootstrap.py
+++ b/python/mach_bootstrap.py
@@ -6,7 +6,9 @@ from __future__ import print_function, unicode_literals
import os
import platform
+import subprocess
import sys
+from distutils.spawn import find_executable
SEARCH_PATHS = [
"python/mach",
@@ -73,6 +75,39 @@ CATEGORIES = {
}
+def _get_exec(name, default=None):
+ path = find_executable(name)
+ if not path:
+ return default
+ return path
+
+
+def _activate_virtualenv(topdir):
+ virtualenv_path = os.path.join(topdir, "python", "_virtualenv")
+ python = _get_exec("python2", "python")
+
+ if not os.path.exists(virtualenv_path):
+ virtualenv = _get_exec("virtualenv2", "virtualenv")
+ subprocess.check_call([virtualenv, "-p", python, virtualenv_path])
+
+ activate_path = os.path.join(virtualenv_path, "bin", "activate_this.py")
+ execfile(activate_path, dict(__file__=activate_path))
+
+ # TODO: Right now, we iteratively install all the requirements by invoking
+ # `pip install` each time. If it were the case that there were conflicting
+ # requirements, we wouldn't know about them. Once
+ # https://github.com/pypa/pip/issues/988 is addressed, then we can just
+ # chain each of the requirements files into the same `pip install` call
+ # and it will check for conflicts.
+ requirements_paths = [
+ os.path.join(topdir, "python", "requirements.txt"),
+ os.path.join(topdir, "tests", "wpt", "harness", "requirements.txt"),
+ os.path.join(topdir, "tests", "wpt", "harness", "requirements_servo.txt"),
+ ]
+ for path in requirements_paths:
+ subprocess.check_call(["pip", "install", "-q", "-r", path])
+
+
def bootstrap(topdir):
topdir = os.path.abspath(topdir)
@@ -84,6 +119,8 @@ def bootstrap(topdir):
print('You are running Python', platform.python_version())
sys.exit(1)
+ _activate_virtualenv(topdir)
+
def populate_context(context, key=None):
if key is None:
return