From 94b7be03790b9df997ee68420b7e950190b53f51 Mon Sep 17 00:00:00 2001 From: Brendan Smith Date: Wed, 22 Jan 2025 16:43:09 +0000 Subject: [PATCH 1/2] Ensure OGDs using allocate and approve button are taken to correct approval flow --- caseworker/cases/helpers/case.py | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/caseworker/cases/helpers/case.py b/caseworker/cases/helpers/case.py index 4392f1f6cb..35b9a3e541 100644 --- a/caseworker/cases/helpers/case.py +++ b/caseworker/cases/helpers/case.py @@ -34,6 +34,7 @@ TAU_ALIAS = "TAU" LU_ALIAS = "LICENSING_UNIT" +FCDO_ALIAS = "FCO" LU_POST_CIRC_FINALISE_QUEUE_ALIAS = "LU_POST_CIRC_FINALISE" LU_PRE_CIRC_REVIEW_QUEUE_ALIAS = "LU_PRE_CIRC_REVIEW" @@ -85,6 +86,9 @@ def is_tau_user(self): def is_lu_user(self): return self.caseworker["team"]["alias"] == LU_ALIAS + def is_fcdo_user(self): + return self.caseworker["team"]["alias"] == FCDO_ALIAS + def get_context_data(self, **kwargs): context = super().get_context_data(**kwargs) allocate_to_me_form = ( @@ -99,6 +103,11 @@ def get_context_data(self, **kwargs): } ) ) + approve_all_url = reverse("cases:approve_all", kwargs={"queue_pk": self.queue_id, "pk": self.case_id}) + if self.is_fcdo_user(): + approve_all_url = reverse( + "cases:approve_all_legacy", kwargs={"queue_pk": self.queue_id, "pk": self.case_id} + ) allocate_and_approve_form = ( None if self.queue["is_system_queue"] @@ -108,9 +117,7 @@ def get_context_data(self, **kwargs): "queue_id": self.queue_id, "user_id": self.caseworker["id"], "case_id": self.case_id, - "return_to": reverse( - "cases:approve_all_legacy", kwargs={"queue_pk": self.queue_id, "pk": self.case_id} - ), + "return_to": approve_all_url, }, ) ) From 1f7d3b443b77ec2809b06991fb22f79c6df63b6f Mon Sep 17 00:00:00 2001 From: Brendan Smith Date: Thu, 23 Jan 2025 09:16:41 +0000 Subject: [PATCH 2/2] Add unit tests for allocate and approve form --- .../cases/views/test_quick_summary.py | 67 ++++++++++++++++++- 1 file changed, 64 insertions(+), 3 deletions(-) diff --git a/unit_tests/caseworker/cases/views/test_quick_summary.py b/unit_tests/caseworker/cases/views/test_quick_summary.py index 2cf5f318f3..3ae2eebbea 100644 --- a/unit_tests/caseworker/cases/views/test_quick_summary.py +++ b/unit_tests/caseworker/cases/views/test_quick_summary.py @@ -1,3 +1,4 @@ +import re from decimal import Decimal import pytest from bs4 import BeautifulSoup @@ -6,11 +7,12 @@ from django.urls import reverse +from core import client + @pytest.fixture(autouse=True) def setup( settings, - mock_queue, mock_gov_lu_user, mock_case, mock_standard_case_activity_filters, @@ -24,7 +26,37 @@ def setup( pass -def test_case_summary_activated(authorized_client, data_queue, data_standard_case): +@pytest.fixture +def mock_gov_fcdo_ogd_user(requests_mock, mock_notifications, mock_case_statuses, mock_gov_user, gov_uk_user_id): + mock_gov_user["user"]["team"] = { + "id": "521154de-f39e-45bf-9922-baaaaaa", + "name": "FCDO", + "alias": "FCO", + } + + url = client._build_absolute_uri("/gov-users/") + requests_mock.get(url=f"{url}me/", json=mock_gov_user) + requests_mock.get(url=re.compile(f"{url}{gov_uk_user_id}/"), json=mock_gov_user) + + +@pytest.fixture +def data_ogd_queue(): + return { + "id": "00000000-0000-0000-0000-000000000002", + "alias": None, + "name": "Some OGD", + "is_system_queue": False, + "countersigning_queue": None, + } + + +@pytest.fixture +def mock_ogd_queue(requests_mock, data_ogd_queue): + url = client._build_absolute_uri("/queues/") + yield requests_mock.get(url=re.compile(f"{url}.*/"), json=data_ogd_queue) + + +def test_case_summary_activated(authorized_client, data_queue, data_standard_case, mock_queue): url = reverse( "cases:case", kwargs={"queue_pk": data_queue["id"], "pk": data_standard_case["case"]["id"], "tab": "quick-summary"}, @@ -33,7 +65,35 @@ def test_case_summary_activated(authorized_client, data_queue, data_standard_cas assertTemplateUsed(response, "case/tabs/quick-summary.html") -def test_case_summary_data(authorized_client, data_queue, data_standard_case): +def test_case_summary_allocate_and_approve(authorized_client, data_ogd_queue, data_standard_case, mock_ogd_queue): + url = reverse( + "cases:case", + kwargs={"queue_pk": data_ogd_queue["id"], "pk": data_standard_case["case"]["id"], "tab": "quick-summary"}, + ) + response = authorized_client.get(url) + assertTemplateUsed(response, "case/tabs/quick-summary.html") + assert "allocate_and_approve_form" in response.context + assert response.context["allocate_and_approve_form"].initial["return_to"] == reverse( + "cases:approve_all", kwargs={"queue_pk": data_ogd_queue["id"], "pk": data_standard_case["case"]["id"]} + ) + + +def test_case_summary_allocate_and_approve_fcdo( + authorized_client, data_ogd_queue, data_standard_case, mock_ogd_queue, mock_gov_fcdo_ogd_user +): + url = reverse( + "cases:case", + kwargs={"queue_pk": data_ogd_queue["id"], "pk": data_standard_case["case"]["id"], "tab": "quick-summary"}, + ) + response = authorized_client.get(url) + assertTemplateUsed(response, "case/tabs/quick-summary.html") + assert "allocate_and_approve_form" in response.context + assert response.context["allocate_and_approve_form"].initial["return_to"] == reverse( + "cases:approve_all_legacy", kwargs={"queue_pk": data_ogd_queue["id"], "pk": data_standard_case["case"]["id"]} + ) + + +def test_case_summary_data(authorized_client, data_queue, data_standard_case, mock_queue): gov_user = { "id": "2a43805b-c082-47e7-9188-c8b3e1a83cb0", "email": "govuser@example.com", @@ -158,6 +218,7 @@ def test_case_summary_data(authorized_client, data_queue, data_standard_case): def test_case_summary_sub_status( data_standard_case, data_queue, + mock_queue, authorized_client, value, expected,