forked from erikbern/ann-benchmarks
-
Notifications
You must be signed in to change notification settings - Fork 2
/
install.py
68 lines (54 loc) · 2.17 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
import argparse
import os
import subprocess
import sys
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" " ann_benchmarks/algorithms/%s/Dockerfile ." % (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 ann_benchmarks/algorithms/base/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("ann_benchmarks/algorithms")]
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))
# Exit 1 if any of the installations fail.
for x in install_status:
for (k, v) in x.items():
if v == "fail":
sys.exit(1)