2017-07-18 01:14:42 +08:00
|
|
|
#!/usr/bin/env python3
|
2017-07-11 00:17:18 +08:00
|
|
|
|
|
|
|
"""
|
|
|
|
A python script that launches the memgraph client,
|
|
|
|
executes a query and prints out a JSON dict of measurements
|
|
|
|
to stdout.
|
|
|
|
|
|
|
|
Takes a number of cmd-line arguments of the following structure:
|
|
|
|
Positional, mandatory:
|
|
|
|
- db_uri
|
|
|
|
- query
|
|
|
|
Named, optional:
|
|
|
|
- encrypt
|
|
|
|
|
|
|
|
Required the database URI to be passed as the single
|
|
|
|
cmd line argument.
|
|
|
|
|
|
|
|
The dict that is printed out contains:
|
|
|
|
- return_code of the client execution process
|
|
|
|
- error_msg (empty if not applicable)
|
|
|
|
- metedata dict
|
|
|
|
|
|
|
|
Note that 'metadata' are only valid if the return_code is 0
|
|
|
|
"""
|
|
|
|
|
|
|
|
import sys
|
2017-07-18 01:14:42 +08:00
|
|
|
import os
|
2017-07-11 00:17:18 +08:00
|
|
|
import time
|
|
|
|
import json
|
|
|
|
import io
|
2017-07-29 23:03:34 +08:00
|
|
|
from contextlib import redirect_stderr
|
2017-07-18 01:14:42 +08:00
|
|
|
from multiprocessing import Pool
|
2017-07-29 23:03:34 +08:00
|
|
|
from functools import partial
|
|
|
|
|
|
|
|
# tests/stress dir, that's the place of common.py.
|
|
|
|
sys.path.append(os.path.join(os.path.dirname(os.path.dirname(os.path.dirname(
|
|
|
|
os.path.realpath(__file__)))), "stress"))
|
2017-07-18 01:14:42 +08:00
|
|
|
from common import connection_argument_parser, execute_till_success, \
|
2017-07-21 21:03:10 +08:00
|
|
|
argument_driver
|
2017-07-11 00:17:18 +08:00
|
|
|
|
|
|
|
|
|
|
|
# string constants
|
|
|
|
RETURN_CODE = "return_code"
|
|
|
|
ERROR_MSG = "error_msg"
|
|
|
|
WALL_TIME = "wall_time"
|
|
|
|
|
2017-07-29 23:03:34 +08:00
|
|
|
|
2017-07-11 00:17:18 +08:00
|
|
|
def _prepare_for_json(obj):
|
|
|
|
if isinstance(obj, dict):
|
|
|
|
return {k: _prepare_for_json(v) for k, v in obj.items()}
|
|
|
|
if isinstance(obj, list):
|
|
|
|
return [_prepare_for_json(elem) for elem in obj]
|
|
|
|
if isinstance(obj, (str, int, float, type(None))):
|
|
|
|
return obj
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
def _print_dict(d):
|
|
|
|
print(json.dumps(_prepare_for_json(d), indent=2))
|
|
|
|
|
|
|
|
|
2017-07-21 21:03:10 +08:00
|
|
|
def _run_query(args, query, self):
|
|
|
|
if not hasattr(self, "driver"):
|
2017-07-29 23:03:34 +08:00
|
|
|
# TODO: this driver and session is never closed.
|
2017-07-21 21:03:10 +08:00
|
|
|
self.driver = argument_driver(args)
|
|
|
|
self.session = self.driver.session()
|
2017-07-29 23:03:34 +08:00
|
|
|
return execute_till_success(self.session, query)[2]
|
2017-07-21 21:03:10 +08:00
|
|
|
_run_query.__defaults__ = (_run_query,)
|
2017-07-18 01:14:42 +08:00
|
|
|
|
2017-07-29 23:03:34 +08:00
|
|
|
|
2017-07-11 00:17:18 +08:00
|
|
|
def main():
|
2017-07-18 01:14:42 +08:00
|
|
|
argp = connection_argument_parser()
|
|
|
|
argp.add_argument("--num-workers", type=int, default=1)
|
2017-07-11 00:17:18 +08:00
|
|
|
|
2017-07-18 01:14:42 +08:00
|
|
|
# Parse args and ensure that stdout is not polluted by argument parsing.
|
2017-07-11 00:17:18 +08:00
|
|
|
try:
|
|
|
|
f = io.StringIO()
|
|
|
|
with redirect_stderr(f):
|
|
|
|
args = argp.parse_args()
|
|
|
|
except:
|
|
|
|
_print_dict({RETURN_CODE: 1, ERROR_MSG: "Invalid cmd-line arguments"})
|
|
|
|
sys.exit(1)
|
|
|
|
|
2017-07-29 23:03:34 +08:00
|
|
|
queries = filter(lambda x: x.strip() != '', sys.stdin.read().split("\n"))
|
2017-07-11 23:45:34 +08:00
|
|
|
|
2017-07-18 01:14:42 +08:00
|
|
|
# Execute the queries.
|
2017-07-11 00:17:18 +08:00
|
|
|
metadatas = []
|
2017-07-18 01:14:42 +08:00
|
|
|
with Pool(args.num_workers) as pool:
|
|
|
|
start = time.time()
|
|
|
|
metadatas = list(pool.map(partial(_run_query, args), queries))
|
|
|
|
end = time.time()
|
|
|
|
delta_time = end - start
|
2017-07-11 00:17:18 +08:00
|
|
|
|
|
|
|
_print_dict({
|
|
|
|
RETURN_CODE: 0,
|
2017-07-18 01:14:42 +08:00
|
|
|
WALL_TIME: (None if not queries else delta_time),
|
2017-07-11 00:17:18 +08:00
|
|
|
"metadatas": metadatas
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|