OpenSlides/tests/integration/core/test_views.py

263 lines
8.9 KiB
Python
Raw Normal View History

import json
from django.urls import reverse
from rest_framework import status
2015-06-29 12:08:15 +02:00
from rest_framework.test import APIClient
2019-01-06 16:22:33 +01:00
from openslides import __license__ as license, __url__ as url, __version__ as version
from openslides.core.config import ConfigVariable, config
2015-06-29 12:08:15 +02:00
from openslides.utils.rest_api import ValidationError
from openslides.utils.test import TestCase
class ProjectorAPI(TestCase):
def test_slide_on_default_projector(self):
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
self.client.put(
reverse("projector-detail", args=["1"]),
{"elements": [{"name": "topics/topic", "id": 1}]},
content_type="application/json",
2019-01-06 16:22:33 +01:00
)
2019-01-06 16:22:33 +01:00
response = self.client.get(reverse("projector-detail", args=["1"]))
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_invalid_element_non_existing_slide(self):
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
response = self.client.put(
reverse("projector-detail", args=["1"]),
{"elements": [{"name": "invalid_slide_name", "id": 1}]},
content_type="application/json",
)
self.assertEqual(response.status_code, 400)
def test_invalid_element_no_name_attribute(self):
self.client.login(username="admin", password="admin")
response = self.client.put(
reverse("projector-detail", args=["1"]),
{"elements": [{"id": 1}]},
content_type="application/json",
2019-01-06 16:22:33 +01:00
)
2015-06-18 21:48:20 +02:00
self.assertEqual(response.status_code, 400)
def test_invalid_element_not_a_inner_dict(self):
self.client.login(username="admin", password="admin")
response = self.client.put(
reverse("projector-detail", args=["1"]),
{"elements": ["not a dict"]},
content_type="application/json",
)
self.assertEqual(response.status_code, 400)
def test_invalid_element_a_list(self):
self.client.login(username="admin", password="admin")
response = self.client.put(
reverse("projector-detail", args=["1"]),
{"elements": {"name": "invalid_slide_name", "id": 1}},
content_type="application/json",
)
self.assertEqual(response.status_code, 400)
2015-06-18 21:48:20 +02:00
class VersionView(TestCase):
"""
Tests the version info view.
"""
2019-01-06 16:22:33 +01:00
2015-06-18 21:48:20 +02:00
def test_get(self):
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
response = self.client.get(reverse("core_version"))
self.assertEqual(
json.loads(response.content.decode()),
{
"openslides_version": version,
"openslides_license": license,
"openslides_url": url,
"plugins": [
{
"verbose_name": "OpenSlides Test Plugin",
"description": "This is a test plugin for OpenSlides.",
"version": "unknown",
"license": "MIT",
"url": "",
}
],
},
)
2015-06-29 12:08:15 +02:00
class ConfigViewSet(TestCase):
"""
Tests requests to deal with config variables.
"""
2019-01-06 16:22:33 +01:00
def setUp(self):
# Save the old value of the config object and add the test values
# TODO: Can be changed to setUpClass when Django 1.8 is no longer supported
self._config_values = config.config_variables.copy()
config.key_to_id = None
2016-06-08 22:18:35 +02:00
config.update_config_variables(set_simple_config_view_integration_config_test())
2017-08-22 14:17:20 +02:00
config.save_default_values()
def tearDown(self):
# Reset the config variables
config.config_variables = self._config_values
2017-08-22 14:17:20 +02:00
super().tearDown()
2015-06-29 12:08:15 +02:00
def test_update(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
2015-06-29 12:08:15 +02:00
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_Xeiizi7ooH8Thuk5aida"]),
{"value": "test_value_Phohx3oopeichaiTheiw"},
)
2015-06-29 12:08:15 +02:00
self.assertEqual(response.status_code, status.HTTP_200_OK)
2019-01-06 16:22:33 +01:00
self.assertEqual(
config["test_var_Xeiizi7ooH8Thuk5aida"], "test_value_Phohx3oopeichaiTheiw"
)
2015-06-29 12:08:15 +02:00
def test_update_wrong_datatype(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
2015-06-29 12:08:15 +02:00
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_ohhii4iavoh5Phoh5ahg"]),
{"value": "test_value_string"},
)
2015-06-29 12:08:15 +02:00
self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
2019-01-06 16:22:33 +01:00
self.assertEqual(
response.data,
{"detail": "Wrong datatype. Expected <class 'int'>, got <class 'str'>."},
)
2015-06-29 12:08:15 +02:00
def test_update_wrong_datatype_that_can_be_converted(self):
"""
Try to send a string that can be converted to an integer to an integer
field.
"""
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_ohhii4iavoh5Phoh5ahg"]),
{"value": "12345"},
)
self.assertEqual(response.status_code, 200)
2015-06-29 12:08:15 +02:00
def test_update_good_choice(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
2015-06-29 12:08:15 +02:00
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_wei0Rei9ahzooSohK1ph"]),
{"value": "key_2_yahb2ain1aeZ1lea1Pei"},
)
2015-06-29 12:08:15 +02:00
self.assertEqual(response.status_code, status.HTTP_200_OK)
2019-01-06 16:22:33 +01:00
self.assertEqual(
config["test_var_wei0Rei9ahzooSohK1ph"], "key_2_yahb2ain1aeZ1lea1Pei"
)
2015-06-29 12:08:15 +02:00
def test_update_bad_choice(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
2015-06-29 12:08:15 +02:00
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_wei0Rei9ahzooSohK1ph"]),
{"value": "test_value_bad_string"},
)
2015-06-29 12:08:15 +02:00
self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
2019-01-06 16:22:33 +01:00
self.assertEqual(
response.data, {"detail": "Invalid input. Choice does not match."}
)
2015-06-29 12:08:15 +02:00
def test_update_validator_ok(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
2015-06-29 12:08:15 +02:00
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_Hi7Oje8Oith7goopeeng"]),
{"value": "valid_string"},
)
2015-06-29 12:08:15 +02:00
self.assertEqual(response.status_code, status.HTTP_200_OK)
2019-01-06 16:22:33 +01:00
self.assertEqual(config["test_var_Hi7Oje8Oith7goopeeng"], "valid_string")
2015-06-29 12:08:15 +02:00
def test_update_validator_invalid(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
2015-06-29 12:08:15 +02:00
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_Hi7Oje8Oith7goopeeng"]),
{"value": "invalid_string"},
)
2015-06-29 12:08:15 +02:00
self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
2019-01-06 16:22:33 +01:00
self.assertEqual(response.data, {"detail": "Invalid input."})
2015-06-29 12:08:15 +02:00
def test_update_only_with_key(self):
self.client = APIClient()
2019-01-06 16:22:33 +01:00
self.client.login(username="admin", password="admin")
response = self.client.put(
2019-01-06 16:22:33 +01:00
reverse("config-detail", args=["test_var_Xeiizi7ooH8Thuk5aida"])
)
self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
2019-01-06 16:22:33 +01:00
self.assertEqual(
response.data, {"detail": "Invalid input. Config value is missing."}
)
2015-06-29 12:08:15 +02:00
def validator_for_testing(value):
"""
Validator for testing.
"""
2019-01-06 16:22:33 +01:00
if value == "invalid_string":
raise ValidationError({"detail": "Invalid input."})
2015-06-29 12:08:15 +02:00
def set_simple_config_view_integration_config_test():
2015-06-29 12:08:15 +02:00
"""
Sets a simple config view with some config variables but without
grouping.
"""
yield ConfigVariable(
2019-01-06 16:22:33 +01:00
name="test_var_aeW3Quahkah1phahCheo",
2015-06-29 12:08:15 +02:00
default_value=None,
2019-01-06 16:22:33 +01:00
label="test_label_aeNahsheu8phahk8taYo",
)
2015-06-29 12:08:15 +02:00
2019-01-06 16:22:33 +01:00
yield ConfigVariable(name="test_var_Xeiizi7ooH8Thuk5aida", default_value="")
2015-06-29 12:08:15 +02:00
yield ConfigVariable(
2019-01-06 16:22:33 +01:00
name="test_var_ohhii4iavoh5Phoh5ahg", default_value=0, input_type="integer"
)
2015-06-29 12:08:15 +02:00
yield ConfigVariable(
2019-01-06 16:22:33 +01:00
name="test_var_wei0Rei9ahzooSohK1ph",
default_value="key_1_Queit2juchoocos2Vugh",
input_type="choice",
2015-06-29 12:08:15 +02:00
choices=(
2019-01-06 16:22:33 +01:00
{
"value": "key_1_Queit2juchoocos2Vugh",
"display_name": "label_1_Queit2juchoocos2Vugh",
},
{
"value": "key_2_yahb2ain1aeZ1lea1Pei",
"display_name": "label_2_yahb2ain1aeZ1lea1Pei",
},
),
)
2015-06-29 12:08:15 +02:00
yield ConfigVariable(
2019-01-06 16:22:33 +01:00
name="test_var_Hi7Oje8Oith7goopeeng",
default_value="",
validators=(validator_for_testing,),
)
yield ConfigVariable(
2019-01-06 16:22:33 +01:00
name="test_var_pud2zah2teeNaiP7IoNa",
default_value=None,
2019-01-06 16:22:33 +01:00
label="test_label_xaing7eefaePheePhei6",
hidden=True,
)