lostplaces-backend/lostplaces/lostplaces_app/tests/views/test_place_views.py

52 lines
1.6 KiB
Python
Raw Normal View History

2020-09-12 08:39:06 +02:00
import datetime
2020-09-04 21:48:05 +02:00
from django.test import TestCase, Client
from django.urls import reverse_lazy
2020-09-12 08:39:06 +02:00
from django.contrib.auth.models import User
2020-09-04 21:48:05 +02:00
from lostplaces_app.models import Place
class TestPlaceCreateView(TestCase):
2020-09-12 08:39:06 +02:00
@classmethod
def setUpTestData(cls):
user = User.objects.create_user(
username='testpeter',
password='Develop123'
)
place = Place.objects.create(
name='Im a place',
submitted_when=datetime.datetime.now(),
submitted_by=user.explorer,
location='Testtown',
latitude=50.5,
longitude=7.0,
description='This is just a test, do not worry'
)
place.tags.add('I a tag', 'testlocation')
place.save()
2020-09-04 21:48:05 +02:00
def setUp(self):
self. client = Client()
def test_url_logged_in(self):
self.client.login(username='testpeter', password='Develop123')
response = self.client.get(reverse_lazy('place_detail', kwargs={'pk': 1}))
self.assertEqual(response.status_code, 200)
def test_url_not_logged_in(self):
url = reverse_lazy('place_detail', kwargs={'pk': 1})
response = self.client.get(url)
self.assertRedirects(
response=response,
expected_url='?'.join([str(reverse_lazy('login')), 'next=/place/1/']),
2020-09-04 21:48:05 +02:00
status_code=302,
target_status_code=200,
msg_prefix='''Accesing PlaceDetailView while not logged should
redirect to login page with redirect params
''',
fetch_redirect_response=True
)