From fcefa41956b96addf55a60cdcb97f6110076f816 Mon Sep 17 00:00:00 2001 From: Ivan Golikov Date: Wed, 8 Jan 2025 22:12:21 +0100 Subject: [PATCH] Combining test cases --- tests/integration/test_utils.py | 30 +++++++++--------------------- tests/unit/test_utils.py | 19 ++++++++----------- 2 files changed, 17 insertions(+), 32 deletions(-) diff --git a/tests/integration/test_utils.py b/tests/integration/test_utils.py index 0d9290d..03ae701 100644 --- a/tests/integration/test_utils.py +++ b/tests/integration/test_utils.py @@ -1,5 +1,6 @@ -from unittest.mock import AsyncMock, Mock, patch +from unittest.mock import AsyncMock, patch +import pytest from redis.asyncio import Redis from pssecret_server.utils import get_new_key, getdel, save_secret @@ -35,27 +36,14 @@ async def test_save_secret_data(redis_server: Redis) -> None: assert redis_data.decode() == secret.data -@patch("pssecret_server.utils._is_getdel_available", side_effect=AsyncMock()) -async def test_getdel_when_available( - is_getdel_available: Mock, redis_server: Redis +@pytest.mark.parametrize("getdel_available", [True, False]) +@patch("pssecret_server.utils._is_getdel_available", new_callable=AsyncMock) +async def test_getdel( + mock_is_getdel_available: AsyncMock, + getdel_available: bool, + redis_server: Redis, ) -> None: - is_getdel_available.side_effect.return_value = True - - test_value = "test_data" - test_key = "test_key" - await redis_server.set(test_key, test_value) - - result = await getdel(redis_server, test_key) - - assert result.decode() == test_value - assert not await redis_server.exists(test_key) - - -@patch("pssecret_server.utils._is_getdel_available", side_effect=AsyncMock()) -async def test_getdel_when_not_available( - is_getdel_available: Mock, redis_server: Redis -) -> None: - is_getdel_available.side_effect.return_value = False + mock_is_getdel_available.return_value = getdel_available test_value = "test_data" test_key = "test_key" diff --git a/tests/unit/test_utils.py b/tests/unit/test_utils.py index 321bb40..0fa6100 100644 --- a/tests/unit/test_utils.py +++ b/tests/unit/test_utils.py @@ -34,18 +34,15 @@ def test_secret_is_not_decryptable_by_random_key(fernet: Fernet): decrypt_secret(encrypted_secret.data.encode(), random_fernet) -async def test_is_getdel_available_when_supported(): +@pytest.mark.parametrize( + ("getdel_effect", "expected_result"), [(None, True), (ResponseError, False)] +) +async def test_is_getdel_available( + getdel_effect: ResponseError | None, expected_result: bool +): redis = AsyncMock() + redis.getdel.side_effect = getdel_effect # pyright: ignore[reportAny] result = await _is_getdel_available(redis) - assert result is True - - -async def test_is_getdel_available_when_not_supported(): - redis = AsyncMock() - redis.getdel.side_effect = ResponseError - - result = await _is_getdel_available(redis) - - assert result is False + assert result is expected_result