From 46be07dca26a3246e82465f6f32e5a65457a89b8 Mon Sep 17 00:00:00 2001 From: SilviaAmAm Date: Wed, 10 Jan 2024 18:08:15 +0100 Subject: [PATCH 1/2] :adhesive_bandage: Replace list method with operation In case that the schema of the service has another operation_id than 'zaaktypen_list', the list method gives a value error when trying to retrieve the URL path. With the operation method, we can just use the URL path directly. --- zgw_consumers/admin_fields.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/zgw_consumers/admin_fields.py b/zgw_consumers/admin_fields.py index 41b1322..66de298 100644 --- a/zgw_consumers/admin_fields.py +++ b/zgw_consumers/admin_fields.py @@ -30,7 +30,12 @@ def get_zaaktypen() -> Dict[Service, List[Dict[str, Any]]]: client = service.build_client() logger.debug("Fetching zaaktype list for service %r", service) zaaktypen_per_service[service] = [] - response = client.list("zaaktype") + response = client.operation( + url="zaaktypen", + operation_id="zaaktype_list", + method="GET", + data={}, + ) zaaktypen_per_service[service] += response["results"] while response["next"]: next_url = urlparse(response["next"]) From 250e7dc72ef6727bc44b625dae12b394082af8e2 Mon Sep 17 00:00:00 2001 From: SilviaAmAm Date: Wed, 10 Jan 2024 18:08:44 +0100 Subject: [PATCH 2/2] :white_check_mark: Test schema with operation ID different from zaaktype_list --- tests/test_admin.py | 48 ++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 47 insertions(+), 1 deletion(-) diff --git a/tests/test_admin.py b/tests/test_admin.py index f829b40..3b68a60 100644 --- a/tests/test_admin.py +++ b/tests/test_admin.py @@ -1,6 +1,7 @@ +import json from pathlib import Path -from django.core.files.base import File +from django.core.files.base import ContentFile, File from django.urls import reverse from django.utils.translation import gettext_lazy as _ @@ -105,3 +106,48 @@ def test_listzaaktypen_mixin_server_error(settings, admin_client, requests_mock) # assert that Zaaktype field is present in admin page despite HTTPError zaaktypen_label = doc.find("label") assert zaaktypen_label.text() == "Zaaktype:" + + +@pytest.mark.django_db +def test_listzaaktypen_unexpected_operation_id(settings, admin_client, requests_mock): + requests_mock.get( + f"{API_ROOT}zaaktypen", + status_code=200, + json={"results": [], "count": 0, "next": None}, + ) + + service = Service.objects.create( + label="Test", + api_type=APITypes.ztc, + api_root=API_ROOT, + oas_file=ContentFile( + json.dumps( + { + "openapi": "3.0.1", + "info": {"title": "Catalogi API 1.0", "version": "1.0"}, + "paths": { + "/api/v1/zaaktypen": { + "get": { + "tags": ["ZaakType"], + "summary": "Alle ZAAKTYPEn opvragen.\r\nDeze lijst kan gefilterd wordt met query-string parameters.", + "description": "", + "operationId": "ZaakTypeGetAll", # Operation ID different from zaaktype_list + "responses": { + "200": {"description": "OK"}, + "401": {"description": "Unauthorized"}, + }, + } + } + }, + } + ), + name="schema.yaml", + ), + ) + service.full_clean() + + # assert that admin page works despite an operation ID different from zaaktype_list + url = reverse("admin:testapp_zgwconfig_change") + response = admin_client.get(url) + + assert response.status_code == 200