From 1f223d0dc501a5345f33a9cf8015f8e04fe36404 Mon Sep 17 00:00:00 2001 From: Nicola Soranzo Date: Tue, 5 Nov 2024 15:33:40 +0000 Subject: [PATCH] Test hash validation also for upload by path --- test/unit/app/tools/test_data_fetch.py | 36 +++++++++++++++++++++++--- 1 file changed, 33 insertions(+), 3 deletions(-) diff --git a/test/unit/app/tools/test_data_fetch.py b/test/unit/app/tools/test_data_fetch.py index ee7cdd61536f..8c1a64318de6 100644 --- a/test/unit/app/tools/test_data_fetch.py +++ b/test/unit/app/tools/test_data_fetch.py @@ -5,6 +5,9 @@ from contextlib import contextmanager from shutil import rmtree from tempfile import mkdtemp +from typing import Optional + +import pytest from galaxy.tools.data_fetch import main from galaxy.util.unittest_utils import skip_if_github_down @@ -13,7 +16,17 @@ URI_FOR_1_2_3 = f"base64://{B64_FOR_1_2_3}" -def test_simple_path_get(): +@pytest.mark.parametrize( + "hash_value, error_message", + [ + ("471ddd37fc297fba09b893b88739ece9", None), + ( + "thisisbad", + "Failed to validate upload with [MD5] - expected [thisisbad] got [471ddd37fc297fba09b893b88739ece9]", + ), + ], +) +def test_simple_path_get(hash_value: str, error_message: Optional[str]): with _execute_context() as execute_context: job_directory = execute_context.job_directory example_path = os.path.join(job_directory, "example_file") @@ -25,13 +38,30 @@ def test_simple_path_get(): "destination": { "type": "hdas", }, - "elements": [{"src": "path", "path": example_path}], + "elements": [ + { + "src": "path", + "path": example_path, + "hashes": [ + { + "hash_function": "MD5", + "hash_value": hash_value, + } + ], + } + ], } - ] + ], + "validate_hashes": True, } execute_context.execute_request(request) output = _unnamed_output(execute_context) assert output + hda_result = output["elements"][0] + if error_message is not None: + assert hda_result["error_message"] == error_message + else: + assert "error_message" not in hda_result @skip_if_github_down