2020-09-19 22:50:07 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
2020-09-13 10:27:01 +02:00
|
|
|
|
2020-10-04 22:12:24 +02:00
|
|
|
import datetime
|
|
|
|
|
|
|
|
from django.utils import timezone
|
2020-09-13 10:27:01 +02:00
|
|
|
from django.test import TestCase
|
|
|
|
from django.db import models
|
|
|
|
from django.contrib.auth.models import User
|
|
|
|
|
2020-09-14 17:26:17 +02:00
|
|
|
from lostplaces.models import (
|
2020-09-13 19:12:32 +02:00
|
|
|
Taggable,
|
2020-09-14 15:18:21 +02:00
|
|
|
Mapable,
|
2020-09-22 21:56:51 +02:00
|
|
|
Submittable,
|
|
|
|
PlaceAsset,
|
2020-10-04 22:12:24 +02:00
|
|
|
Expireable,
|
|
|
|
Voucher
|
2020-09-13 19:12:32 +02:00
|
|
|
)
|
2020-09-14 17:26:17 +02:00
|
|
|
from lostplaces.tests.models import ModelTestCase
|
2020-09-13 10:27:01 +02:00
|
|
|
|
|
|
|
from taggit.managers import TaggableManager
|
|
|
|
|
|
|
|
|
2020-09-13 18:37:21 +02:00
|
|
|
class TaggableTestCase(ModelTestCase):
|
2020-09-13 10:27:01 +02:00
|
|
|
|
|
|
|
model = Taggable
|
|
|
|
|
|
|
|
def test_tags(self):
|
2020-09-13 13:29:27 +02:00
|
|
|
self.assertField('tags', TaggableManager)
|
2020-09-13 10:27:01 +02:00
|
|
|
|
|
|
|
|
2020-09-14 15:18:21 +02:00
|
|
|
class MapableTestCase(ModelTestCase):
|
2020-09-13 10:27:01 +02:00
|
|
|
|
2020-09-14 15:18:21 +02:00
|
|
|
model = Mapable
|
2020-09-13 10:27:01 +02:00
|
|
|
|
|
|
|
def test_name(self):
|
2020-09-13 13:30:11 +02:00
|
|
|
self.assertCharField(
|
2020-09-13 10:27:01 +02:00
|
|
|
field_name='name',
|
|
|
|
min_length=10,
|
|
|
|
max_length=100
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_latitude(self):
|
2020-09-13 13:30:47 +02:00
|
|
|
self.assertFloatField(
|
2020-09-13 10:27:01 +02:00
|
|
|
field_name='latitude',
|
|
|
|
min_value=-90,
|
|
|
|
max_value=90
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_longitude(self):
|
2020-09-13 13:30:47 +02:00
|
|
|
self.assertFloatField(
|
2020-09-13 10:27:01 +02:00
|
|
|
field_name='longitude',
|
|
|
|
min_value=-180,
|
|
|
|
max_value=180
|
|
|
|
)
|
2020-09-13 19:12:32 +02:00
|
|
|
|
|
|
|
class SubmittableTestCase(ModelTestCase):
|
|
|
|
model = Submittable
|
|
|
|
|
|
|
|
def test_submitted_when(self):
|
|
|
|
self.assertField(
|
|
|
|
field_name='submitted_when',
|
|
|
|
field_class=models.DateTimeField,
|
|
|
|
must_have={'auto_now_add': True}
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_submitted_by(self):
|
|
|
|
submitted_by = self.assertField(
|
|
|
|
field_name='submitted_by',
|
|
|
|
field_class=models.ForeignKey
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
submitted_by.remote_field.related_name,
|
2020-09-22 21:56:51 +02:00
|
|
|
'%(class)ss',
|
|
|
|
msg='Expecting the related_name of %s to be \'%%(class)ss\', got %s' % (
|
2020-09-13 19:12:32 +02:00
|
|
|
str(submitted_by),
|
|
|
|
submitted_by.remote_field.related_name
|
|
|
|
)
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
submitted_by.null,
|
2020-09-13 19:17:04 +02:00
|
|
|
msg='Expecting %s to has null=True' % (
|
|
|
|
str(submitted_by)
|
2020-09-13 19:12:32 +02:00
|
|
|
)
|
2020-09-13 19:17:04 +02:00
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
submitted_by.blank,
|
|
|
|
msg='Expecting %s to has blank=True' % (
|
|
|
|
str(submitted_by)
|
|
|
|
)
|
|
|
|
)
|
2020-09-13 19:12:32 +02:00
|
|
|
self.assertEqual(
|
2020-09-13 19:17:04 +02:00
|
|
|
submitted_by.remote_field.on_delete,
|
2020-09-13 19:29:30 +02:00
|
|
|
models.SET_NULL,
|
2020-09-13 19:17:04 +02:00
|
|
|
msg='Expecting %s to be null when reference is delete (models.SET_NULL)' % (
|
|
|
|
str(submitted_by)
|
|
|
|
)
|
|
|
|
)
|
2020-09-13 19:12:32 +02:00
|
|
|
|
2020-09-22 21:56:51 +02:00
|
|
|
class PlaceAssetTestCase(ModelTestCase):
|
|
|
|
model = PlaceAsset
|
|
|
|
|
|
|
|
def test_place(self):
|
|
|
|
field = self.assertField('place', models.ForeignKey)
|
|
|
|
self.assertEqual(field.remote_field.on_delete, models.CASCADE,
|
|
|
|
msg='Expecting the deletion of %s to be cascading' % (
|
|
|
|
str(field)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
expected_related_name = '%(class)ss'
|
|
|
|
self.assertEqual(field.remote_field.related_name, expected_related_name,
|
|
|
|
msg='Expecting the related name of %s to be %s' % (
|
|
|
|
str(field),
|
|
|
|
expected_related_name
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
class ExpireableTestCase(ModelTestCase):
|
2020-10-04 22:12:24 +02:00
|
|
|
model = Expireable
|
|
|
|
|
|
|
|
def test_fields(self):
|
|
|
|
self.assertField(
|
|
|
|
field_name='created_when',
|
|
|
|
field_class=models.DateTimeField,
|
|
|
|
must_have={'auto_now_add': True}
|
|
|
|
)
|
|
|
|
self.assertField(
|
|
|
|
field_name='expires_when',
|
|
|
|
field_class=models.DateTimeField
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_is_expired(self):
|
|
|
|
valid_voucher = Voucher.objects.create(
|
|
|
|
code='Test123',
|
|
|
|
expires_when=timezone.now() + datetime.timedelta(minutes=2)
|
|
|
|
)
|
|
|
|
self.assertFalse(
|
|
|
|
valid_voucher.is_expired,
|
|
|
|
msg='Expecing the expirable object to not be expired'
|
|
|
|
)
|
|
|
|
|
|
|
|
invalid_voucher = Voucher.objects.create(
|
|
|
|
code='Test1234',
|
|
|
|
expires_when=timezone.now() - datetime.timedelta(minutes=2)
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
invalid_voucher.is_expired,
|
|
|
|
msg='Expecing the expirable object to be expired'
|
|
|
|
)
|