-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathmain.py
118 lines (97 loc) · 3.4 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
from __future__ import print_function
import argparse
import json
import os
import shutil
import subprocess
import xmlrpclib
from multiprocessing.dummy import Pool
PYPI = xmlrpclib.ServerProxy('https://pypi.python.org/pypi')
PATH = "/tmp/pypy.space"
PIP_CACHE = "/tmp/pipcache"
REQUIREMENTS_DIR = 'requirements'
REQUIREMENTS_HOST_DIR = os.path.join(os.getcwd(), REQUIREMENTS_DIR)
REQUIREMENTS_CONTAINER_DIR = os.path.join('/root', REQUIREMENTS_DIR)
virtualenv_name = None
BASE_DOCKER_COMMAND = [
'docker', 'run',
'-e' 'LC_CTYPE=en_US.UTF8',
'-e' 'LANG=en_US.UTF8',
'-e' 'LANGUAGE=en_US.UTF8',
'-v', '{}:{}'.format(
REQUIREMENTS_HOST_DIR, REQUIREMENTS_CONTAINER_DIR),
'-v', '{}:/pipcache'.format(PIP_CACHE),
'pypypackages_pypy:latest'
]
def thing(args):
name, count = args
print("=" * 30, name, 'starting pip install', '='*30)
base_pip_cmd = [
os.path.join(virtualenv_name, 'bin/pip'),
'--cache-dir=/pipcache',
'install']
requirements_file = os.path.join('requirements', name)
if os.path.isfile(requirements_file):
pip_cmd = base_pip_cmd + ['-r', requirements_file]
else:
pip_cmd = base_pip_cmd + [name]
p = subprocess.Popen(BASE_DOCKER_COMMAND + pip_cmd,
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT)
stdout, _ = p.communicate()
print("=" * 30, name, p.returncode, "=" * 30)
print(stdout)
return name, p.returncode, stdout, count
def main():
global virtualenv_name
parser = argparse.ArgumentParser()
parser.add_argument(
'--parallel', help='Number of concurrent processes', type=int,
default=50)
parser.add_argument(
'--filter', nargs='*',
help='Filter to these packages')
parser.add_argument(
'--virtualenv', default='pypy3_venv',
help='Python virtualenv for package installation')
args = parser.parse_args()
virtualenv_name = args.virtualenv
if os.path.exists(PATH):
shutil.rmtree(PATH)
os.makedirs(PATH)
pool = Pool(processes=args.parallel)
top_packages = []
with open('downloads.csv', 'rt') as fid:
for line in fid:
try:
vals = line.split(',')
top_packages.append((vals[0], int(vals[1])))
except:
continue
if args.filter:
filter_ = {p for p in args.filter}
top_packages = [p for p in top_packages if p[0] in filter_]
results = pool.map(thing, top_packages)
pool.close()
pool.join()
p = subprocess.Popen(BASE_DOCKER_COMMAND + [
os.path.join(virtualenv_name, 'bin/python'), '-c',
"import sys, os; print(sys.version);"],
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT)
stdout, stderr = p.communicate()
print("=" * 30, 'python', "=" * 30)
print(stdout)
print(stderr)
print("=" * 30, 'python', "=" * 30)
index = []
for name, status, output, count in results:
output_log = '%s.txt' % name
with open(os.path.join(PATH, output_log), 'w') as f:
f.write(output)
index.append((name, {"status": status,
"count": count,
"log": output_log}))
json.dump(index, open(os.path.join(PATH, "index.json"), 'w'), indent=2)
if __name__ == '__main__':
main()