From 51e1c3dcc01d36e068bda2b2816007b25588b81b Mon Sep 17 00:00:00 2001 From: Dhruv Bhanushali Date: Thu, 19 Dec 2024 22:54:34 +0400 Subject: [PATCH] Test that the list view makes 1 or 2 DB calls based on addons --- api/test/unit/views/test_audio_views.py | 39 +++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 api/test/unit/views/test_audio_views.py diff --git a/api/test/unit/views/test_audio_views.py b/api/test/unit/views/test_audio_views.py new file mode 100644 index 00000000000..ef689b30dc7 --- /dev/null +++ b/api/test/unit/views/test_audio_views.py @@ -0,0 +1,39 @@ +from unittest.mock import MagicMock, patch + +import pytest +import pytest_django.asserts + +from test.factory.models import AudioFactory + + +@pytest.mark.parametrize("peaks, query_count", [(True, 2), (False, 1)]) +@pytest.mark.django_db +def test_peaks_param_determines_addons(api_client, peaks, query_count): + num_results = 20 + + # Since controller returns a list of ``Hit``s, not model instances, we must + # set the ``meta`` param on each of them to match the shape of ``Hit``. + results = AudioFactory.create_batch(size=num_results) + for result in results: + result.meta = None + + controller_ret = ( + results, + 1, # num_pages + num_results, + {}, # search_context + ) + with ( + patch( + "api.views.media_views.search_controller", + query_media=MagicMock(return_value=controller_ret), + ), + patch( + "api.serializers.media_serializers.search_controller", + get_sources=MagicMock(return_value={}), + ), + pytest_django.asserts.assertNumQueries(query_count), + ): + res = api_client.get(f"/v1/audio/?peaks={peaks}") + + assert res.status_code == 200