forked from erikbern/ann-benchmarks
-
Notifications
You must be signed in to change notification settings - Fork 1
/
install.py
70 lines (58 loc) · 2.06 KB
/
install.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
import json
import os
import argparse
import subprocess
from multiprocessing import Pool
from ann_benchmarks.main import positive_int
def build(library, args):
print('Building %s...' % library)
if args is not None and len(args) != 0:
q = " ".join(["--build-arg " + x.replace(" ", "\\ ") for x in args])
else:
q = ""
try:
subprocess.check_call(
'docker build %s --rm -t ann-benchmarks-%s -f'
' install/Dockerfile.%s .' % (q, library, library), shell=True)
return {library: 'success'}
except subprocess.CalledProcessError:
return {library: 'fail'}
def build_multiprocess(args):
return build(*args)
if __name__ == "__main__":
parser = argparse.ArgumentParser(
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument(
"--proc",
default=1,
type=positive_int,
help="the number of process to build docker images")
parser.add_argument(
'--algorithm',
metavar='NAME',
help='build only the named algorithm image',
default=None)
parser.add_argument(
'--build-arg',
help='pass given args to all docker builds',
nargs="+")
args = parser.parse_args()
print('Building base image...')
subprocess.check_call(
'docker build \
--rm -t ann-benchmarks -f install/Dockerfile .', shell=True)
if args.algorithm:
tags = [args.algorithm]
elif os.getenv('LIBRARY'):
tags = [os.getenv('LIBRARY')]
else:
tags = [fn.split('.')[-1] for fn in os.listdir('install') if fn.startswith('Dockerfile.')]
print('Building algorithm images... with (%d) processes' % args.proc)
if args.proc == 1:
install_status = [build(tag, args.build_arg) for tag in tags]
else:
pool = Pool(processes=args.proc)
install_status = pool.map(build_multiprocess, [(tag, args.build_arg) for tag in tags])
pool.close()
pool.join()
print('\n\nInstall Status:\n' + '\n'.join(str(algo) for algo in install_status))