OpenSlides/server/tests/integration/users/test_views.py

165 lines
5.1 KiB
Python
Raw Normal View History

import json
2018-08-22 06:22:28 +02:00
from django.urls import reverse
from rest_framework.test import APIClient
2021-03-18 16:06:55 +01:00
from openslides.users.models import User
2019-10-18 14:18:49 +02:00
from tests.test_case import TestCase
class TestWhoAmIView(TestCase):
2019-01-06 16:22:33 +01:00
url = reverse("user_whoami")
2019-10-18 14:18:49 +02:00
def setUp(self):
pass
def test_get_anonymous(self):
response = self.client.get(self.url)
self.assertEqual(response.status_code, 200)
self.assertEqual(
2015-12-11 15:47:22 +01:00
json.loads(response.content.decode()),
2019-08-20 12:00:54 +02:00
{
"auth_type": "default",
"user_id": None,
"user": None,
"permissions": [],
"guest_enabled": False,
},
2019-01-06 16:22:33 +01:00
)
def test_get_authenticated_user(self):
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
response = self.client.get(self.url)
self.assertEqual(response.status_code, 200)
2019-01-06 16:22:33 +01:00
self.assertEqual(json.loads(response.content.decode()).get("user_id"), 1)
self.assertEqual(
json.loads(response.content.decode()).get("guest_enabled"), False
)
def test_post(self):
response = self.client.post(self.url)
self.assertEqual(response.status_code, 405)
class TestUserLogoutView(TestCase):
2019-01-06 16:22:33 +01:00
url = reverse("user_logout")
2019-10-18 14:18:49 +02:00
def setUp(self):
pass
def test_get(self):
response = self.client.get(self.url)
self.assertEqual(response.status_code, 405)
def test_post_anonymous(self):
response = self.client.post(self.url)
self.assertEqual(response.status_code, 400)
def test_post_authenticated_user(self):
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
self.client.session["test_key"] = "test_value"
response = self.client.post(self.url)
self.assertEqual(response.status_code, 200)
2019-01-06 16:22:33 +01:00
self.assertFalse(hasattr(self.client.session, "test_key"))
2019-03-07 10:47:03 +01:00
self.assertEqual(
json.loads(response.content.decode()),
2019-08-20 12:00:54 +02:00
{
"auth_type": "default",
"user_id": None,
"user": None,
"permissions": [],
"guest_enabled": False,
},
2019-03-07 10:47:03 +01:00
)
class TestUserLoginView(TestCase):
2019-01-06 16:22:33 +01:00
url = reverse("user_login")
def setUp(self):
self.client = APIClient()
def test_get(self):
response = self.client.get(self.url)
self.assertEqual(response.status_code, 200)
2019-08-20 12:00:54 +02:00
content = json.loads(response.content.decode())
self.assertTrue("login_info_text" in content)
self.assertTrue("privacy_policy" in content)
self.assertTrue("legal_notice" in content)
self.assertTrue("theme" in content)
self.assertTrue("logo_web_header" in content)
def test_post_no_data(self):
response = self.client.post(self.url)
self.assertEqual(response.status_code, 400)
2021-03-18 16:06:55 +01:00
content = json.loads(response.content.decode())
self.assertEqual(content.get("detail"), "Username or password is not correct.")
def test_post_correct_data(self):
response = self.client.post(
2019-01-06 16:22:33 +01:00
self.url, {"username": "admin", "password": "admin"}
)
self.assertEqual(response.status_code, 200)
2019-08-20 12:00:54 +02:00
content = json.loads(response.content.decode())
self.assertEqual(content.get("user_id"), 1)
self.assertTrue(isinstance(content.get("user"), dict))
self.assertTrue(isinstance(content.get("permissions"), list))
self.assertFalse(content.get("guest_enabled", True))
self.assertEqual(content.get("auth_type"), "default")
def test_post_incorrect_data(self):
response = self.client.post(
2019-01-06 16:22:33 +01:00
self.url, {"username": "wrong", "password": "wrong"}
)
self.assertEqual(response.status_code, 400)
2021-03-18 16:06:55 +01:00
content = json.loads(response.content.decode())
self.assertEqual(content.get("detail"), "Username or password is not correct.")
def test_user_inactive(self):
admin = User.objects.get()
admin.is_active = False
admin.save()
response = self.client.post(
self.url, {"username": "admin", "password": "admin"}
)
self.assertEqual(response.status_code, 400)
content = json.loads(response.content.decode())
self.assertEqual(content.get("detail"), "You are not active.")
def test_user_wrong_auth_type(self):
admin = User.objects.get()
admin.auth_type = "not default"
admin.save()
response = self.client.post(
self.url, {"username": "admin", "password": "admin"}
)
self.assertEqual(response.status_code, 400)
content = json.loads(response.content.decode())
self.assertEqual(
content.get("detail"), "Please login via your identity provider."
)
def test_no_cookies(self):
response = self.client.post(
self.url, {"username": "admin", "password": "admin", "cookies": False}
)
self.assertEqual(response.status_code, 400)
content = json.loads(response.content.decode())
self.assertEqual(
content.get("detail"), "Cookies have to be enabled to use OpenSlides."
)