From 958edac63a79f636dc7ce9bdb3df238403a0103b Mon Sep 17 00:00:00 2001 From: Chiruzzi Marco Date: Tue, 7 Sep 2021 18:52:55 +0200 Subject: [PATCH] Run the load_dump function through docker-compose instead of interacting with the running containers throught the docker client. --- azure-pipelines/provision_services.yml | 2 ++ derex/runner/docker_utils.py | 31 +++++++++++++------------- 2 files changed, 17 insertions(+), 16 deletions(-) diff --git a/azure-pipelines/provision_services.yml b/azure-pipelines/provision_services.yml index 2a94f6d16..0748a7ca7 100644 --- a/azure-pipelines/provision_services.yml +++ b/azure-pipelines/provision_services.yml @@ -10,6 +10,8 @@ steps: set -ex export DEREX_ADMIN_SERVICES=False ddc-services up -d + # Give it some seconds to boot + sleep 15 displayName: "Start services docker containers" - script: | diff --git a/derex/runner/docker_utils.py b/derex/runner/docker_utils.py index 20e9f1eb8..94a94f4f0 100644 --- a/derex/runner/docker_utils.py +++ b/derex/runner/docker_utils.py @@ -112,25 +112,24 @@ def check_services(services: Iterable[str], max_seconds: int = 1) -> bool: def load_dump(relpath): """Loads a mysql dump into the derex mysql database.""" + from derex.runner.ddc import run_ddc_services from derex.runner.mysql import MYSQL_ROOT_PASSWORD + wait_for_service("mysql", 30) dump_path = abspath_from_egg("derex.runner", relpath) - image = client.containers.get("mysql").image - logger.info("Resetting email database") - try: - client.containers.run( - image.tags[0], - [ - "sh", - "-c", - f"mysql -h mysql -p{MYSQL_ROOT_PASSWORD} < /dump/{dump_path.name}", - ], - network="derex", - volumes={dump_path.parent: {"bind": "/dump"}}, - auto_remove=True, - ) - except docker.errors.ContainerError as exc: - logger.exception(exc) + logger.info(f"Loading mysql dump from {dump_path}") + compose_args = [ + "run", + "--rm", + "-v", + f"{dump_path.parent}:/dump", + "-T", + "mysql", + "sh", + "-c", + f"mysql -h mysql -p{MYSQL_ROOT_PASSWORD} < /dump/{dump_path.name}", + ] + run_ddc_services(compose_args) def build_image(