e7230b7391
* seperate unittests and integration tests * moved old tests in seperat folder 'old' * created a testrunner that does not create a testdatabase, if only unittests are run * wrote some unit- and integration tests as examples * fixed user.get_short_name() to use the sort order from config * fixed wrong url_pattern in the user app
362 lines
17 KiB
Python
362 lines
17 KiB
Python
import re
|
|
from unittest.mock import patch
|
|
|
|
from django import forms
|
|
from django.contrib.auth.models import Permission
|
|
from django.contrib.contenttypes.models import ContentType
|
|
from django.dispatch import receiver
|
|
from django.test.client import Client
|
|
|
|
|
|
from openslides.config.api import (config, ConfigCollection, ConfigGroup,
|
|
ConfigGroupedCollection, ConfigVariable)
|
|
from openslides.config.exceptions import ConfigError, ConfigNotFound
|
|
from openslides.config.signals import config_signal
|
|
from openslides.users.models import User
|
|
from openslides.utils.test import TestCase
|
|
|
|
|
|
class HandleConfigTest(TestCase):
|
|
|
|
def get_config_var(self, key):
|
|
return config[key]
|
|
|
|
def set_config_var(self, key, value):
|
|
config[key] = value
|
|
|
|
def test_get_config_default_value(self):
|
|
self.assertEqual(config['string_var'], 'default_string_rien4ooCZieng6ah')
|
|
self.assertTrue(config['bool_var'])
|
|
self.assertEqual(config['integer_var'], 3)
|
|
self.assertEqual(config['choices_var'], '1')
|
|
self.assertEqual(config['none_config_var'], None)
|
|
self.assertRaisesMessage(expected_exception=ConfigNotFound,
|
|
expected_message='The config variable unknown_config_var was not found.',
|
|
callable_obj=self.get_config_var, key='unknown_config_var')
|
|
|
|
def test_get_multiple_config_var_error(self):
|
|
config_signal.connect(set_simple_config_view_multiple_vars, dispatch_uid='set_simple_config_view_multiple_vars_for_testing')
|
|
self.assertRaisesMessage(expected_exception=ConfigError,
|
|
expected_message='Too many values for config variable multiple_config_var found.',
|
|
callable_obj=config.setup_cache)
|
|
config_signal.disconnect(set_simple_config_view_multiple_vars, dispatch_uid='set_simple_config_view_multiple_vars_for_testing')
|
|
|
|
def test_database_queries(self):
|
|
"""
|
|
Test that no database queries are send, after the cache was created.
|
|
"""
|
|
config.setup_cache()
|
|
self.assertNumQueries(0, self.get_config_var, key='string_var')
|
|
|
|
def test_setup_config_var(self):
|
|
self.assertRaises(TypeError, ConfigVariable)
|
|
self.assertRaises(TypeError, ConfigVariable, name='foo')
|
|
self.assertRaises(TypeError, ConfigVariable, default_value='foo')
|
|
|
|
def test_change_config_value(self):
|
|
self.assertEqual(config['string_var'], 'default_string_rien4ooCZieng6ah')
|
|
config['string_var'] = 'other_special_unique_string dauTex9eAiy7jeen'
|
|
self.assertEqual(config['string_var'], 'other_special_unique_string dauTex9eAiy7jeen')
|
|
|
|
def test_missing_cache_(self):
|
|
self.assertEqual(config['string_var'], 'default_string_rien4ooCZieng6ah')
|
|
|
|
def test_config_contains(self):
|
|
self.assertTrue('string_var' in config)
|
|
self.assertFalse('unknown_config_var' in config)
|
|
|
|
def test_set_value_before_getting_it(self):
|
|
"""
|
|
Try to call __setitem__ before __getitem.
|
|
"""
|
|
config['my_config_var'] = 'value'
|
|
|
|
def test_on_change(self):
|
|
"""
|
|
Tests that the special callback is called and raises a special
|
|
message.
|
|
"""
|
|
# TODO: use right exception
|
|
self.assertRaisesMessage(
|
|
Exception,
|
|
'Change callback dhcnfg34dlg06kdg successfully called.',
|
|
self.set_config_var,
|
|
key='var_with_callback_ghvnfjd5768gdfkwg0hm2',
|
|
value='new_string_kbmbnfhdgibkdjshg452bc')
|
|
self.assertEqual(config['var_with_callback_ghvnfjd5768gdfkwg0hm2'], 'new_string_kbmbnfhdgibkdjshg452bc')
|
|
|
|
def test_get_default(self):
|
|
"""
|
|
Tests the methode 'default'.
|
|
"""
|
|
self.assertEqual(config.get_default('string_var'), 'default_string_rien4ooCZieng6ah')
|
|
self.assertRaisesMessage(
|
|
ConfigNotFound,
|
|
'The config variable unknown_var was not found.',
|
|
config.get_default,
|
|
'unknown_var')
|
|
|
|
|
|
class ConfigFormTest(TestCase):
|
|
|
|
def setUp(self):
|
|
# Setup the permission
|
|
ct = ContentType.objects.get(app_label='config', model='configstore')
|
|
perm = Permission.objects.get(content_type=ct, codename='can_manage')
|
|
|
|
# Setup two users
|
|
self.manager = User.objects.create_user('config_test_manager', 'default')
|
|
self.manager.user_permissions.add(perm)
|
|
|
|
self.normal_user = User.objects.create_user('config_test_normal_user', 'default')
|
|
|
|
# Login
|
|
self.client_manager = Client()
|
|
self.client_manager.login(username='config_test_manager', password='default')
|
|
self.client_normal_user = Client()
|
|
self.client_normal_user.login(username='config_test_normal_user', password='default')
|
|
|
|
def test_get_config_form_overview(self):
|
|
response = self.client_manager.get('/config/')
|
|
self.assertRedirects(response=response, expected_url='/config/general/',
|
|
status_code=302, target_status_code=200)
|
|
bad_client = Client()
|
|
response = bad_client.get('/config/', follow=True)
|
|
self.assertRedirects(response=response, expected_url='/login/?next=/config/general/',
|
|
status_code=302, target_status_code=200)
|
|
|
|
def test_get_config_form_testgroupedpage1_manager_client(self):
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
self.assertContains(response=response, text='default_string_rien4ooCZieng6ah', status_code=200)
|
|
self.assertTemplateUsed(response=response, template_name='base.html')
|
|
self.assertTemplateUsed(response=response, template_name='config/config_form.html')
|
|
self.assertTemplateNotUsed(response=response, template_name='form.html')
|
|
self.assertTemplateUsed(response=response, template_name='formbuttons_save.html')
|
|
|
|
def test_get_config_form_testgroupedpage1_grouping(self):
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
self.assertContains(response=response, text='Group 1 aiYeix2mCieQuae3', status_code=200)
|
|
self.assertContains(response=response, text='Group 2 Toongai7ahyahy7B', status_code=200)
|
|
|
|
def test_get_config_form_testgroupedpage1_other_clients(self):
|
|
response = self.client_normal_user.get('/config/testgroupedpage1/')
|
|
self.assertEqual(response.status_code, 403)
|
|
bad_client = Client()
|
|
response = bad_client.get('/config/testgroupedpage1/')
|
|
self.assertRedirects(response=response, expected_url='/login/?next=/config/testgroupedpage1/',
|
|
status_code=302, target_status_code=200)
|
|
|
|
def test_get_config_form_testsimplepage1_manager_client(self):
|
|
response = self.client_manager.get('/config/testsimplepage1/')
|
|
self.assertNotContains(response=response, text='BaeB0ahcMae3feem', status_code=200)
|
|
self.assertTemplateUsed(response=response, template_name='base.html')
|
|
self.assertTemplateUsed(response=response, template_name='config/config_form.html')
|
|
self.assertTemplateUsed(response=response, template_name='form.html')
|
|
self.assertTemplateUsed(response=response, template_name='formbuttons_save.html')
|
|
|
|
def test_get_config_form_testgroupedpage1_initial(self):
|
|
config['string_var'] = 'something unique AChie6eeiDie3Ieciy1bah4I'
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
self.assertContains(response=response, text='AChie6eeiDie3Ieciy1bah4I', status_code=200)
|
|
|
|
def test_get_config_form_testgroupedpage1_choices(self):
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
self.assertContains(response=response, text='Ughoch4ocoche6Ee', status_code=200)
|
|
self.assertContains(response=response, text='Vahnoh5yalohv5Eb', status_code=200)
|
|
|
|
def test_post_config_form_configtest1(self):
|
|
response = self.client_manager.post(
|
|
'/config/testgroupedpage1/',
|
|
{'string_var': 'other_special_unique_string faiPaid4utie6eeL',
|
|
'integer_var': 3,
|
|
'choices_var': 2})
|
|
self.assertRedirects(response=response, expected_url='/config/testgroupedpage1/',
|
|
status_code=302, target_status_code=200)
|
|
self.assertEqual(config['string_var'], 'other_special_unique_string faiPaid4utie6eeL')
|
|
self.assertFalse(config['bool_var'])
|
|
self.assertEqual(config['integer_var'], 3)
|
|
self.assertEqual(config['choices_var'], '2')
|
|
|
|
def test_post_config_form_error(self):
|
|
response = self.client_manager.post(
|
|
'/config/testgroupedpage1/',
|
|
{'integer_var': 'bad_string_value'})
|
|
self.assertContains(response=response, text='errorlist', status_code=200)
|
|
|
|
def test_disabled_config_view(self):
|
|
response = self.client_manager.get('/config/testsimplepage3/')
|
|
self.assertEqual(response.status_code, 404)
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
self.assertNotContains(response=response, text='Ho5iengaoon5Hoht', status_code=200)
|
|
|
|
def test_improperly_configured_config_view(self):
|
|
"""
|
|
Tests that a ConfigCollection object without an url raises ConfigError
|
|
when is_shown() is called.
|
|
"""
|
|
collection = ConfigCollection(
|
|
title='Only a small title but no url ci6xahb8Chula0Thesho',
|
|
variables=(ConfigVariable(name='some_var_paiji9theiW8ooXivae6',
|
|
default_value='',
|
|
form_field=forms.CharField()),))
|
|
|
|
self.assertRaisesMessage(
|
|
ConfigError,
|
|
'The config collection %s must have a title and an url attribute.' % repr(collection),
|
|
collection.is_shown)
|
|
|
|
def test_improperly_configured_config_view_two(self):
|
|
"""
|
|
Tests that a ConfigCollection object without a title raises ConfigError
|
|
when is_shown() is called.
|
|
"""
|
|
collection = ConfigCollection(
|
|
url='only_url_ureiraeY1Oochuad7xei',
|
|
variables=(ConfigVariable(name='some_var_vuuC6eiXeiyae3ik4gie',
|
|
default_value='',
|
|
form_field=forms.CharField()),))
|
|
|
|
self.assertRaisesMessage(
|
|
ConfigError,
|
|
'The config collection %s must have a title and an url attribute.' % repr(collection),
|
|
collection.is_shown)
|
|
|
|
def test_extra_stylefiles(self):
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
text = '<link href="/static/styles/test-config-sjNN56dFGDrg2.css" type="text/css" rel="stylesheet" />'
|
|
self.assertContains(response=response, text=text, status_code=200)
|
|
|
|
def test_extra_javascript(self):
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
text = '<script src="/static/javascript/test-config-djg4dFGVslk4209f.js" type="text/javascript"></script>'
|
|
self.assertContains(response=response, text=text, status_code=200)
|
|
|
|
@patch('openslides.config.views.FormView.get_context_data')
|
|
def test_extra_stylefiles_other_context(self, mock_get_context_data):
|
|
"""
|
|
Tests the view with empty context data at the beginning.
|
|
"""
|
|
mock_get_context_data.return_value = {}
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
text1 = '<link href="/static/styles/test-config-sjNN56dFGDrg2.css" type="text/css" rel="stylesheet" />'
|
|
text2 = '<script src="/static/javascript/test-config-djg4dFGVslk4209f.js" type="text/javascript"></script>'
|
|
self.assertContains(response=response, text=text1, status_code=200)
|
|
self.assertContains(response=response, text=text2, status_code=200)
|
|
|
|
|
|
class ConfigWeightTest(TestCase):
|
|
|
|
def setUp(self):
|
|
# Setup the permission
|
|
ct = ContentType.objects.get(app_label='config', model='configstore')
|
|
perm = Permission.objects.get(content_type=ct, codename='can_manage')
|
|
|
|
# Setup two users
|
|
self.manager = User.objects.create_user('config_test_manager', 'default')
|
|
self.manager.user_permissions.add(perm)
|
|
|
|
# Login
|
|
self.client_manager = Client()
|
|
self.client_manager.login(username='config_test_manager', password='default')
|
|
|
|
def test_order_of_config_views_abstract(self):
|
|
config_collection_dict = {}
|
|
for signal_receiver, config_collection in config_signal.send(sender=self):
|
|
config_collection_dict[signal_receiver.__name__] = config_collection
|
|
self.assertGreater(config_collection_dict['set_grouped_config_view'].weight, config_collection_dict['set_simple_config_view'].weight)
|
|
|
|
def test_order_of_config_collections_on_view(self):
|
|
response = self.client_manager.get('/config/testgroupedpage1/')
|
|
content = response.content.decode('utf-8')
|
|
m1 = re.search('<a href="/config/testgroupedpage1/" class="btn btn-mini active">\s*Config vars for testing 1\s*</a>', content)
|
|
m2 = re.search('<a href="/config/testsimplepage1/" class="btn btn-mini ">\s*Config vars for testing 2\s*</a>', content)
|
|
self.assertGreater(m1.start(), m2.start())
|
|
|
|
|
|
@receiver(config_signal, dispatch_uid='set_grouped_config_view_for_testing')
|
|
def set_grouped_config_view(sender, **kwargs):
|
|
"""
|
|
Sets a grouped config collection view which can be reached under the url
|
|
'/config/testgroupedpage1/'. There are some variables, one variable
|
|
with a string as default value, one with a boolean as default value,
|
|
one with an integer as default value, one with choices and one
|
|
hidden variable. These variables are grouped in two groups.
|
|
"""
|
|
string_var = ConfigVariable(
|
|
name='string_var',
|
|
default_value='default_string_rien4ooCZieng6ah',
|
|
form_field=forms.CharField())
|
|
bool_var = ConfigVariable(
|
|
name='bool_var',
|
|
default_value=True,
|
|
form_field=forms.BooleanField(required=False))
|
|
integer_var = ConfigVariable(
|
|
name='integer_var',
|
|
default_value=3,
|
|
form_field=forms.IntegerField())
|
|
group_1 = ConfigGroup(title='Group 1 aiYeix2mCieQuae3', variables=(string_var, bool_var, integer_var))
|
|
|
|
hidden_var = ConfigVariable(
|
|
name='hidden_var',
|
|
default_value='hidden_value')
|
|
choices_var = ConfigVariable(
|
|
name='choices_var',
|
|
default_value='1',
|
|
form_field=forms.ChoiceField(choices=(('1', 'Choice One Ughoch4ocoche6Ee'), ('2', 'Choice Two Vahnoh5yalohv5Eb'))))
|
|
group_2 = ConfigGroup(title='Group 2 Toongai7ahyahy7B', variables=(hidden_var, choices_var))
|
|
|
|
return ConfigGroupedCollection(
|
|
title='Config vars for testing 1',
|
|
url='testgroupedpage1',
|
|
weight=10000,
|
|
groups=(group_1, group_2),
|
|
extra_context={'extra_stylefiles': ['styles/test-config-sjNN56dFGDrg2.css'],
|
|
'extra_javascript': ['javascript/test-config-djg4dFGVslk4209f.js']})
|
|
|
|
|
|
@receiver(config_signal, dispatch_uid='set_simple_config_view_for_testing')
|
|
def set_simple_config_view(sender, **kwargs):
|
|
"""
|
|
Sets a simple config view with some config variables but without
|
|
grouping.
|
|
"""
|
|
return ConfigCollection(
|
|
title='Config vars for testing 2',
|
|
url='testsimplepage1',
|
|
variables=(ConfigVariable(name='additional_config_var', default_value='BaeB0ahcMae3feem'),
|
|
ConfigVariable(name='additional_config_var_2', default_value='', form_field=forms.CharField()),
|
|
ConfigVariable(name='none_config_var', default_value=None)))
|
|
|
|
|
|
# Do not connect to the signal now but later inside the test.
|
|
def set_simple_config_view_multiple_vars(sender, **kwargs):
|
|
"""
|
|
Sets a bad config view with some multiple config vars.
|
|
"""
|
|
return ConfigCollection(
|
|
title='Config vars for testing 3',
|
|
url='testsimplepage2',
|
|
variables=(ConfigVariable(name='multiple_config_var', default_value='foobar1'),
|
|
ConfigVariable(name='multiple_config_var', default_value='foobar2')))
|
|
|
|
|
|
@receiver(config_signal, dispatch_uid='set_simple_config_collection_disabled_view_for_testing')
|
|
def set_simple_config_collection_disabled_view(sender, **kwargs):
|
|
return ConfigCollection(
|
|
title='Ho5iengaoon5Hoht',
|
|
url='testsimplepage3',
|
|
variables=(ConfigVariable(name='hidden_config_var_2', default_value=''),))
|
|
|
|
|
|
@receiver(config_signal, dispatch_uid='set_simple_config_collection_with_callback_for_testing')
|
|
def set_simple_config_collection_with_callback(sender, **kwargs):
|
|
def callback():
|
|
raise Exception('Change callback dhcnfg34dlg06kdg successfully called.')
|
|
return ConfigCollection(
|
|
title='Hvndfhsbgkridfgdfg',
|
|
url='testsimplepage4',
|
|
variables=(ConfigVariable(
|
|
name='var_with_callback_ghvnfjd5768gdfkwg0hm2',
|
|
default_value='',
|
|
on_change=callback),))
|