Skip to content

Commit

Permalink
[#1788] Include submissions in cases
Browse files Browse the repository at this point in the history
  • Loading branch information
pi-sigma committed Oct 10, 2023
1 parent 3e2e563 commit d5f659d
Show file tree
Hide file tree
Showing 15 changed files with 168 additions and 253 deletions.
4 changes: 2 additions & 2 deletions src/open_inwoner/accounts/tests/test_auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -955,7 +955,7 @@ def test_non_digid_user_can_edit_profile(self):
form = edit_page.forms["profile-edit"]
form["first_name"] = "changed_first"
form["last_name"] = "changed_last"
response = form.submit()
form.submit()

user = User.objects.get(id=test_user.id)

Expand Down Expand Up @@ -994,7 +994,7 @@ def test_any_page_for_digid_user_redirect_to_necessary_fields(self):
urls = [
reverse("pages-root"),
reverse("products:category_list"),
reverse("cases:open_cases"),
reverse("cases:index"),
reverse("profile:detail"),
reverse("profile:data"),
reverse("collaborate:plan_list"),
Expand Down
10 changes: 1 addition & 9 deletions src/open_inwoner/cms/cases/urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,27 +6,19 @@
KlantContactMomentListView,
)

from .views import ( # TODO: delete; TODO
from .views import (
CaseContactFormView,
CaseDocumentDownloadView,
CaseDocumentUploadFormView,
InnerCaseDetailView,
InnerCaseListView,
InnerOpenSubmissionListView,
OuterCaseDetailView,
OuterCaseListView,
OuterOpenSubmissionListView,
)

app_name = "cases"

urlpatterns = [
path("forms/", OuterOpenSubmissionListView.as_view(), name="open_submissions"),
path(
"forms/content/",
InnerOpenSubmissionListView.as_view(),
name="open_submissions_content",
),
path(
"contactmomenten/",
KlantContactMomentListView.as_view(),
Expand Down
1 change: 0 additions & 1 deletion src/open_inwoner/cms/cases/views/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,3 @@
InnerCaseDetailView,
OuterCaseDetailView,
)
from .submissions import InnerOpenSubmissionListView, OuterOpenSubmissionListView
9 changes: 6 additions & 3 deletions src/open_inwoner/cms/cases/views/cases.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,12 @@
from view_breadcrumbs import BaseBreadcrumbMixin

from open_inwoner.htmx.mixins import RequiresHtmxMixin
from open_inwoner.openzaak.formapi import fetch_open_submissions
from open_inwoner.utils.views import CommonPageMixin

from .mixins import CaseAccessMixin, CaseListMixin, OuterCaseAccessMixin


# TODO add OuterCaseAccessMixin back
class OuterCaseListView(
OuterCaseAccessMixin, CommonPageMixin, BaseBreadcrumbMixin, TemplateView
):
Expand All @@ -33,7 +33,6 @@ def get_context_data(self, **kwargs):
return context


# TODO: add CaseAccessMixin back
class InnerCaseListView(
RequiresHtmxMixin, CommonPageMixin, CaseAccessMixin, CaseListMixin, TemplateView
):
Expand All @@ -46,9 +45,13 @@ def page_title(self):

def get_cases(self):
cases = super().get_cases()
subs = fetch_open_submissions(self.request.user.bsn)

cases.sort(key=lambda case: case.startdatum, reverse=True)
return cases
subs.sort(key=lambda sub: sub.datum_laatste_wijziging, reverse=True)

all_cases = subs + cases
return all_cases

def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
Expand Down
43 changes: 30 additions & 13 deletions src/open_inwoner/cms/cases/views/mixins.py
Original file line number Diff line number Diff line change
Expand Up @@ -145,17 +145,32 @@ def process_cases(self, cases: List[Zaak]) -> List[dict]:

updated_cases = []
for case in cases:
case_dict = {
"identificatie": format_zaak_identificatie(case.identificatie, config),
"uuid": str(case.uuid),
"start_date": case.startdatum,
"end_date": getattr(case, "einddatum", None),
"description": case.zaaktype.omschrijving,
"current_status": status_translate.from_glom(
case, "status.statustype.omschrijving", default=""
),
}
updated_cases.append(case_dict)
try:
# cases
case_dict = {
"identificatie": format_zaak_identificatie(
case.identificatie, config
),
"uuid": str(case.uuid),
"start_date": case.startdatum,
"end_date": getattr(case, "einddatum", None),
"description": case.zaaktype.omschrijving,
"current_status": status_translate.from_glom(
case, "status.statustype.omschrijving", default=""
),
}
updated_cases.append(case_dict)
except AttributeError:
# submissions are now cases too
case_dict = {
"url": case.url,
"uuid": case.uuid,
"naam": case.naam,
"vervolg_link": case.vervolg_link,
"datum_laatste_wijziging": case.datum_laatste_wijziging,
"eind_datum_geldigheid": case.eind_datum_geldigheid,
}
updated_cases.append(case_dict)
return updated_cases

def get_context_data(self, **kwargs):
Expand All @@ -169,9 +184,11 @@ def get_context_data(self, **kwargs):
context.update(paginator_dict)

for case in cases:
self.log_case_access(case["identificatie"])
try:
self.log_case_access(case["identificatie"])
except KeyError:
self.log_case_access(f"{case['naam']}: {case['uuid']}")

context["anchors"] = self.get_anchors()
return context

def get_anchors(self) -> list:
Expand Down
4 changes: 2 additions & 2 deletions src/open_inwoner/cms/cases/views/status.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ class OuterCaseDetailView(
@cached_property
def crumbs(self):
return [
(_("Mijn aanvragen"), reverse("cases:open_cases")),
(_("Mijn aanvragen"), reverse("cases:index")),
(
_("Status"),
reverse("cases:case_detail", kwargs=self.kwargs),
Expand All @@ -95,7 +95,7 @@ class InnerCaseDetailView(
@cached_property
def crumbs(self):
return [
(_("Mijn aanvragen"), reverse("cases:open_cases")),
(_("Mijn aanvragen"), reverse("cases:index")),
(
_("Status"),
reverse("cases:case_detail", kwargs=self.kwargs),
Expand Down
72 changes: 0 additions & 72 deletions src/open_inwoner/cms/cases/views/submissions.py

This file was deleted.

3 changes: 1 addition & 2 deletions src/open_inwoner/openzaak/tests/factories.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,12 @@
from simple_certmanager.constants import CertificateTypes
from simple_certmanager.models import Certificate
from zgw_consumers.api_models.base import factory as zwg_factory
from zgw_consumers.api_models.catalogi import InformatieObjectType
from zgw_consumers.api_models.constants import RolOmschrijving
from zgw_consumers.models import Service
from zgw_consumers.test import generate_oas_component

from open_inwoner.accounts.tests.factories import UserFactory
from open_inwoner.openzaak.api_models import Notification, Rol, ZaakType
from open_inwoner.openzaak.api_models import Notification, Rol
from open_inwoner.openzaak.models import (
CatalogusConfig,
StatusTranslation,
Expand Down
42 changes: 42 additions & 0 deletions src/open_inwoner/openzaak/tests/mocks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
from zgw_consumers.test import mock_service_oas_get

from open_inwoner.openzaak.tests.shared import FORMS_ROOT


class ESuiteData:
def __init__(self):
self.submission_1 = {
"url": "https://dmidoffice2.esuite-development.net/formulieren-provider/api/v1/8e3ae29c-7bc5-4f7d-a27c-b0c83c13328e",
"uuid": "8e3ae29c-7bc5-4f7d-a27c-b0c83c13328e",
"naam": "Melding openbare ruimte",
"vervolgLink": "https://dloket2.esuite-development.net/formulieren-nieuw/formulier/start/8e3ae29c-7bc5-4f7d-a27c-b0c83c13328e",
"datumLaatsteWijziging": "2023-02-13T14:02:00.999+01:00",
"eindDatumGeldigheid": "2023-05-14T14:02:00.999+02:00",
}
self.submission_2 = {
"url": "https://dmidoffice2.esuite-development.net/formulieren-provider/api/v1/d14658b0-dcb4-4d3c-a61c-fd7d0c78f296",
"uuid": "d14658b0-dcb4-4d3c-a61c-fd7d0c78f296",
"naam": "Indienen bezwaarschrift",
"vervolgLink": "https://dloket2.esuite-development.net/formulieren-nieuw/formulier/start/d14658b0-dcb4-4d3c-a61c-fd7d0c78f296",
"datumLaatsteWijziging": "2023-02-13T14:10:26.197000+0100",
"eindDatumGeldigheid": "2023-05-14T14:10:26.197+02:00",
}
# note this is a weird esuite response without pagination links
self.response = {
"count": 2,
"results": [
self.submission_1,
self.submission_2,
],
}

def setUpOASMocks(self, m):
mock_service_oas_get(m, FORMS_ROOT, "submissions-esuite")

def install_mocks(self, m):
self.setUpOASMocks(m)
m.get(
f"{FORMS_ROOT}openstaande-inzendingen",
json=self.response,
)
return self
53 changes: 51 additions & 2 deletions src/open_inwoner/openzaak/tests/test_cases.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,14 @@
from open_inwoner.accounts.choices import LoginTypeChoices
from open_inwoner.accounts.tests.factories import UserFactory
from open_inwoner.cms.cases.views.mixins import CaseListMixin
from open_inwoner.openzaak.tests.shared import FORMS_ROOT
from open_inwoner.utils.test import ClearCachesMixin, paginated_response

from ...utils.tests.helpers import AssertRedirectsMixin
from ..models import OpenZaakConfig
from ..utils import format_zaak_identificatie
from .factories import ServiceFactory, StatusTranslationFactory
from .mocks import ESuiteData
from .shared import CATALOGI_ROOT, ZAKEN_ROOT


Expand Down Expand Up @@ -133,8 +135,6 @@ def test_no_cases_are_retrieved_when_http_500(self, m):
@requests_mock.Mocker()
@override_settings(ROOT_URLCONF="open_inwoner.cms.tests.urls")
class CaseListViewTests(ClearCachesMixin, WebTest):
# inner_url_open = reverse_lazy("cases:open_cases_content")
# inner_url_closed = reverse_lazy("cases:closed_cases_content")
inner_url = reverse_lazy("cases:cases_content")

@classmethod
Expand Down Expand Up @@ -285,6 +285,14 @@ def setUpTestData(cls):
datumStatusGezet="2021-01-12",
statustoelichting="",
)
cls.submission = generate_oas_component(
"zrc",
"schemas/Zaak",
url=f"{ZAKEN_ROOT}zaken/d8bbdeb7-770f-4ca9-b1ea-77b4ee0bf67d",
uuid="c8yudeb7-490f-2cw9-h8wa-44h9830bf67d",
naam="mysub",
datum_laatste_wijziging="2023-10-10",
)

def _setUpMocks(self, m):
mock_service_oas_get(m, ZAKEN_ROOT, "zrc")
Expand Down Expand Up @@ -533,3 +541,44 @@ def test_list_cases_paginated_logs_displayed_case_ids(self, m):
for log in logs:
self.assertNotIn(self.zaak2["identificatie"], log.extra_data["message"])
self.assertNotIn(self.zaak3["identificatie"], log.extra_data["message"])


@override_settings(ROOT_URLCONF="open_inwoner.cms.tests.urls")
class CaseSubmissionTest(WebTest):
inner_url = reverse_lazy("cases:cases_content")

@classmethod
def setUpTestData(cls):
super().setUpTestData()

cls.config = OpenZaakConfig.get_solo()
cls.config.form_service = ServiceFactory(
api_root=FORMS_ROOT, api_type=APITypes.orc
)
cls.config.save()

@requests_mock.Mocker()
def test_case_submission(self, m):
user = UserFactory(
login_type=LoginTypeChoices.digid, bsn="900222086", email="john@smith.nl"
)

data = ESuiteData().install_mocks(m)

response = self.app.get(
self.inner_url, user=user, headers={"HX-Request": "true"}
)

cases = response.context["cases"]

self.assertEqual(len(cases), 2)

# submission cases are sorted in reverse by `last modified`
self.assertEqual(cases[0]["url"], data.submission_2["url"])
self.assertEqual(cases[0]["uuid"], data.submission_2["uuid"])
self.assertEqual(cases[0]["naam"], data.submission_2["naam"])
self.assertEqual(cases[0]["vervolg_link"], data.submission_2["vervolgLink"])
self.assertEqual(
cases[0]["datum_laatste_wijziging"].strftime("%Y-%m-%dT%H:%M:%S.%f%z"),
data.submission_2["datumLaatsteWijziging"],
)
Loading

0 comments on commit d5f659d

Please sign in to comment.