9bb0d04aeb
* root: add pytest-randomly to randomise tests Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * *: generate flows for testing instead of relying on existing ones Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * *: generate users for testing instead of relying on existing ones Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * *: use generated certificate Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * tests/e2e: keep containers Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * tests/e2e: use websockets test case Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
53 lines
1.7 KiB
Python
53 lines
1.7 KiB
Python
"""Test bindings API"""
|
|
from django.urls import reverse
|
|
from rest_framework.test import APITestCase
|
|
|
|
from authentik.core.tests.utils import create_test_admin_user
|
|
from authentik.policies.models import PolicyBindingModel
|
|
|
|
|
|
class TestBindingsAPI(APITestCase):
|
|
"""Test bindings API"""
|
|
|
|
def setUp(self) -> None:
|
|
super().setUp()
|
|
self.pbm = PolicyBindingModel.objects.create()
|
|
self.user = create_test_admin_user()
|
|
self.group = self.user.ak_groups.first()
|
|
self.client.force_login(self.user)
|
|
|
|
def test_valid_binding(self):
|
|
"""Test valid binding"""
|
|
response = self.client.post(
|
|
reverse("authentik_api:policybinding-list"),
|
|
data={"target": self.pbm.pk, "user": self.user.pk, "order": 0},
|
|
)
|
|
self.assertEqual(response.status_code, 201)
|
|
|
|
def test_invalid_too_much(self):
|
|
"""Test invalid binding (too much)"""
|
|
response = self.client.post(
|
|
reverse("authentik_api:policybinding-list"),
|
|
data={
|
|
"target": self.pbm.pk,
|
|
"user": self.user.pk,
|
|
"group": self.group.pk,
|
|
"order": 0,
|
|
},
|
|
)
|
|
self.assertJSONEqual(
|
|
response.content.decode(),
|
|
{"non_field_errors": ["Only one of 'policy', 'group' or 'user' can be set."]},
|
|
)
|
|
|
|
def test_invalid_too_little(self):
|
|
"""Test invvalid binding (too little)"""
|
|
response = self.client.post(
|
|
reverse("authentik_api:policybinding-list"),
|
|
data={"target": self.pbm.pk, "order": 0},
|
|
)
|
|
self.assertJSONEqual(
|
|
response.content.decode(),
|
|
{"non_field_errors": ["One of 'policy', 'group' or 'user' must be set."]},
|
|
)
|