From 5e3bf1464c80e2cae8880fa83a47c6897d691382 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcin=20Po=C5=BAniak?= Date: Tue, 29 Aug 2023 17:12:41 +0200 Subject: [PATCH 1/2] Move temporary dir deletion to inner function, delete temp dir in skipped benchmarks --- .../__runner__/runner.py | 70 +++++++++++++++---- 1 file changed, 58 insertions(+), 12 deletions(-) diff --git a/redis_benchmarks_specification/__runner__/runner.py b/redis_benchmarks_specification/__runner__/runner.py index 2303b62..57acc55 100644 --- a/redis_benchmarks_specification/__runner__/runner.py +++ b/redis_benchmarks_specification/__runner__/runner.py @@ -359,6 +359,19 @@ def process_self_contained_coordinator_stream( resp_version=None, override_memtier_test_time=0, ): + def delete_temporary_files( + temporary_dir_client, full_result_path, benchmark_tool_global + ): + if preserve_temporary_client_dirs is True: + logging.info(f"Preserving temporary client dir {temporary_dir_client}") + else: + if "redis-benchmark" in benchmark_tool_global: + if full_result_path is not None: + os.remove(full_result_path) + logging.info("Removing temporary JSON file") + shutil.rmtree(temporary_dir_client, ignore_errors=True) + logging.info(f"Removing temporary client dir {temporary_dir_client}") + overall_result = True results_matrix = [] total_test_suite_runs = 0 @@ -507,6 +520,11 @@ def process_self_contained_coordinator_stream( test_name, maxmemory, benchmark_required_memory ) ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue reset_commandstats(redis_conns) @@ -543,6 +561,11 @@ def process_self_contained_coordinator_stream( test_name, priority_upper_limit, priority ) ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue if priority < priority_lower_limit: logging.warning( @@ -550,6 +573,11 @@ def process_self_contained_coordinator_stream( test_name, priority_lower_limit, priority ) ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue logging.info( "Test {} priority ({}) is within the priority limit [{},{}]".format( @@ -567,10 +595,20 @@ def process_self_contained_coordinator_stream( test_name ) ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue if dry_run is True: dry_run_count = dry_run_count + 1 + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue if "preload_tool" in benchmark_config["dbconfig"]: @@ -598,6 +636,11 @@ def process_self_contained_coordinator_stream( logging.warning( "Skipping this test given preload result was false" ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue execute_init_commands( benchmark_config, r, dbconfig_keyname="dbconfig" @@ -618,6 +661,11 @@ def process_self_contained_coordinator_stream( if dry_run_include_preload is True: dry_run_count = dry_run_count + 1 + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue benchmark_tool = extract_client_tool(benchmark_config) @@ -692,6 +740,11 @@ def process_self_contained_coordinator_stream( logging.warning( "Forcing skip this test given there is an arbitrary commmand and memtier usage. Check https://github.com/RedisLabs/memtier_benchmark/pull/117 ." ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=None, + benchmark_tool_global=benchmark_tool_global, + ) continue client_container_image = extract_client_container_image( @@ -899,18 +952,11 @@ def process_self_contained_coordinator_stream( shutil.copy(full_result_path, dest_fpath) overall_result &= test_result - if preserve_temporary_client_dirs is True: - logging.info( - f"Preserving temporary client dir {temporary_dir_client}" - ) - else: - if "redis-benchmark" in benchmark_tool_global: - os.remove(full_result_path) - logging.info("Removing temporary JSON file") - shutil.rmtree(temporary_dir_client, ignore_errors=True) - logging.info( - f"Removing temporary client dir {temporary_dir_client}" - ) + delete_temporary_files( + temporary_dir_client=temporary_dir_client, + full_result_path=full_result_path, + benchmark_tool_global=benchmark_tool_global, + ) table_name = "Results for entire test-suite" results_matrix_headers = [ From c9ce358281fabd22f36ee3b2419f0502926e3de3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcin=20Po=C5=BAniak?= Date: Tue, 12 Sep 2023 13:40:10 +0200 Subject: [PATCH 2/2] Fix docker.client.containers.logs usage in coordinator --- .../self_contained_coordinator.py | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/redis_benchmarks_specification/__self_contained_coordinator__/self_contained_coordinator.py b/redis_benchmarks_specification/__self_contained_coordinator__/self_contained_coordinator.py index 0b2e857..2fa328f 100644 --- a/redis_benchmarks_specification/__self_contained_coordinator__/self_contained_coordinator.py +++ b/redis_benchmarks_specification/__self_contained_coordinator__/self_contained_coordinator.py @@ -912,9 +912,7 @@ def process_self_contained_coordinator_stream( logging.critical("Printing redis container log....") print("-" * 60) print( - redis_container.logs( - stdout=True, stderr=True, logs=True - ) + redis_container.logs(stdout=True, stderr=True) ) print("-" * 60) test_result = False