2018-02-28 01:57:02 +08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import json
|
|
|
|
import os
|
|
|
|
import re
|
|
|
|
import subprocess
|
|
|
|
|
|
|
|
from card_fraud import NUM_MACHINES, BINARIES
|
|
|
|
|
|
|
|
# paths
|
|
|
|
SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
WORKSPACE_DIR = os.path.normpath(os.path.join(SCRIPT_DIR, "..", "..", "..", ".."))
|
|
|
|
OUTPUT_DIR_REL = os.path.join(os.path.relpath(SCRIPT_DIR, WORKSPACE_DIR), "output")
|
|
|
|
|
|
|
|
# generate runs
|
|
|
|
runs = []
|
|
|
|
|
|
|
|
binaries = list(map(lambda x: os.path.join("..", "..", "build_release", x), BINARIES))
|
|
|
|
|
|
|
|
for i in range(NUM_MACHINES):
|
|
|
|
name = "master" if i == 0 else "worker" + str(i)
|
|
|
|
additional = ["master.py"] if i == 0 else []
|
|
|
|
outfile_paths = ["\\./" + OUTPUT_DIR_REL + "/.+"] if i == 0 else []
|
|
|
|
if i == 0:
|
2018-05-14 23:26:33 +08:00
|
|
|
cmd = "master.py"
|
|
|
|
args = "--machines-num {0} --test-suite card_fraud " \
|
2018-02-28 01:57:02 +08:00
|
|
|
"--test card_fraud".format(NUM_MACHINES)
|
|
|
|
else:
|
|
|
|
cmd = "jail_service.py"
|
2018-05-14 23:26:33 +08:00
|
|
|
args = ""
|
2018-02-28 01:57:02 +08:00
|
|
|
runs.append({
|
|
|
|
"name": "distributed__card_fraud__" + name,
|
|
|
|
"cd": "..",
|
|
|
|
"supervisor": cmd,
|
2018-05-14 23:26:33 +08:00
|
|
|
"arguments": args,
|
2018-02-28 01:57:02 +08:00
|
|
|
"infiles": binaries + [
|
|
|
|
"common.py",
|
|
|
|
"jail_service.py",
|
|
|
|
"card_fraud/card_fraud.py",
|
|
|
|
"card_fraud/snapshots/worker_" + str(i),
|
|
|
|
] + additional,
|
|
|
|
"outfile_paths": outfile_paths,
|
|
|
|
"parallel_run": "distributed__card_fraud",
|
|
|
|
"slave_group": "remote_4c32g",
|
|
|
|
"enable_network": True,
|
|
|
|
})
|
|
|
|
|
|
|
|
print(json.dumps(runs, indent=4, sort_keys=True))
|