-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[#2808] Use KVK API to checkout legal status of compay at login
- Loading branch information
Paul Schilling
committed
Jan 10, 2025
1 parent
fbae2b8
commit 125b3b8
Showing
5 changed files
with
111 additions
and
31 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
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 |
---|---|---|
|
@@ -20,7 +20,6 @@ | |
from open_inwoner.kvk.branches import get_kvk_branch_number | ||
from open_inwoner.kvk.tests.factories import CertificateFactory | ||
from open_inwoner.openklant.tests.data import MockAPIReadPatchData | ||
from open_inwoner.openzaak.models import OpenZaakConfig | ||
from open_inwoner.utils.tests.helpers import AssertTimelineLogMixin | ||
|
||
from ...cms.collaborate.cms_apps import CollaborateApphook | ||
|
@@ -598,19 +597,20 @@ def test_eherkenning_fail_without_invite_redirects_to_login_page(self, m): | |
|
||
self.assertRedirectsLogin(response, with_host=True) | ||
|
||
@patch("open_inwoner.kvk.signals.KvKClient.get_basisprofiel", autospec=True) | ||
@patch( | ||
"open_inwoner.kvk.signals.KvKClient.retrieve_rsin_with_kvk", | ||
return_value="", | ||
autospec=True, | ||
) | ||
@patch( | ||
"open_inwoner.accounts.views.auth.OpenZaakConfig.get_solo", | ||
return_value=OpenZaakConfig(fetch_eherkenning_zaken_with_rsin=True), | ||
autospec=True, | ||
) | ||
def test_login_as_eenmanszaak_blocked( | ||
self, mock_oz_config, mock_retrieve_rsin_with_kvk | ||
self, | ||
mock_retrieve_rsin_with_kvk, | ||
mock_get_basisprofiel, | ||
): | ||
mock_get_basisprofiel.return_value = { | ||
"_embedded": {"eigenaar": {"rechtsvorm": "Eenmanszaak"}} | ||
} | ||
url = reverse("eherkenning-mock:password") | ||
params = { | ||
"acs": f"http://testserver{reverse('eherkenning:acs')}", | ||
|
@@ -693,6 +693,7 @@ def test_eherkenning_fail_with_invite_redirects_to_register_page(self, m): | |
f"http://testserver{reverse('django_registration_register')}?invite={invite.key}", | ||
) | ||
|
||
@patch("open_inwoner.kvk.signals.KvKClient.get_basisprofiel", autospec=True) | ||
@patch( | ||
"open_inwoner.kvk.signals.KvKClient.retrieve_rsin_with_kvk", | ||
return_value="123456789", | ||
|
@@ -711,10 +712,14 @@ def test_invite_url_not_in_session_after_successful_login( | |
mock_solo, | ||
mock_kvk, | ||
mock_retrieve_rsin_with_kvk, | ||
mock_get_basisprofiel, | ||
): | ||
mock_kvk.return_value = [ | ||
{"kvkNummer": "12345678", "vestigingsnummer": "1234"}, | ||
] | ||
mock_get_basisprofiel.return_value = { | ||
"_embedded": {"eigenaar": {"rechtsvorm": "Stichting"}} | ||
} | ||
|
||
mock_solo.return_value.api_key = "123" | ||
mock_solo.return_value.api_root = "http://foo.bar/api/v1/" | ||
|
@@ -758,11 +763,14 @@ def test_invite_url_not_in_session_after_successful_login( | |
# check company branch number in session | ||
self.assertEqual(get_kvk_branch_number(self.client.session), None) | ||
|
||
@patch("open_inwoner.kvk.signals.KvKClient.get_basisprofiel", autospec=True) | ||
@patch("open_inwoner.kvk.client.KvKClient.get_all_company_branches") | ||
@patch( | ||
"open_inwoner.kvk.models.KvKConfig.get_solo", | ||
) | ||
def test_redirect_flow_with_no_vestigingsnummer(self, mock_solo, mock_kvk): | ||
def test_redirect_flow_with_no_vestigingsnummer( | ||
self, mock_solo, mock_kvk, mock_get_basisprofiel | ||
): | ||
""" | ||
Assert that if the KvK API returns only a single company without vestigingsnummer: | ||
1. the redirect flow passes automatically through `KvKLoginMiddleware` | ||
|
@@ -771,6 +779,9 @@ def test_redirect_flow_with_no_vestigingsnummer(self, mock_solo, mock_kvk): | |
mock_kvk.return_value = [ | ||
{"kvkNummer": "12345678"}, | ||
] | ||
mock_get_basisprofiel.return_value = { | ||
"_embedded": {"eigenaar": {"rechtsvorm": "Stichting"}} | ||
} | ||
|
||
mock_solo.return_value.api_key = "123" | ||
mock_solo.return_value.api_root = "http://foo.bar/api/v1/" | ||
|
@@ -1139,6 +1150,7 @@ def test_digid_user_success(self): | |
self.assertEqual(users.first().email, "[email protected]") | ||
self.assertEqual(users.last().email, "[email protected]") | ||
|
||
@patch("open_inwoner.kvk.signals.KvKClient.get_basisprofiel", autospec=True) | ||
@patch( | ||
"open_inwoner.kvk.signals.KvKClient.retrieve_rsin_with_kvk", | ||
return_value="123456789", | ||
|
@@ -1148,7 +1160,9 @@ def test_digid_user_success(self): | |
"open_inwoner.kvk.client.KvKClient.get_all_company_branches", | ||
autospec=True, | ||
) | ||
def test_eherkenning_user_success(self, mock_kvk, mock_retrieve_rsin_with_kvk): | ||
def test_eherkenning_user_success( | ||
self, mock_kvk, mock_retrieve_rsin_with_kvk, mock_get_basisprofiel | ||
): | ||
"""Assert that eHerkenning users can register with duplicate emails""" | ||
|
||
mock_kvk.return_value = [ | ||
|
@@ -1163,6 +1177,9 @@ def test_eherkenning_user_success(self, mock_kvk, mock_retrieve_rsin_with_kvk): | |
"naam": "Mijn bedrijf", | ||
}, | ||
] | ||
mock_get_basisprofiel.return_value = { | ||
"_embedded": {"eigenaar": {"rechtsvorm": "Stichting"}} | ||
} | ||
|
||
test_user = eHerkenningUserFactory.create( | ||
email="test@localhost", | ||
|
Oops, something went wrong.