from argparse import ArgumentParser import atexit import logging import os import subprocess import yaml from memgraph import MemgraphInstanceRunner SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__)) PROJECT_DIR = os.path.normpath(os.path.join(SCRIPT_DIR, "..", "..")) BUILD_DIR = os.path.join(PROJECT_DIR, "build") MEMGRAPH_BINARY = os.path.join(BUILD_DIR, "memgraph") log = logging.getLogger("memgraph.tests.e2e.replication") def load_args(): parser = ArgumentParser() parser.add_argument("--workloads-path", required=True) parser.add_argument("--workload-name", default=None, required=False) return parser.parse_args() def load_workloads(path): with open(path, "r") as f: return yaml.load(f, Loader=yaml.FullLoader)['workloads'] def run(args): workloads = load_workloads(args.workloads_path) for workload in workloads: workload_name = workload['name'] if args.workload_name is not None and \ args.workload_name != workload_name: continue log.info("%s STARTED.", workload_name) # Setup. mg_instances = {} @atexit.register def cleanup(): for mg_instance in mg_instances.values(): mg_instance.stop() for name, config in workload['cluster'].items(): mg_instance = MemgraphInstanceRunner(MEMGRAPH_BINARY) mg_instances[name] = mg_instance mg_instance.start(args=config['args']) for query in config['setup_queries']: mg_instance.query(query) # Test. mg_test_binary = os.path.join(BUILD_DIR, workload['binary']) subprocess.run( [mg_test_binary] + workload['args'], check=True, stderr=subprocess.STDOUT) # Validation. for name, config in workload['cluster'].items(): for validation in config['validation_queries']: mg_instance = mg_instances[name] data = mg_instance.query(validation['query'])[0][0] assert data == validation['expected'] cleanup() log.info("%s PASSED.", workload_name) if __name__ == '__main__': args = load_args() logging.basicConfig( level=logging.INFO, format='%(levelname)s %(asctime)s %(name)s] %(message)s') run(args)