123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- from django.core.urlresolvers import reverse
- from misago.admin.testutils import AdminTestCase
- from misago.users.models import WarningLevel
- class WarningsAdminViewsTests(AdminTestCase):
- def test_link_registered(self):
- """admin nav contains warning levels link"""
- response = self.client.get(
- reverse('misago:admin:users:accounts:index'))
- response = self.client.get(response['location'])
- self.assertIn(reverse('misago:admin:users:warnings:index'),
- response.content)
- def test_list_view(self):
- """warning levels list view returns 200"""
- response = self.client.get(
- reverse('misago:admin:users:warnings:index'))
- self.assertEqual(response.status_code, 200)
- self.assertIn('No warning levels', response.content)
- def test_new_view(self):
- """new warning level view has no showstoppers"""
- response = self.client.get(
- reverse('misago:admin:users:warnings:new'))
- self.assertEqual(response.status_code, 200)
- response = self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Test Level',
- 'length_in_minutes': 60,
- 'restricts_posting_replies': '1',
- 'restricts_posting_threads': '1',
- })
- self.assertEqual(response.status_code, 302)
- response = self.client.get(
- reverse('misago:admin:users:warnings:index'))
- self.assertEqual(response.status_code, 200)
- self.assertIn('Test Level', response.content)
- def test_edit_view(self):
- """edit warning level view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Test Level',
- 'length_in_minutes': 60,
- 'restricts_posting_replies': '1',
- 'restricts_posting_threads': '1',
- })
- test_level = WarningLevel.objects.get(level=1)
- response = self.client.get(
- reverse('misago:admin:users:warnings:edit',
- kwargs={'warning_id': test_level.pk}))
- self.assertEqual(response.status_code, 200)
- self.assertIn(test_level.name, response.content)
- response = self.client.post(
- reverse('misago:admin:users:warnings:edit',
- kwargs={'warning_id': test_level.pk}),
- data={
- 'name': 'Edited Level',
- 'length_in_minutes': 5,
- 'restricts_posting_replies': '0',
- 'restricts_posting_threads': '0',
- })
- self.assertEqual(response.status_code, 302)
- test_level = WarningLevel.objects.get(level=1)
- response = self.client.get(
- reverse('misago:admin:users:warnings:index'))
- self.assertEqual(response.status_code, 200)
- self.assertIn(test_level.name, response.content)
- self.assertTrue('Test Level' not in response.content)
- def test_move_up_view(self):
- """move warning level up view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Level 1',
- 'length_in_minutes': 5,
- 'restricts_posting_replies': '0',
- 'restricts_posting_threads': '0',
- })
- self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Level 2',
- 'length_in_minutes': 5,
- 'restricts_posting_replies': '0',
- 'restricts_posting_threads': '0',
- })
- test_level_1 = WarningLevel.objects.get(level=1)
- test_level_2 = WarningLevel.objects.get(level=2)
- response = self.client.post(
- reverse('misago:admin:users:warnings:up',
- kwargs={'warning_id': test_level_2.pk}))
- self.assertEqual(response.status_code, 302)
- changed_level_1 = WarningLevel.objects.get(id=test_level_1.pk)
- changed_level_2 = WarningLevel.objects.get(id=test_level_2.pk)
- self.assertEqual(test_level_1.level, changed_level_2.level)
- self.assertEqual(test_level_2.level, changed_level_1.level)
- def test_move_down_view(self):
- """move warning level down view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Level 1',
- 'length_in_minutes': 5,
- 'restricts_posting_replies': '0',
- 'restricts_posting_threads': '0',
- })
- self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Level 2',
- 'length_in_minutes': 5,
- 'restricts_posting_replies': '0',
- 'restricts_posting_threads': '0',
- })
- test_level_1 = WarningLevel.objects.get(level=1)
- test_level_2 = WarningLevel.objects.get(level=2)
- response = self.client.post(
- reverse('misago:admin:users:warnings:down',
- kwargs={'warning_id': test_level_1.pk}))
- self.assertEqual(response.status_code, 302)
- changed_level_1 = WarningLevel.objects.get(id=test_level_1.pk)
- changed_level_2 = WarningLevel.objects.get(id=test_level_2.pk)
- self.assertEqual(test_level_1.level, changed_level_2.level)
- self.assertEqual(test_level_2.level, changed_level_1.level)
- def test_delete_view(self):
- """delete warning level view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:users:warnings:new'),
- data={
- 'name': 'Test Level',
- 'length_in_minutes': 60,
- 'restricts_posting_replies': '1',
- 'restricts_posting_threads': '1',
- })
- test_level = WarningLevel.objects.get(level=1)
- response = self.client.post(
- reverse('misago:admin:users:warnings:delete',
- kwargs={'warning_id': test_level.pk}))
- self.assertEqual(response.status_code, 302)
- self.client.get(reverse('misago:admin:users:warnings:index'))
- response = self.client.get(
- reverse('misago:admin:users:warnings:index'))
- self.assertEqual(response.status_code, 200)
- self.assertTrue(test_level.name not in response.content)
|