Merge pull request #3176 from normanjaeckel/TopicTest
Added some tests for topics. See #3175.
This commit is contained in:
commit
a45807eddd
0
tests/integration/topics/__init__.py
Normal file
0
tests/integration/topics/__init__.py
Normal file
71
tests/integration/topics/test_viewset.py
Normal file
71
tests/integration/topics/test_viewset.py
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
from django.contrib.auth import get_user_model
|
||||||
|
from django.core.urlresolvers import reverse
|
||||||
|
from rest_framework import status
|
||||||
|
from rest_framework.test import APIClient
|
||||||
|
|
||||||
|
from openslides.agenda.models import Item
|
||||||
|
from openslides.core.config import config
|
||||||
|
from openslides.topics.models import Topic
|
||||||
|
from openslides.utils.test import TestCase, use_cache
|
||||||
|
|
||||||
|
|
||||||
|
class TestDBQueries(TestCase):
|
||||||
|
"""
|
||||||
|
Tests that receiving elements only need the required db queries.
|
||||||
|
|
||||||
|
Therefore in setup some topics are created and received with different
|
||||||
|
user accounts.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
self.client = APIClient()
|
||||||
|
config['general_system_enable_anonymous'] = True
|
||||||
|
for index in range(10):
|
||||||
|
Topic.objects.create(title='topic-{}'.format(index))
|
||||||
|
|
||||||
|
@use_cache()
|
||||||
|
def test_admin(self):
|
||||||
|
"""
|
||||||
|
Tests that only the following db queries are done:
|
||||||
|
* 4 requests to get the session an the request user with its permissions,
|
||||||
|
* 2 requests to get the list of all topics,
|
||||||
|
* 1 request to get attachments,
|
||||||
|
* 1 request to get the agenda item
|
||||||
|
"""
|
||||||
|
self.client.force_login(get_user_model().objects.get(pk=1))
|
||||||
|
with self.assertNumQueries(8):
|
||||||
|
self.client.get(reverse('topic-list'))
|
||||||
|
|
||||||
|
@use_cache()
|
||||||
|
def test_anonymous(self):
|
||||||
|
"""
|
||||||
|
Tests that only the following db queries are done:
|
||||||
|
* 3 requests to get the permission for anonymous,
|
||||||
|
* 2 requests to get the list of all topics,
|
||||||
|
* 1 request to get attachments,
|
||||||
|
* 1 request to get the agenda item,
|
||||||
|
"""
|
||||||
|
with self.assertNumQueries(7):
|
||||||
|
self.client.get(reverse('topic-list'))
|
||||||
|
|
||||||
|
|
||||||
|
class TopicCreate(TestCase):
|
||||||
|
"""
|
||||||
|
Tests creation of new topics.
|
||||||
|
"""
|
||||||
|
def setUp(self):
|
||||||
|
self.client.login(
|
||||||
|
username='admin',
|
||||||
|
password='admin',
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_simple_create(self):
|
||||||
|
response = self.client.post(
|
||||||
|
reverse('topic-list'),
|
||||||
|
{'title': 'test_title_ahyo1uifoo9Aiph2av5a',
|
||||||
|
'text': 'test_text_chu9Uevoo5choo0Xithe'})
|
||||||
|
self.assertEqual(response.status_code, status.HTTP_201_CREATED)
|
||||||
|
topic = Topic.objects.get()
|
||||||
|
self.assertEqual(topic.title, 'test_title_ahyo1uifoo9Aiph2av5a')
|
||||||
|
self.assertEqual(topic.text, 'test_text_chu9Uevoo5choo0Xithe')
|
||||||
|
self.assertEqual(Item.objects.get(), topic.agenda_item)
|
Loading…
Reference in New Issue
Block a user