Skip to content

Commit

Permalink
✅ [#1902/1903] Tests for DigiD/eHerkenning via OIDC
Browse files Browse the repository at this point in the history
  • Loading branch information
stevenbal committed Dec 5, 2023
1 parent 0979edb commit b1fcb69
Show file tree
Hide file tree
Showing 2 changed files with 158 additions and 25 deletions.
126 changes: 102 additions & 24 deletions src/open_inwoner/accounts/tests/test_auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,10 @@
from furl import furl
from pyquery import PyQuery as PQ

from digid_eherkenning_oidc_generics.models import (
OpenIDConnectEHerkenningConfig,
OpenIDConnectPublicConfig,
)
from open_inwoner.configurations.models import SiteConfiguration
from open_inwoner.contrib.kvk.models import KvKConfig
from open_inwoner.contrib.kvk.tests.factories import CertificateFactory
Expand Down Expand Up @@ -42,20 +46,31 @@ class DigiDRegistrationTest(AssertRedirectsMixin, HaalCentraalMixin, WebTest):
def setUpTestData(cls):
cms_tools.create_homepage()

def test_registration_page_only_digid(self):
response = self.app.get(self.url)
@patch("digid_eherkenning_oidc_generics.models.OpenIDConnectPublicConfig.get_solo")
def test_registration_page_only_digid(self, mock_solo):
for oidc_enabled in [True, False]:
with self.subTest(oidc_enabled=oidc_enabled):
mock_solo.return_value.enabled = oidc_enabled

self.assertEqual(response.status_code, 200)
self.assertIsNone(response.html.find(id="registration-form"))
digid_url = (
reverse("digid_oidc:init")
if oidc_enabled
else reverse("digid:login")
)

digid_tag = response.html.find("a", title="Registreren met DigiD")
self.assertIsNotNone(digid_tag)
self.assertEqual(
digid_tag.attrs["href"],
furl(reverse("digid:login"))
.add({"next": reverse("profile:registration_necessary")})
.url,
)
response = self.app.get(self.url)

self.assertEqual(response.status_code, 200)
self.assertIsNone(response.html.find(id="registration-form"))

digid_tag = response.html.find("a", title="Registreren met DigiD")
self.assertIsNotNone(digid_tag)
self.assertEqual(
digid_tag.attrs["href"],
furl(digid_url)
.add({"next": reverse("profile:registration_necessary")})
.url,
)

def test_registration_page_only_digid_with_invite(self):
invite = InviteFactory.create()
Expand Down Expand Up @@ -422,24 +437,39 @@ class eHerkenningRegistrationTest(AssertRedirectsMixin, WebTest):
def setUpTestData(cls):
cms_tools.create_homepage()

@patch(
"digid_eherkenning_oidc_generics.models.OpenIDConnectEHerkenningConfig.get_solo"
)
@patch("open_inwoner.configurations.models.SiteConfiguration.get_solo")
def test_registration_page_eherkenning(self, mock_solo):
def test_registration_page_eherkenning(self, mock_solo, mock_eherkenning_config):
mock_solo.return_value.eherkenning_enabled = True
mock_solo.return_value.login_allow_registration = False

response = self.app.get(self.url)
for oidc_enabled in [True, False]:
with self.subTest(oidc_enabled=oidc_enabled):
mock_eherkenning_config.return_value.enabled = oidc_enabled

self.assertEqual(response.status_code, 200)
self.assertIsNone(response.html.find(id="registration-form"))
eherkenning_url = (
reverse("eherkenning_oidc:init")
if oidc_enabled
else reverse("eherkenning:login")
)

eherkenning_tag = response.html.find("a", title="Registreren met eHerkenning")
self.assertIsNotNone(eherkenning_tag)
self.assertEqual(
eherkenning_tag.attrs["href"],
furl(reverse("eherkenning:login"))
.add({"next": reverse("profile:registration_necessary")})
.url,
)
response = self.app.get(self.url)

self.assertEqual(response.status_code, 200)
self.assertIsNone(response.html.find(id="registration-form"))

eherkenning_tag = response.html.find(
"a", title="Registreren met eHerkenning"
)
self.assertIsNotNone(eherkenning_tag)
self.assertEqual(
eherkenning_tag.attrs["href"],
furl(eherkenning_url)
.add({"next": reverse("profile:registration_necessary")})
.url,
)

@patch("open_inwoner.configurations.models.SiteConfiguration.get_solo")
def test_registration_page_eherkenning_with_invite(self, mock_solo):
Expand Down Expand Up @@ -1453,6 +1483,54 @@ def test_login(self):
# Verify that the user has been authenticated
self.assertIn("_auth_user_id", self.app.session)

def test_login_page_shows_correct_digid_login_url(self):
config = OpenIDConnectPublicConfig.get_solo()

for oidc_enabled in [True, False]:
with self.subTest(oidc_enabled=oidc_enabled):
config.enabled = oidc_enabled
config.save()

login_url = (
reverse("digid_oidc:init")
if oidc_enabled
else f"{reverse('digid:login')}?next="
)

response = self.app.get(reverse("login"))

digid_login_title = _("Inloggen met DigiD")
digid_login_link = response.pyquery(f"[title='{digid_login_title}']")

self.assertEqual(digid_login_link.attr("href"), login_url)

def test_login_page_shows_correct_eherkenning_login_url(self):
site_config = SiteConfiguration.get_solo()
site_config.eherkenning_enabled = True
site_config.save()

config = OpenIDConnectEHerkenningConfig.get_solo()

for oidc_enabled in [True, False]:
with self.subTest(oidc_enabled=oidc_enabled):
config.enabled = oidc_enabled
config.save()

login_url = (
reverse("eherkenning_oidc:init")
if oidc_enabled
else f"{reverse('eherkenning:login')}?next="
)

response = self.app.get(reverse("login"))

eherkenning_login_title = _("Inloggen met eHerkenning")
eherkenning_login_link = response.pyquery(
f"[title='{eherkenning_login_title}']"
)

self.assertEqual(eherkenning_login_link.attr("href"), login_url)

def test_login_for_inactive_user_shows_appropriate_message(self):
# Change user to inactive
self.user.is_active = False
Expand Down
57 changes: 56 additions & 1 deletion src/open_inwoner/accounts/tests/test_profile_views.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,12 @@
from ..choices import ContactTypeChoices, LoginTypeChoices
from ..forms import BrpUserForm, UserForm
from ..models import User
from .factories import ActionFactory, DigidUserFactory, DocumentFactory, UserFactory
from .factories import (
ActionFactory,
DigidUserFactory,
UserFactory,
eHerkenningUserFactory,
)


@override_settings(ROOT_URLCONF="open_inwoner.cms.tests.urls")
Expand All @@ -37,6 +42,8 @@ def setUp(self):
self.url = reverse("profile:detail")
self.return_url = reverse("logout")
self.user = UserFactory(street="MyStreet")
self.digid_user = DigidUserFactory()
self.eherkenning_user = eHerkenningUserFactory()

self.action_deleted = ActionFactory(
name="deleted action, should not show up",
Expand All @@ -57,6 +64,54 @@ def test_login_required(self):
response = self.app.get(self.url)
self.assertRedirects(response, f"{login_url}?next={self.url}")

def test_show_correct_logout_button_for_login_type_default(self):
response = self.app.get(self.url, user=self.user)

logout_title = _("Logout")
logout_link = response.pyquery.find(f"[title='{logout_title}']")

self.assertEqual(logout_link.attr("href"), reverse("logout"))

@patch("digid_eherkenning_oidc_generics.models.OpenIDConnectPublicConfig.get_solo")
def test_show_correct_logout_button_for_login_type_digid(self, mock_solo):
for oidc_enabled in [True, False]:
with self.subTest(oidc_enabled=oidc_enabled):
mock_solo.return_value.enabled = oidc_enabled

logout_url = (
reverse("digid_oidc:logout")
if oidc_enabled
else reverse("digid:logout")
)

response = self.app.get(self.url, user=self.digid_user)

logout_title = _("Logout")
logout_link = response.pyquery.find(f"[title='{logout_title}']")

self.assertEqual(logout_link.attr("href"), logout_url)

@patch(
"digid_eherkenning_oidc_generics.models.OpenIDConnectEHerkenningConfig.get_solo"
)
def test_show_correct_logout_button_for_login_type_eherkenning(self, mock_solo):
for oidc_enabled in [True, False]:
with self.subTest(oidc_enabled=oidc_enabled):
mock_solo.return_value.enabled = oidc_enabled

logout_url = (
reverse("eherkenning_oidc:logout")
if oidc_enabled
else reverse("eherkenning:logout")
)

response = self.app.get(self.url, user=self.eherkenning_user)

logout_title = _("Logout")
logout_link = response.pyquery.find(f"[title='{logout_title}']")

self.assertEqual(logout_link.attr("href"), logout_url)

def test_user_information_profile_page(self):
response = self.app.get(self.url, user=self.user)

Expand Down

0 comments on commit b1fcb69

Please sign in to comment.