From 23a485dce2e98dd4bb8c9d384db042f8420a06cf Mon Sep 17 00:00:00 2001 From: sfmig <33267254+sfmig@users.noreply.github.com> Date: Mon, 16 Oct 2023 12:27:06 +0100 Subject: [PATCH] added git URL to monkeypatched asv but not fully working yet (WIP) --- .../test_cellfinder_benchmarks.py | 43 +++++++++++++++---- 1 file changed, 34 insertions(+), 9 deletions(-) diff --git a/tests/test_integration/test_cellfinder_benchmarks.py b/tests/test_integration/test_cellfinder_benchmarks.py index 708a3635..ab204764 100644 --- a/tests/test_integration/test_cellfinder_benchmarks.py +++ b/tests/test_integration/test_cellfinder_benchmarks.py @@ -3,6 +3,7 @@ from pathlib import Path import pytest +from asv import util @pytest.fixture() @@ -23,8 +24,11 @@ def asv_config_monkeypatched_path(tmp_path): """ # read reference asv config asv_original_path = Path(__file__).resolve().parents[2] / "asv.conf.json" - with open(asv_original_path) as asv_config: - asv_monkeypatched_dict = json.load(asv_config) + asv_monkeypatched_dict = util.load_json( + asv_original_path, js_comments=True + ) + # with open(asv_original_path) as asv_config: + # asv_monkeypatched_dict = json.load(asv_config) # change directories for ky in ["env_dir", "results_dir", "html_dir"]: @@ -32,6 +36,14 @@ def asv_config_monkeypatched_path(tmp_path): Path(tmp_path) / asv_monkeypatched_dict[ky] ) + # change repo to URL rather than local + asv_monkeypatched_dict[ + "repo" + ] = "https://github.com/brainglobe/brainglobe-workflows/" + asv_monkeypatched_dict[ + "dvcs" + ] = "git" # not sure why I need this with the URL? + # define path to a temp json file to dump config data asv_monkeypatched_path = tmp_path / "asv.conf.json" @@ -49,26 +61,39 @@ def test_run_benchmarks(asv_config_monkeypatched_path): # --- ideally monkeypatch an asv config so that results are in tmp_dir? # set up machine (env_dir, results_dir, html_dir) - subprocess.run(["asv", "machine", "--yes"]) + asv_machine_output = subprocess.run( + [ + "asv", + "machine", + "--yes", + "--config", + asv_config_monkeypatched_path, + ] + ) + assert asv_machine_output.returncode == 0 # run benchmarks - subprocess_output = subprocess.run( + asv_benchmark_output = subprocess.run( [ "asv", "run", - "--config", # --- can I pass a dict? + "--config", asv_config_monkeypatched_path, - # "--dry-run" # Do not save any results to disk. for now! + # "--dry-run" + # # Do not save any results to disk? not truly testing then ], - # cwd=tmp_path, ---> from where asv config is + cwd=str( + Path(asv_config_monkeypatched_path).parent + ), # ---> from where asv config is stdout=subprocess.PIPE, stderr=subprocess.STDOUT, text=True, encoding="utf-8", - ) + ) # STDOUT: "· Cloning project\n· Fetching recent changes\n· + # Creating environments\n· No __init__.py file in 'benchmarks'\n"? # check returncode - assert subprocess_output.returncode == 0 + assert asv_benchmark_output.returncode == 0 # check logs?