2020-09-19 22:50:07 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
2020-09-12 08:39:06 +02:00
|
|
|
|
2021-06-12 15:07:14 +02:00
|
|
|
import re
|
|
|
|
from os import path
|
|
|
|
|
2020-09-13 19:43:47 +02:00
|
|
|
from django.test import TestCase, Client
|
2020-09-13 20:27:05 +02:00
|
|
|
from django.urls import reverse
|
2020-09-12 08:39:06 +02:00
|
|
|
from django.contrib.auth.models import User
|
2020-09-18 22:04:19 +02:00
|
|
|
from django.utils import timezone
|
2021-06-12 15:07:14 +02:00
|
|
|
from django.conf import settings
|
2022-09-17 18:07:29 +02:00
|
|
|
from django.utils.translation import gettext as _
|
2020-09-18 22:04:19 +02:00
|
|
|
|
2020-09-04 21:48:05 +02:00
|
|
|
|
2020-09-14 17:26:17 +02:00
|
|
|
from lostplaces.models import Place
|
2022-09-24 12:10:19 +02:00
|
|
|
from lostplaces.models import PLACE_MODES
|
2020-09-14 17:26:17 +02:00
|
|
|
from lostplaces.views import (
|
2020-09-12 11:02:39 +02:00
|
|
|
PlaceCreateView,
|
2020-09-13 20:27:05 +02:00
|
|
|
PlaceListView,
|
|
|
|
PlaceDetailView
|
2020-09-12 11:02:39 +02:00
|
|
|
)
|
2020-09-18 23:50:25 +02:00
|
|
|
from lostplaces.forms import PlaceImageForm, PlaceForm
|
2020-09-14 17:26:17 +02:00
|
|
|
from lostplaces.tests.views import (
|
2020-09-13 20:27:05 +02:00
|
|
|
ViewTestCase,
|
|
|
|
TaggableViewTestCaseMixin,
|
2021-05-15 23:27:25 +02:00
|
|
|
MapableViewTestCaseMixin,
|
|
|
|
GlobalTemplateTestCaseMixin
|
2020-09-13 20:27:05 +02:00
|
|
|
)
|
|
|
|
|
2020-09-04 21:48:05 +02:00
|
|
|
|
2021-05-15 23:27:25 +02:00
|
|
|
class TestPlaceListView(GlobalTemplateTestCaseMixin, ViewTestCase):
|
2021-06-12 15:07:14 +02:00
|
|
|
"""
|
|
|
|
Tests the view listing all placs
|
|
|
|
"""
|
2021-05-15 23:27:25 +02:00
|
|
|
view = PlaceListView
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2020-09-12 08:39:06 +02:00
|
|
|
@classmethod
|
|
|
|
def setUpTestData(cls):
|
|
|
|
user = User.objects.create_user(
|
|
|
|
username='testpeter',
|
2021-10-02 00:50:32 +02:00
|
|
|
password='Develop123',
|
|
|
|
)
|
|
|
|
user.explorer.level = 3
|
|
|
|
user.explorer.save()
|
|
|
|
|
|
|
|
# default level should be 1, not setting required
|
|
|
|
other_user = User.objects.create_user(
|
|
|
|
username='blubberbernd',
|
|
|
|
password='Develop123'
|
|
|
|
)
|
|
|
|
|
|
|
|
superuser = User.objects.create_user(
|
|
|
|
username='toor',
|
2020-09-12 08:39:06 +02:00
|
|
|
password='Develop123'
|
|
|
|
)
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2021-10-02 00:50:32 +02:00
|
|
|
superuser.is_superuser = True
|
|
|
|
superuser.save()
|
|
|
|
|
|
|
|
Place.objects.create(
|
|
|
|
name='Im a own place',
|
|
|
|
submitted_when=timezone.now(),
|
|
|
|
submitted_by=other_user.explorer,
|
|
|
|
location='Test %d town' % 5,
|
|
|
|
latitude=50.5 + 5/10,
|
|
|
|
longitude=7.0 - 5/10,
|
|
|
|
description='This is just a test, do not worry %d' % 5,
|
|
|
|
level=3
|
|
|
|
)
|
|
|
|
|
2021-06-12 15:07:14 +02:00
|
|
|
for i in range(12):
|
|
|
|
place = Place.objects.create(
|
|
|
|
name='Im a place %d' % i,
|
|
|
|
submitted_when=timezone.now(),
|
|
|
|
submitted_by=user.explorer,
|
|
|
|
location='Test %d town' % i,
|
|
|
|
latitude=50.5 + i/10,
|
|
|
|
longitude=7.0 - i/10,
|
2021-10-02 00:50:32 +02:00
|
|
|
description='This is just a test, do not worry %d' % i,
|
|
|
|
level=3
|
2021-06-12 15:07:14 +02:00
|
|
|
)
|
2020-09-12 08:39:06 +02:00
|
|
|
place.tags.add('I a tag', 'testlocation')
|
|
|
|
place.save()
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2020-09-13 19:43:47 +02:00
|
|
|
def setUp(self):
|
|
|
|
self.client = Client()
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2021-05-15 23:27:25 +02:00
|
|
|
def test_list_view(self):
|
2020-09-04 21:48:05 +02:00
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
2021-05-15 23:27:25 +02:00
|
|
|
response = self.client.get(reverse('place_list'))
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2021-05-15 23:27:25 +02:00
|
|
|
self.assertContext(response, 'mapping_config')
|
|
|
|
self.assertGlobal(response)
|
2021-06-12 15:07:14 +02:00
|
|
|
|
2021-06-25 11:04:01 +02:00
|
|
|
def test_first_places(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
|
|
|
|
|
|
|
for i in range(1, 4):
|
|
|
|
place = Place.objects.get(id=i)
|
|
|
|
self.assertTrue(
|
|
|
|
place.name in response.content.decode(),
|
|
|
|
msg='Expecting the %dth place name to be on the first page of list' % i
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
place.description in response.content.decode(),
|
|
|
|
msg='Expecting the %dth place description to be on the first page of list' % i
|
|
|
|
)
|
|
|
|
|
2021-06-12 15:07:14 +02:00
|
|
|
def test_pagination(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2021-06-12 15:07:14 +02:00
|
|
|
self.assertNotEqual(
|
|
|
|
None,
|
|
|
|
re.search(
|
|
|
|
"""<ul.*pagination.*>\s*(<li.*>.*</li>\s*){6,}</ul>""",
|
|
|
|
response.content.decode().replace('\n', '').lower()
|
|
|
|
),
|
|
|
|
msg='Expecting the place list to be paginated like [first] [previous] [item] at least 2 times [next] [last]'
|
|
|
|
)
|
2021-10-02 00:50:32 +02:00
|
|
|
|
|
|
|
def test_not_eligible_to_see_because_of_low_level(self):
|
|
|
|
self.client.login(username='blubberbernd', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
|
|
|
|
|
|
|
self.assertFalse(
|
|
|
|
'Im a place' in response.content.decode(),
|
|
|
|
msg='Expecting the user to not see any places'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_not_eligible_to_see_because_of_low_level_superuser(self):
|
|
|
|
self.client.login(username='toor', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
'Im a place' in response.content.decode(),
|
|
|
|
msg='Expecting the superuser to see all places'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_not_eligible_to_see_because_of_low_level_own_place(self):
|
|
|
|
self.client.login(username='blubberbernd', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
'Im a own place' in response.content.decode(),
|
|
|
|
msg='Expecting the user to see it\'s own places'
|
|
|
|
)
|
2021-10-02 01:31:12 +02:00
|
|
|
|
|
|
|
def test_eligible_to_see(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
'Im a own place' in response.content.decode(),
|
|
|
|
msg='Expecting the user to see places where their level is high enough'
|
|
|
|
)
|
2022-09-24 12:10:19 +02:00
|
|
|
|
|
|
|
def test_place_mode_filter(self):
|
|
|
|
explorer = User.objects.get(username='testpeter').explorer
|
|
|
|
Place.objects.all().delete()
|
|
|
|
|
|
|
|
for mode in PLACE_MODES:
|
|
|
|
place = Place.objects.create(
|
|
|
|
name='Im a place in mode %s' % mode[0],
|
|
|
|
submitted_when=timezone.now(),
|
|
|
|
submitted_by=explorer,
|
|
|
|
location='Test town',
|
|
|
|
latitude=50.5,
|
|
|
|
longitude=7.0,
|
|
|
|
description='This is just a test, do not worry %s' % mode[0],
|
|
|
|
level=3,
|
|
|
|
mode=mode[0]
|
|
|
|
)
|
|
|
|
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_list'))
|
|
|
|
|
|
|
|
for mode in PLACE_MODES:
|
|
|
|
if ('Im a place in mode %s' % mode[0]) in response.content.decode():
|
|
|
|
self.assertTrue(
|
|
|
|
mode[0] == 'live',
|
|
|
|
msg='Expecting only places in mode \'live\' to be listed, saw a place in mode %s' % mode[0]
|
|
|
|
)
|
|
|
|
elif mode[0] == 'live':
|
|
|
|
self.fail(
|
|
|
|
msg='Expecting at least one place in mode \'live\' to be listed'
|
|
|
|
)
|
|
|
|
|
2021-06-12 15:07:14 +02:00
|
|
|
|
2021-05-15 23:27:25 +02:00
|
|
|
class TestPlaceCreateView(ViewTestCase):
|
|
|
|
view = PlaceCreateView
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2020-09-12 11:02:39 +02:00
|
|
|
@classmethod
|
|
|
|
def setUpTestData(cls):
|
|
|
|
user = User.objects.create_user(
|
|
|
|
username='testpeter',
|
|
|
|
password='Develop123'
|
2020-09-04 21:48:05 +02:00
|
|
|
)
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2020-09-13 19:43:47 +02:00
|
|
|
def setUp(self):
|
2020-09-13 20:27:05 +02:00
|
|
|
self.client = Client()
|
2021-06-12 15:07:14 +02:00
|
|
|
|
2021-05-15 23:27:25 +02:00
|
|
|
def test_has_forms(self):
|
2020-09-12 11:02:39 +02:00
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
2021-05-15 23:27:25 +02:00
|
|
|
response = self.client.get(reverse('place_create'))
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2021-05-15 23:27:25 +02:00
|
|
|
self.assertHasForm(response, 'place_image_form', PlaceImageForm)
|
|
|
|
self.assertHasForm(response, 'place_form', PlaceForm)
|
2021-06-12 15:07:14 +02:00
|
|
|
|
|
|
|
def test_positive_no_image(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
2021-06-12 17:06:09 +02:00
|
|
|
data={
|
2021-06-12 15:07:14 +02:00
|
|
|
'name': 'test place 486',
|
|
|
|
'location': 'test location',
|
|
|
|
'latitude': 45.804192,
|
|
|
|
'longitude': 1.860222,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
"""
|
2021-06-12 17:06:09 +02:00
|
|
|
},
|
|
|
|
follow=True
|
2021-06-12 15:07:14 +02:00
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertHttpOK(response)
|
2021-06-12 15:07:14 +02:00
|
|
|
place = Place.objects.get(name='test place 486')
|
|
|
|
self.assertNotEqual(
|
|
|
|
None,
|
|
|
|
place,
|
|
|
|
msg='Submitted place not found in database / model'
|
|
|
|
),
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertEqual(
|
|
|
|
reverse(
|
|
|
|
'place_detail', kwargs={'pk': place.id}
|
|
|
|
),
|
|
|
|
response.redirect_chain[-1][0]
|
|
|
|
)
|
|
|
|
self.assertMessage(
|
|
|
|
response,
|
|
|
|
_('Successfully created place'),
|
|
|
|
'success',
|
|
|
|
msg='Expecting a visible success message'
|
2021-06-12 15:07:14 +02:00
|
|
|
)
|
2022-09-25 16:12:14 +02:00
|
|
|
self.assertEqual(
|
|
|
|
Place.objects.get(name='test place 486').mode,
|
|
|
|
'live',
|
|
|
|
msg='Expeting the place to be in \'live\' mode'
|
|
|
|
)
|
2021-06-12 15:07:14 +02:00
|
|
|
|
2021-06-12 15:52:52 +02:00
|
|
|
def test_positive_image(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
image = open(
|
|
|
|
path.join(
|
|
|
|
settings.BASE_DIR,
|
|
|
|
'testdata',
|
|
|
|
'test_image.jpg'
|
2021-06-12 15:07:14 +02:00
|
|
|
),
|
2021-06-12 15:52:52 +02:00
|
|
|
'rb'
|
|
|
|
)
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
2021-06-12 17:06:09 +02:00
|
|
|
data={
|
2021-06-12 15:52:52 +02:00
|
|
|
'name': 'test place 894',
|
|
|
|
'location': 'test location',
|
|
|
|
'latitude': 45.804192,
|
|
|
|
'longitude': 1.860222,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
""",
|
|
|
|
'filename': [image]
|
2021-06-12 17:06:09 +02:00
|
|
|
},
|
|
|
|
follow=True
|
2021-06-12 15:52:52 +02:00
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertHttpOK(response)
|
2021-06-12 15:52:52 +02:00
|
|
|
place = Place.objects.get(name='test place 894')
|
|
|
|
self.assertNotEqual(
|
|
|
|
None,
|
|
|
|
place,
|
|
|
|
msg='Submitted place not found in database / model'
|
|
|
|
),
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertEqual(
|
|
|
|
reverse(
|
|
|
|
'place_detail', kwargs={'pk': place.id}
|
|
|
|
),
|
|
|
|
response.redirect_chain[-1][0]
|
2021-06-12 15:52:52 +02:00
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
len(place.placeimages.all()),
|
|
|
|
1,
|
|
|
|
msg='Expecting the place to have exactly 1 place image'
|
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertMessage(
|
|
|
|
response,
|
|
|
|
_('Successfully created place'),
|
|
|
|
'success',
|
|
|
|
msg='Expecting a visible success message'
|
|
|
|
)
|
2022-09-25 16:12:14 +02:00
|
|
|
self.assertEqual(
|
|
|
|
Place.objects.get(name='test place 894').mode,
|
|
|
|
'live',
|
|
|
|
msg='Expeting the place to be in \'live\' mode'
|
|
|
|
)
|
2021-06-12 15:52:52 +02:00
|
|
|
|
|
|
|
def test_negative_no_name(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
|
|
|
{
|
|
|
|
'location': 'test location 456',
|
|
|
|
'latitude': 45.804192,
|
|
|
|
'longitude': 1.860222,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
"""
|
|
|
|
}
|
|
|
|
)
|
|
|
|
self.assertHttpBadRequest(response)
|
|
|
|
self.assertEqual(
|
|
|
|
len(Place.objects.filter(location='test location 456')),
|
|
|
|
0,
|
|
|
|
msg='Expecting no place to be created'
|
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertMessage(
|
|
|
|
response,
|
|
|
|
_('Please fill in all required fields.'),
|
|
|
|
'error',
|
|
|
|
msg='Expecing a visible error message'
|
|
|
|
)
|
2021-06-12 15:52:52 +02:00
|
|
|
|
|
|
|
def test_negative_no_location(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
|
|
|
{
|
|
|
|
'name': 'test name 376',
|
|
|
|
'latitude': 45.804192,
|
|
|
|
'longitude': 1.860222,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
"""
|
|
|
|
}
|
|
|
|
)
|
|
|
|
self.assertHttpBadRequest(response)
|
|
|
|
self.assertEqual(
|
|
|
|
len(Place.objects.filter(name='test name 376')),
|
|
|
|
0,
|
|
|
|
msg='Expecting no place to be created'
|
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertMessage(
|
|
|
|
response,
|
|
|
|
_('Please fill in all required fields.'),
|
|
|
|
'error',
|
|
|
|
msg='Expecing a visible error message'
|
|
|
|
)
|
2021-06-12 15:52:52 +02:00
|
|
|
|
|
|
|
def test_negative_no_latitude(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
|
|
|
{
|
|
|
|
'name': 'test name 417',
|
|
|
|
'location': 'location',
|
|
|
|
'longitude': 1.860222,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
"""
|
|
|
|
}
|
|
|
|
)
|
|
|
|
self.assertHttpBadRequest(response)
|
|
|
|
self.assertEqual(
|
|
|
|
len(Place.objects.filter(name='test name 417')),
|
|
|
|
0,
|
|
|
|
msg='Expecting no place to be created'
|
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertMessage(
|
|
|
|
response,
|
|
|
|
_('Please fill in all required fields.'),
|
|
|
|
'error',
|
|
|
|
msg='Expecing a visible error message'
|
|
|
|
)
|
2021-06-12 15:52:52 +02:00
|
|
|
|
|
|
|
def test_negative_no_longitude(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
|
|
|
{
|
|
|
|
'name': 'test name 417',
|
|
|
|
'location': 'location',
|
|
|
|
'latitude': 45.804192,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
"""
|
|
|
|
}
|
|
|
|
)
|
|
|
|
self.assertHttpBadRequest(response)
|
|
|
|
self.assertEqual(
|
|
|
|
len(Place.objects.filter(name='test name 417')),
|
|
|
|
0,
|
|
|
|
msg='Expecting no place to be created'
|
|
|
|
)
|
2021-06-12 17:06:09 +02:00
|
|
|
self.assertMessage(
|
|
|
|
response,
|
|
|
|
_('Please fill in all required fields.'),
|
|
|
|
'error',
|
|
|
|
msg='Expecing a visible error message'
|
|
|
|
)
|
2020-09-13 20:27:05 +02:00
|
|
|
|
2022-09-25 16:12:14 +02:00
|
|
|
def test_positve_save_as_draft(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.post(
|
|
|
|
reverse('place_create'),
|
|
|
|
{
|
|
|
|
'name': 'test name 6483',
|
|
|
|
'location': 'wurstwasser',
|
|
|
|
'latitude': 45.4654,
|
|
|
|
'longitude': 68.135489,
|
|
|
|
'description': """
|
|
|
|
Cupiditate harum reprehenderit ipsam iure consequuntur eaque eos reiciendis. Blanditiis vel minima minus repudiandae voluptate aut quia sed. Provident ex omnis illo molestiae. Ullam eos et est provident enim deserunt.
|
|
|
|
""",
|
|
|
|
'draft': True
|
|
|
|
},
|
|
|
|
follow=True
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
self.assertEqual(
|
|
|
|
Place.objects.get(name='test name 6483').mode,
|
|
|
|
'draft',
|
|
|
|
msg='Expeting the place to be in \'draft\' mode'
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2020-09-14 15:18:21 +02:00
|
|
|
class PlaceDetailViewTestCase(TaggableViewTestCaseMixin, MapableViewTestCaseMixin, ViewTestCase):
|
2020-09-13 20:27:05 +02:00
|
|
|
view = PlaceDetailView
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def setUpTestData(cls):
|
|
|
|
user = User.objects.create_user(
|
|
|
|
username='testpeter',
|
|
|
|
password='Develop123'
|
|
|
|
)
|
2021-10-02 01:31:12 +02:00
|
|
|
user.explorer.level = 3
|
|
|
|
user.explorer.save()
|
2020-09-13 20:27:05 +02:00
|
|
|
|
|
|
|
place = Place.objects.create(
|
|
|
|
name='Im a place',
|
2020-09-18 22:04:19 +02:00
|
|
|
submitted_when=timezone.now(),
|
2020-09-13 20:27:05 +02:00
|
|
|
submitted_by=user.explorer,
|
|
|
|
location='Testtown',
|
|
|
|
latitude=50.5,
|
|
|
|
longitude=7.0,
|
2021-10-02 01:31:12 +02:00
|
|
|
description='This is just a test, do not worry',
|
|
|
|
level=3
|
2020-09-13 20:27:05 +02:00
|
|
|
)
|
|
|
|
place.tags.add('I a tag', 'testlocation')
|
|
|
|
place.save()
|
|
|
|
|
2021-10-02 01:31:12 +02:00
|
|
|
other_user = User.objects.create_user(
|
|
|
|
username='blubberbernd',
|
|
|
|
password='Develop123'
|
|
|
|
)
|
|
|
|
|
|
|
|
superuser = User.objects.create_user(
|
|
|
|
username='toor',
|
|
|
|
password='Develop123'
|
|
|
|
)
|
|
|
|
|
|
|
|
superuser.is_superuser = True
|
|
|
|
superuser.save()
|
|
|
|
|
|
|
|
Place.objects.create(
|
|
|
|
name='Im a own place',
|
|
|
|
submitted_when=timezone.now(),
|
|
|
|
submitted_by=other_user.explorer,
|
|
|
|
location='Test %d town' % 5,
|
|
|
|
latitude=50.5 + 5/10,
|
|
|
|
longitude=7.0 - 5/10,
|
|
|
|
description='This is just a test, do not worry %d' % 5,
|
|
|
|
level=3
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_not_eligible_to_see_because_of_low_level(self):
|
|
|
|
self.client.login(username='blubberbernd', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
|
2022-09-25 16:12:14 +02:00
|
|
|
self.assertHttpForbidden(response)
|
2021-10-02 01:31:12 +02:00
|
|
|
self.assertFalse(
|
|
|
|
'Im a place' in response.content.decode(),
|
|
|
|
msg='Expecting the user to not see the places'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_not_eligible_to_see_because_of_low_level_superuser(self):
|
|
|
|
self.client.login(username='toor', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
|
2022-09-25 16:12:14 +02:00
|
|
|
self.assertHttpOK(response)
|
2021-10-02 01:31:12 +02:00
|
|
|
self.assertTrue(
|
|
|
|
'Im a place' in response.content.decode(),
|
|
|
|
msg='Expecting the superuser to see all places'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_not_eligible_to_see_because_of_low_level_own_place(self):
|
|
|
|
self.client.login(username='blubberbernd', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 2}))
|
|
|
|
|
2022-09-25 16:12:14 +02:00
|
|
|
self.assertHttpOK(response)
|
2021-10-02 01:31:12 +02:00
|
|
|
self.assertTrue(
|
|
|
|
'Im a own place' in response.content.decode(),
|
|
|
|
msg='Expecting the user to see it\'s own places'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_eligible_to_see(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 2}))
|
|
|
|
|
2022-09-25 16:12:14 +02:00
|
|
|
self.assertHttpOK(response)
|
2021-10-02 01:31:12 +02:00
|
|
|
self.assertTrue(
|
|
|
|
'Im a own place' in response.content.decode(),
|
|
|
|
msg='Expecting the user to see places where their level is high enough'
|
|
|
|
)
|
|
|
|
|
2021-06-12 17:06:09 +02:00
|
|
|
def test_not_authenticated(self):
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
self.assertHttpRedirect(response)
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
'%s?next=%s' % (
|
|
|
|
reverse('login'),
|
|
|
|
reverse('place_detail', kwargs={'pk': 1})
|
|
|
|
),
|
|
|
|
response.url,
|
|
|
|
msg='Expecting unauthenticated user to be redirected to login page, using the \'next\' GET-Param to store the places details page'
|
|
|
|
)
|
|
|
|
|
2020-09-13 20:27:05 +02:00
|
|
|
def test_context(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
'tagging_config' in response.context,
|
|
|
|
msg='Expecting the context of %s to have an \'tagging_config\'' % (
|
|
|
|
str(self.view)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
self.assertTaggableContext(response.context['tagging_config'])
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
'mapping_config' in response.context,
|
|
|
|
msg='Expecting the context of %s to have an \'mapping_config\'' % (
|
|
|
|
str(self.view)
|
|
|
|
)
|
|
|
|
)
|
2020-09-14 15:18:21 +02:00
|
|
|
self.assertMapableContext(response.context['mapping_config'])
|
2021-06-25 11:04:01 +02:00
|
|
|
|
|
|
|
def test_place_data(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
place = Place.objects.get(id=1)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
place.name in response.content.decode(),
|
|
|
|
msg='Expecting the places name to be on the page'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
place.description in response.content.decode(),
|
|
|
|
msg='Expecting the places description to be on the page'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
str(place.latitude) in response.content.decode(),
|
|
|
|
msg='Expecting the places latitude to be on the page'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
str(place.longitude) in response.content.decode(),
|
|
|
|
msg='Expecting the places longitude to be on the page'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_favorite(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
|
|
|
|
user = User.objects.get(username='testpeter')
|
|
|
|
place = Place.objects.get(id=1)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
reverse('place_favorite', kwargs={'place_id': 1}) in response.content.decode(),
|
|
|
|
msg='Expecting the (right) create favorite url to be on the page '
|
|
|
|
)
|
|
|
|
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_favorite', kwargs={'place_id': 1}),
|
|
|
|
follow=True
|
|
|
|
)
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
reverse('place_unfavorite', kwargs={'place_id': 1}) in response.content.decode(),
|
|
|
|
msg='Expecting the (right) delete favorite url to be on the page '
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
place in user.explorer.favorite_places.all(),
|
|
|
|
msg='Expecting the place to be in the explorers favorites'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
user.explorer in place.explorer_favorites.all(),
|
|
|
|
msg='Expecting the explorere to be in the reverse list of favorites'
|
|
|
|
)
|
|
|
|
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_unfavorite', kwargs={'place_id': 1}),
|
|
|
|
follow=True
|
|
|
|
)
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
self.assertTrue(
|
|
|
|
reverse('place_favorite', kwargs={'place_id': 1}) in response.content.decode(),
|
|
|
|
msg='Expecting the (right) create favorite url to be on the page after unfavorite'
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
place not in user.explorer.favorite_places.all(),
|
|
|
|
msg='Expecting the place to not be in the explorers favorites after unfavorite'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
user.explorer not in place.explorer_favorites.all(),
|
|
|
|
msg='Expecting the explorere to not be in the reverse list of favorites after unfavorite'
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def test_visit(self):
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
response = self.client.get(reverse('place_detail', kwargs={'pk': 1}))
|
|
|
|
|
|
|
|
user = User.objects.get(username='testpeter')
|
|
|
|
place = Place.objects.get(id=1)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
reverse('place_visit_create', kwargs={'place_id': 1}) in response.content.decode(),
|
|
|
|
msg='Expecting the (right) create visit url to be on the page '
|
|
|
|
)
|
|
|
|
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_visit_create', kwargs={'place_id': 1}),
|
|
|
|
follow=True
|
|
|
|
)
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
reverse('place_visit_delete', kwargs={'place_id': 1}) in response.content.decode(),
|
|
|
|
msg='Expecting the (right) delete visist url to be on the page '
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
place in user.explorer.visited_places.all(),
|
|
|
|
msg='Expecting the place to be in the explorers visits'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
user.explorer in place.explorer_visits.all(),
|
|
|
|
msg='Expecting the explorer to be in the reverse list of visits'
|
|
|
|
)
|
|
|
|
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_visit_delete', kwargs={'place_id': 1}),
|
|
|
|
follow=True
|
|
|
|
)
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
self.assertTrue(
|
|
|
|
reverse('place_visit_create', kwargs={'place_id': 1}) in response.content.decode(),
|
|
|
|
msg='Expecting the (right) create favorite url to be on the page after deleting visit'
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
place not in user.explorer.visited_places.all(),
|
|
|
|
msg='Expecting the place to not be in the explorers visits after deleting visit'
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
user.explorer not in place.explorer_visits.all(),
|
|
|
|
msg='Expecting the explorer to not be in the reverse list of visits after deleting visit'
|
|
|
|
)
|
2022-09-25 18:03:22 +02:00
|
|
|
|
|
|
|
def test_accessing_place_in_draft(self):
|
|
|
|
user = User.objects.get(username='testpeter')
|
|
|
|
place = Place.objects.create(
|
|
|
|
name='Im a own place in draft 387948',
|
|
|
|
submitted_when=timezone.now(),
|
|
|
|
submitted_by=user.explorer,
|
|
|
|
location='Test %d town' % 5,
|
|
|
|
latitude=50.5 + 5/10,
|
|
|
|
longitude=7.0 - 5/10,
|
|
|
|
description='This is just a test, do not worry %d' % 5,
|
|
|
|
level=3,
|
|
|
|
mode='draft'
|
|
|
|
)
|
|
|
|
|
|
|
|
self.client.login(username='testpeter', password='Develop123')
|
|
|
|
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_detail', kwargs={
|
|
|
|
'pk': place.pk
|
|
|
|
})
|
|
|
|
)
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
self.assertTrue(
|
|
|
|
'Im a own place in draft 387948' in response.content.decode(),
|
|
|
|
msg='Expecting the user to see his own place in draft mode'
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
self.client.login(username='blubberbernd', password='Develop123')
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_detail', kwargs={
|
|
|
|
'pk': place.pk
|
|
|
|
})
|
|
|
|
)
|
|
|
|
self.assertHttpForbidden(response)
|
|
|
|
|
|
|
|
self.client.login(username='toor', password='Develop123')
|
|
|
|
response = self.client.get(
|
|
|
|
reverse('place_detail', kwargs={
|
|
|
|
'pk': place.pk
|
|
|
|
})
|
|
|
|
)
|
|
|
|
self.assertHttpOK(response)
|
|
|
|
self.assertTrue(
|
|
|
|
'Im a own place in draft 387948' in response.content.decode(),
|
|
|
|
msg='Expecting a superuser to see all places in draft mode'
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-06-25 11:04:01 +02:00
|
|
|
|
|
|
|
|
|
|
|
|