
* flows: add initial inspector Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: change naming a bit Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web/flow: add inspector frame Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * core: don't use shadydom when inspecting Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: add current stage to api Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * stages/*: fix imports Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: deep-copy plan instead of just adding Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web/flows: ui Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: restrict inspector to admin Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web/admin: add buttons to launch flow with inspector Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web/flows: don't automatically follow redirects when inspector is open Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: make current_plan optional, only require historry Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web/flows: handle error messages in inspector Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web/flows: improve UI when flow is done Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: add is_completed flag to inspector Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: fix monkeypatches for tests Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: add inspector tests Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * ci: re-enable cache Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
41 lines
1.5 KiB
Python
41 lines
1.5 KiB
Python
"""flow views tests"""
|
|
from django.test import TestCase
|
|
from django.urls import reverse
|
|
|
|
from authentik.flows.models import Flow, FlowDesignation
|
|
from authentik.flows.planner import FlowPlan
|
|
from authentik.flows.views.executor import SESSION_KEY_PLAN
|
|
|
|
|
|
class TestHelperView(TestCase):
|
|
"""Test helper views logic"""
|
|
|
|
def test_default_view(self):
|
|
"""Test that ToDefaultFlow returns the expected URL"""
|
|
flow = Flow.objects.filter(
|
|
designation=FlowDesignation.INVALIDATION,
|
|
).first()
|
|
response = self.client.get(
|
|
reverse("authentik_flows:default-invalidation"),
|
|
)
|
|
expected_url = reverse("authentik_core:if-flow", kwargs={"flow_slug": flow.slug})
|
|
self.assertEqual(response.status_code, 302)
|
|
self.assertEqual(response.url, expected_url)
|
|
|
|
def test_default_view_invalid_plan(self):
|
|
"""Test that ToDefaultFlow returns the expected URL (with an invalid plan)"""
|
|
flow = Flow.objects.filter(
|
|
designation=FlowDesignation.INVALIDATION,
|
|
).first()
|
|
plan = FlowPlan(flow_pk=flow.pk.hex + "aa")
|
|
session = self.client.session
|
|
session[SESSION_KEY_PLAN] = plan
|
|
session.save()
|
|
|
|
response = self.client.get(
|
|
reverse("authentik_flows:default-invalidation"),
|
|
)
|
|
expected_url = reverse("authentik_core:if-flow", kwargs={"flow_slug": flow.slug})
|
|
self.assertEqual(response.status_code, 302)
|
|
self.assertEqual(response.url, expected_url)
|