stages/prompt: add more tests

Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
Jens Langhammer 2021-06-07 17:40:06 +02:00
parent f23111beff
commit 25f987ba2b
2 changed files with 50 additions and 4 deletions

View file

@ -89,9 +89,7 @@ class PromptChallengeResponse(ChallengeResponse):
if len(all_passwords) > 1: if len(all_passwords) > 1:
raise ValidationError(_("Passwords don't match.")) raise ValidationError(_("Passwords don't match."))
def validate(self, attrs): def validate(self, attrs: dict[str, Any]) -> dict[str, Any]:
if attrs == {}:
return {}
# Check if we have two password fields, and make sure they are the same # Check if we have two password fields, and make sure they are the same
password_fields: QuerySet[Prompt] = self.stage.fields.filter( password_fields: QuerySet[Prompt] = self.stage.fields.filter(
type=FieldTypes.PASSWORD type=FieldTypes.PASSWORD
@ -172,7 +170,7 @@ class PromptStageView(ChallengeStageView):
return challenge return challenge
def get_response_instance(self, data: QueryDict) -> ChallengeResponse: def get_response_instance(self, data: QueryDict) -> ChallengeResponse:
if not self.executor.plan: if not self.executor.plan: # pragma: no cover
raise ValueError raise ValueError
return PromptChallengeResponse( return PromptChallengeResponse(
instance=None, instance=None,

View file

@ -4,6 +4,7 @@ from unittest.mock import MagicMock, patch
from django.test import Client, TestCase from django.test import Client, TestCase
from django.urls import reverse from django.urls import reverse
from django.utils.encoding import force_str from django.utils.encoding import force_str
from rest_framework.exceptions import ErrorDetail
from authentik.core.models import User from authentik.core.models import User
from authentik.flows.challenge import ChallengeTypes from authentik.flows.challenge import ChallengeTypes
@ -29,6 +30,13 @@ class TestPromptStage(TestCase):
slug="test-prompt", slug="test-prompt",
designation=FlowDesignation.AUTHENTICATION, designation=FlowDesignation.AUTHENTICATION,
) )
username_prompt = Prompt.objects.create(
field_key="username_prompt",
label="USERNAME_LABEL",
type=FieldTypes.USERNAME,
required=True,
placeholder="USERNAME_PLACEHOLDER",
)
text_prompt = Prompt.objects.create( text_prompt = Prompt.objects.create(
field_key="text_prompt", field_key="text_prompt",
label="TEXT_LABEL", label="TEXT_LABEL",
@ -73,6 +81,7 @@ class TestPromptStage(TestCase):
self.stage = PromptStage.objects.create(name="prompt-stage") self.stage = PromptStage.objects.create(name="prompt-stage")
self.stage.fields.set( self.stage.fields.set(
[ [
username_prompt,
text_prompt, text_prompt,
email_prompt, email_prompt,
password_prompt, password_prompt,
@ -84,6 +93,7 @@ class TestPromptStage(TestCase):
self.stage.save() self.stage.save()
self.prompt_data = { self.prompt_data = {
username_prompt.field_key: "test-username",
text_prompt.field_key: "test-input", text_prompt.field_key: "test-input",
email_prompt.field_key: "test@test.test", email_prompt.field_key: "test@test.test",
password_prompt.field_key: "test", password_prompt.field_key: "test",
@ -182,3 +192,41 @@ class TestPromptStage(TestCase):
for prompt in self.stage.fields.all(): for prompt in self.stage.fields.all():
prompt: Prompt prompt: Prompt
self.assertEqual(data[prompt.field_key], self.prompt_data[prompt.field_key]) self.assertEqual(data[prompt.field_key], self.prompt_data[prompt.field_key])
def test_invalid_password(self):
"""Test challenge_response validation"""
plan = FlowPlan(
flow_pk=self.flow.pk.hex, stages=[self.stage], markers=[StageMarker()]
)
self.prompt_data["password2_prompt"] = "qwerqwerqr"
challenge_response = PromptChallengeResponse(
None, stage=self.stage, plan=plan, data=self.prompt_data
)
self.assertEqual(challenge_response.is_valid(), False)
self.assertEqual(
challenge_response.errors,
{
"non_field_errors": [
ErrorDetail(string="Passwords don't match.", code="invalid")
]
},
)
def test_invalid_username(self):
"""Test challenge_response validation"""
plan = FlowPlan(
flow_pk=self.flow.pk.hex, stages=[self.stage], markers=[StageMarker()]
)
self.prompt_data["username_prompt"] = "akadmin"
challenge_response = PromptChallengeResponse(
None, stage=self.stage, plan=plan, data=self.prompt_data
)
self.assertEqual(challenge_response.is_valid(), False)
self.assertEqual(
challenge_response.errors,
{
"username_prompt": [
ErrorDetail(string="Username is already taken.", code="invalid")
]
},
)