add NoteManager and NoteQuerySet, and basic tests

This commit is contained in:
Arthur Gerbaud
2016-08-07 11:50:01 +02:00
parent 2a8082e5b1
commit 9646c9f8ab
3 changed files with 129 additions and 6 deletions

View File

@@ -1,9 +1,32 @@
from django.db.models import Manager
from django.db.models.query import QuerySet
class NoteQuerySet(QuerySet):
def _ordered_by_field(self, field, reverse=False):
return self.order_by( '%s%s' % ( "-" if reverse else "",
field
)
)
def by_date(self, reverse=False):
return self._ordered_by_field('created_date', reverse=reverse)
def by_time(self, reverse=False):
return self._ordered_by_field('created_time', reverse=reverse)
class NoteManager(Manager):
def by_date(self):
return self.get_queryset().order_by('created_date')
def get_queryset(self):
return NoteQuerySet(self.model)
get_query_set = get_queryset
def by_date(self, **kwargs):
return self.get_queryset().by_date(**kwargs)
def by_time(self, **kwargs):
return self.get_queryset().by_time(**kwargs)
def by_time(self):
return self.get_queryset().order_by('created_time')

View File

@@ -40,7 +40,9 @@ class Note(models.Model):
return super().save(*args, **kwargs)
def __str__(self):
return "%s of %s" % (self.child_class.__qualname__, self.created_by)
return "%s [%s %s]" % ( self.child_class.__qualname__,
self.created_date,
self.created_time)
def note_date(self):
""" Default 'created_date' value. Child may override this method. """

View File

@@ -1,3 +1,101 @@
from django.test import TestCase
from .models import Note
# Create your tests here.
class NoteManagerTestCase(TestCase):
""" managers.NoteManager Test Case """
def setUp(self):
from notes.managers import NoteManager
self.note_manager = NoteManager
def test_note_default_manager_is_NoteManager(self):
self.assertIsInstance(Note.objects, self.note_manager,
msg="%s is not Note default manager" % self.note_manager)
def test_by_date(self):
prev_note = None
for note in Note.objects.by_date(reverse=False):
if not prev_note:
prev_note = note
else:
self.assertLessEqual(prev_note.created_date, note.created_date,
msg="%s is not same date or prior to %s" % (prev_note, note))
prev_note = note
def test_by_date_reversed(self):
prev_note = None
for note in Note.objects.by_date(reverse=True):
if not prev_note:
prev_note = note
else:
self.assertGreaterEqual(prev_note.created_date, note.created_date,
msg="%s is not same date or later to %s" % (prev_note, note))
prev_note = note
def test_by_time(self):
prev_note = None
for note in Note.objects.by_time(reverse=False):
if not prev_note:
prev_note = note
else:
self.assertLessEqual(prev_note.created_time, note.created_time,
msg="%s is not same time or prior to %s" % (prev_note, note))
prev_note = note
def test_by_time_reversed(self):
prev_note = None
for note in Note.objects.by_time(reverse=True):
if not prev_note:
prev_note = note
else:
self.assertLessEqual(prev_note.created_time, note.created_time,
msg="%s is not same time or later to %s" % (prev_note, note))
prev_note = note
class NoteQuerySetTestCase(TestCase):
def setUp(self):
self.qs = Note.objects.all()
def test_by_date(self):
prev_note = None
for note in self.qs.by_date(reverse=False):
if not prev_note:
prev_note = note
else:
self.assertLessEqual(prev_note.created_date, note.created_date,
msg="%s is not same date or prior to %s" % (prev_note, note))
prev_note = note
def test_by_date_reversed(self):
prev_note = None
for note in self.qs.by_date(reverse=True):
if not prev_note:
prev_note = note
else:
self.assertGreaterEqual(prev_note.created_date, note.created_date,
msg="%s is not same date or later to %s" % (prev_note, note))
prev_note = note
def test_by_time(self):
prev_note = None
for note in self.qs.by_time(reverse=False):
if not prev_note:
prev_note = note
else:
self.assertLessEqual(prev_note.created_time, note.created_time,
msg="%s is not same time or prior to %s" % (prev_note, note))
prev_note = note
def test_by_time_reversed(self):
prev_note = None
for note in self.qs.by_time(reverse=True):
if not prev_note:
prev_note = note
else:
self.assertLessEqual(prev_note.created_time, note.created_time,
msg="%s is not same time or later to %s" % (prev_note, note))
prev_note = note