From b474a02cbbc3c211b8240126a8a9474b51b0660c Mon Sep 17 00:00:00 2001 From: Paul Spooren Date: Wed, 4 Dec 2024 09:58:04 +0100 Subject: [PATCH] util: simplify hasing Signed-off-by: Paul Spooren --- asu/build.py | 2 +- asu/util.py | 12 +++--------- tests/test_api.py | 7 +++++-- tests/test_util.py | 21 ++++++++++++++++----- 4 files changed, 25 insertions(+), 17 deletions(-) diff --git a/asu/build.py b/asu/build.py index 3c0a6dde..f1c4718e 100644 --- a/asu/build.py +++ b/asu/build.py @@ -245,7 +245,7 @@ def build(build_request: BuildRequest, job=None): "image", f"PROFILE={build_request.profile}", f"PACKAGES={' '.join(build_cmd_packages)}", - f"EXTRA_IMAGE_NAME={packages_hash}", + f"EXTRA_IMAGE_NAME={packages_hash[:12]}", f"BIN_DIR=/builder/{request_hash}", ] diff --git a/asu/util.py b/asu/util.py index a256a0c8..f3587a3e 100644 --- a/asu/util.py +++ b/asu/util.py @@ -22,9 +22,6 @@ from asu.build_request import BuildRequest from asu.config import settings - -REQUEST_HASH_LENGTH: int = 32 - log: logging.Logger = logging.getLogger("rq.worker") log.propagate = False # Suppress duplicate log messages. @@ -66,18 +63,16 @@ def get_branch(version_or_branch: str) -> dict[str, str]: return {**settings.branches.get(branch_name, {}), "name": branch_name} -def get_str_hash(string: str, length: int = REQUEST_HASH_LENGTH) -> str: +def get_str_hash(string: str) -> str: """Return sha256sum of str with optional length Args: string (str): input string - length (int): hash length Returns: str: hash of string with specified length """ - h = hashlib.sha256(bytes(string or "", "utf-8")) - return h.hexdigest()[:length] + return hashlib.sha256(bytes(string or "", "utf-8")).hexdigest() def get_file_hash(path: str) -> str: @@ -145,7 +140,6 @@ def get_request_hash(build_request: BuildRequest) -> str: str(build_request.repositories), ] ), - REQUEST_HASH_LENGTH, ) @@ -161,7 +155,7 @@ def get_packages_hash(packages: list[str]) -> str: Returns: str: hash of `req` """ - return get_str_hash(" ".join(sorted(list(set(packages)))), 12) + return get_str_hash(" ".join(sorted(list(set(packages))))) def fingerprint_pubkey_usign(pubkey: str) -> str: diff --git a/tests/test_api.py b/tests/test_api.py index 3a7a7c60..951d2e62 100644 --- a/tests/test_api.py +++ b/tests/test_api.py @@ -178,7 +178,7 @@ def test_api_build_request_hash(client): profile="testprofile", ) - case12hash = "8731372f84b0022c070e6127bad24eb2" + case12hash = "8d8e0aa2fd95bb75dba4aff4279dd6f976a40ad17300927d54b8a9a9b0576306" case34hash = "0dab3b60bd8174da250e2ea2942a3744" # Case 1 - diff_packages=True, first package ordering @@ -702,7 +702,10 @@ def test_api_build_defaults_filled_allowed(app): assert response.status_code == 200 data = response.json() - assert data["request_hash"] == "c9836b2259eec0c3a31868fe77a19983" + assert ( + data["request_hash"] + == "9c8d0cd7d9ec208a233b954edb20c3c20b5c11103bb7f5f1ebface565f8c6720" + ) def test_api_build_defaults_filled_too_big(app): diff --git a/tests/test_util.py b/tests/test_util.py index cb520647..7479fdfc 100644 --- a/tests/test_util.py +++ b/tests/test_util.py @@ -27,21 +27,29 @@ def test_get_str_hash(): - assert get_str_hash("test", 12) == "9f86d081884c" + assert ( + get_str_hash("test") + == "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08" + ) def test_get_file_hash(): file_fd, file_path = tempfile.mkstemp() os.write(file_fd, b"test") - assert get_file_hash(file_path).startswith("9f86d081884c") + assert get_file_hash(file_path).startswith( + "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08" + ) os.close(file_fd) os.unlink(file_path) def test_get_packages_hash(): - assert get_packages_hash(["test1", "test2"]) == "57aab5949a36" + assert ( + get_packages_hash(["test1", "test2"]) + == "57aab5949a36e66b535a8cb13e39e9e093181c9000c016990d7be9eb86a9b9e8" + ) def test_get_request_hash(): @@ -49,13 +57,16 @@ def test_get_request_hash(): **{ "distro": "test", "version": "test", - "target": "test", + "target": "testtarget/testsubtarget", "profile": "test", "packages": ["test"], } ) - assert get_request_hash(request) == "3944eba49da93e2c605a7e9980e52765" + assert ( + get_request_hash(request) + == "99ff721439cd696f7da259541a07d7bfc7eb6c45a844db532e0384b464e23f46" + ) def test_diff_packages():