Files
django-maraudes/notes/tests.py
artus40 be087464fc Remaster (#38)
* setup new 'statistiques' module

* added 'graphos' package and created first test graph

* put graphos in requirements, deleted local folder

* added "load_csv" management command !

* added update of premiere_rencontre field in 'load_csv' management command

* added missing urls.py file

* added 'merge' action and view

* added 'info_completed' ratio

* linked sujets:merge views inside suivi:details

* added link to maraudes:details in notes table headers, if any

* Major reorganisation, moved 'suivi' and 'sujets' to 'notes', cleanup in 'maraudes', dropping 'website' mixins (mostly useless)

* small cleanup

* worked on Maraude and Sujet lists

* corrected missing line in notes.__init__

* restored 'details' view for maraudes and sujets insie 'notes' module

* worked on 'notes': added navigation between maraude's compte-rendu, right content in details, header to list tables

* changed queryset for CompteRenduDetailsView to all notes of same date, minor layout changes

* added right content to 'details-sujet', created 'statistiques' view and update templates

* restored 'statistiques' ajax view in 'details-sujet', fixed 'merge_two' util function

* added auto-creation of FicheStatistique (plus some tests), pagination for notes in 'details-sujet'

* added error-prone cases in paginator

* fixed non-working modals, added titles

* added UpdateStatistiques capacity in CompteRenduCreate view

* fixed missing AjaxTemplateMixin for CreateSujetView, worked on compte-rendu creation scripts

* fixed MaraudeManager.all_of() for common Maraudeurs, added color hints in planning

* re-instated statistiques module link and first test page

* added FinalizeView to send a mail before finalizing compte-rendu

* Added PieChart view for FicheStatistique fields

* small style updates, added 'age' and 'genre' fields from sujets in statistiques.PieChartView

* worked on statistiques, fixed small issues in 'notes' list views

* small theme change

* removed some dead code

* fixed notes.tests, fixed statistiques.info_completed display, added filter in SujetLisView

* added some tests

* added customised admin templates

* added authenticate in CustomAuthenticatationBackend, more verbose login thanks to messages

* added django-nose for test coverage

* Corrected raising exception on first migration

On first migration, qs.exists() would previously be called and raising an Exception, sot he migrations would fail.

* Better try block

* cleaned up custom settings.py, added some overrides of django base_settings

* corrected bad dictionnary key
2017-06-11 17:16:17 +02:00

122 lines
4.4 KiB
Python

from django.core.exceptions import ValidationError
from django.test import TestCase
from .models import Note, Sujet
# Create your tests here.
# TODO: test 'actions.py'
class SujetModelTestCase(TestCase):
def setUp(self):
pass
def test_statistiques_is_autocreated(self):
new_sujet = Sujet.objects.create(prenom="Astérix")
self.assertIsNotNone(new_sujet.statistiques)
def test_at_least_one_in_name_surname_firstname(self):
self.assertIsInstance(Sujet.objects.create(nom="DeGaulle"), Sujet)
self.assertIsInstance(Sujet.objects.create(surnom="Le Gaulois"), Sujet)
self.assertIsInstance(Sujet.objects.create(prenom="Astérix"), Sujet)
def test_raises_validation_error_if_no_name(self):
with self.assertRaises(ValidationError):
Sujet.objects.create(age=25)
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