-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
✅ [#246] Add tests for DigitaalAdres.is_standaard_adres
- Loading branch information
Showing
1 changed file
with
92 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,6 +2,7 @@ | |
from vng_api_common.tests import reverse | ||
|
||
from openklant.components.klantinteracties.constants import SoortDigitaalAdres | ||
from openklant.components.klantinteracties.models import DigitaalAdres | ||
from openklant.components.klantinteracties.models.tests.factories.digitaal_adres import ( | ||
DigitaalAdresFactory, | ||
) | ||
|
@@ -70,6 +71,7 @@ def test_create_digitaal_adres(self): | |
self.assertEqual(data["verstrektDoorPartij"], None) | ||
self.assertEqual(data["adres"], "[email protected]") | ||
self.assertEqual(data["omschrijving"], "omschrijving") | ||
self.assertEqual(data["isStandaardAdres"], False) | ||
|
||
with self.subTest("with_betrokkene_and_partij"): | ||
partij = PartijFactory.create() | ||
|
@@ -90,6 +92,47 @@ def test_create_digitaal_adres(self): | |
self.assertEqual(data["adres"], "[email protected]") | ||
self.assertEqual(data["omschrijving"], "omschrijving") | ||
|
||
def test_create_digitaal_adres_is_standaard_adres(self): | ||
""" | ||
Creating a DigitaalAdres with isStandaardAdres=True should make other existing | ||
DigitaalAdressen no longer the default | ||
""" | ||
# Since this has a different Partij, the value of `is_standaard_adres` should stay `True` | ||
partij1, partij2 = PartijFactory.create_batch(2) | ||
existing_adres_different_partij = DigitaalAdresFactory.create( | ||
partij=partij1, is_standaard_adres=True, soort_digitaal_adres="email" | ||
) | ||
# This adres has the same `soort_digitaal_adres` and `partij`, so the value of | ||
# `is_standaard_adres` should be changed to `False` if we change another one to `True` | ||
existing_adres = DigitaalAdresFactory.create( | ||
is_standaard_adres=True, soort_digitaal_adres="email", partij=partij2 | ||
) | ||
|
||
list_url = reverse("klantinteracties:digitaaladres-list") | ||
data = { | ||
"verstrektDoorBetrokkene": None, | ||
"verstrektDoorPartij": {"uuid": str(partij2.uuid)}, | ||
"soortDigitaalAdres": "email", | ||
"adres": "adres", | ||
"omschrijving": "omschrijving", | ||
"isStandaardAdres": True, | ||
} | ||
|
||
response = self.client.post(list_url, data) | ||
self.assertEqual(response.status_code, status.HTTP_201_CREATED) | ||
|
||
data = response.json() | ||
|
||
self.assertEqual(data["isStandaardAdres"], True) | ||
|
||
existing_adres_different_partij.refresh_from_db() | ||
existing_adres.refresh_from_db() | ||
new_adres = DigitaalAdres.objects.last() | ||
|
||
self.assertEqual(existing_adres_different_partij.is_standaard_adres, True) | ||
self.assertEqual(existing_adres.is_standaard_adres, False) | ||
self.assertEqual(new_adres.is_standaard_adres, True) | ||
|
||
def test_update_digitaal_adres(self): | ||
betrokkene, betrokkene2 = BetrokkeneFactory.create_batch(2) | ||
partij, partij2 = PartijFactory.create_batch(2) | ||
|
@@ -156,6 +199,55 @@ def test_update_digitaal_adres(self): | |
self.assertEqual(data["adres"], "0721434543") | ||
self.assertEqual(data["omschrijving"], "changed") | ||
|
||
def test_update_digitaal_adres_is_standaard_adres(self): | ||
""" | ||
Creating a DigitaalAdres with isStandaardAdres=True should make other existing | ||
DigitaalAdressen no longer the default | ||
""" | ||
partij1, partij2 = PartijFactory.create_batch(2) | ||
# Since this has a different Partij, the value of `is_standaard_adres` should stay `True` | ||
existing_adres_different_partij = DigitaalAdresFactory.create( | ||
partij=partij1, is_standaard_adres=True, soort_digitaal_adres="email" | ||
) | ||
# This adres has the same `soort_digitaal_adres` and `partij`, so the value of | ||
# `is_standaard_adres` should be changed to `False` if we change another one to `True` | ||
existing_adres = DigitaalAdresFactory.create( | ||
is_standaard_adres=True, soort_digitaal_adres="email", partij=partij2 | ||
) | ||
digitaal_adres = DigitaalAdresFactory.create( | ||
partij=partij2, | ||
soort_digitaal_adres="email", | ||
adres="adres", | ||
omschrijving="omschrijving", | ||
) | ||
detail_url = reverse( | ||
"klantinteracties:digitaaladres-detail", | ||
kwargs={"uuid": str(digitaal_adres.uuid)}, | ||
) | ||
|
||
data = { | ||
"verstrektDoorBetrokkene": {"uuid": str(digitaal_adres.betrokkene.uuid)}, | ||
"verstrektDoorPartij": {"uuid": str(partij2.uuid)}, | ||
"soortDigitaalAdres": "email", | ||
"isStandaardAdres": True, | ||
"adres": "changed", | ||
"omschrijving": "changed", | ||
} | ||
|
||
response = self.client.put(detail_url, data) | ||
|
||
data = response.json() | ||
|
||
self.assertEqual(data["isStandaardAdres"], True) | ||
|
||
existing_adres_different_partij.refresh_from_db() | ||
existing_adres.refresh_from_db() | ||
digitaal_adres.refresh_from_db() | ||
|
||
self.assertEqual(existing_adres_different_partij.is_standaard_adres, True) | ||
self.assertEqual(existing_adres.is_standaard_adres, False) | ||
self.assertEqual(digitaal_adres.is_standaard_adres, True) | ||
|
||
def test_partial_update_digitaal_adres(self): | ||
betrokkene = BetrokkeneFactory.create() | ||
partij = PartijFactory.create() | ||
|