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
This commit is contained in:
@@ -1,33 +1,64 @@
|
||||
from django.test import TestCase
|
||||
|
||||
from .models import Maraudeur, Professionnel
|
||||
from utilisateurs.models import Maraudeur, Professionnel
|
||||
# Create your tests here.
|
||||
def generate_names():
|
||||
i = 0
|
||||
while True:
|
||||
yield {'first_name': 'name%i' % i, 'last_name': 'family%i' % i}
|
||||
i += 1
|
||||
|
||||
class ProfessionelTestCase(TestCase):
|
||||
pass
|
||||
|
||||
#TODO: Un seul objet Maraudeur peut avoir la propriété vraie 'is_referent'
|
||||
|
||||
class MaraudeurTestCase(TestCase):
|
||||
|
||||
maraudeurs = generate_names()
|
||||
|
||||
def create(self):
|
||||
return Maraudeur.objects.create(**next(self.maraudeurs))
|
||||
|
||||
def test_email_set_on_creation(self):
|
||||
m = self.create()
|
||||
self.assertIsNotNone(m.email)
|
||||
|
||||
def test_username_set_on_creation(self):
|
||||
m = self.create()
|
||||
self.assertEqual(m.username, Maraudeur.make_username(m))
|
||||
|
||||
def test_maraudeurs_is_staff(self):
|
||||
m = self.create()
|
||||
self.assertEqual(m.is_staff, True)
|
||||
|
||||
def test_username_set_on_update(self):
|
||||
m = self.create()
|
||||
m.last_name = "test01"
|
||||
m.save()
|
||||
self.assertEqual(m.username, "%s.test01" % (m.first_name[0]))
|
||||
|
||||
class MaraudeurManagerTestCase(TestCase):
|
||||
|
||||
names = [
|
||||
('Arthur', 'Gerbaud'),
|
||||
('Thibault', 'Huet'),
|
||||
('Jacqueline', 'Julien'),
|
||||
{'first_name': 'Astérix', 'last_name': 'Devinci'},
|
||||
{'first_name': 'Obélix', 'last_name': 'Idéfix'},
|
||||
]
|
||||
|
||||
|
||||
def setUp(self):
|
||||
for name in self.names:
|
||||
Maraudeur.objects.create(*name)
|
||||
Maraudeur.objects.create(**name)
|
||||
|
||||
def test_get_or_create_from_first_and_last_name(self):
|
||||
# Existing Maraudeur
|
||||
get_maraudeur = Maraudeur.objects.get(first_name="Thibault", last_name="Huet")
|
||||
maraudeur, created = Maraudeur.objects.get_or_create('Thibault','Huet')
|
||||
get_maraudeur = Maraudeur.objects.get(first_name="Obélix", last_name="Idéfix")
|
||||
maraudeur, created = Maraudeur.objects.get_or_create(first_name='Obélix', last_name='Idéfix')
|
||||
self.assertEqual(created, False)
|
||||
self.assertEqual(maraudeur, get_maraudeur)
|
||||
# Non-existing Maraudeur
|
||||
with self.assertRaises(Maraudeur.DoesNotExist):
|
||||
Maraudeur.objects.get(first_name="Thierry", last_name="Lhermitte")
|
||||
maraudeur, created = Maraudeur.objects.get_or_create('Thierry', 'Lhermitte')
|
||||
maraudeur, created = Maraudeur.objects.get_or_create(first_name='Thierry', last_name='Lhermitte')
|
||||
self.assertEqual(created, True)
|
||||
self.assertEqual(maraudeur, Maraudeur.objects.get(username="t.lhermitte"))
|
||||
|
||||
@@ -37,7 +68,7 @@ class MaraudeurTestCase(TestCase):
|
||||
self.assertEqual(referent1.is_superuser, True)
|
||||
self.assertEqual(referent1, Maraudeur.objects.get_referent())
|
||||
# Set a new referent, existing Maraudeur
|
||||
referent2 = Maraudeur.objects.set_referent("Arthur", "Gerbaud")
|
||||
referent2 = Maraudeur.objects.set_referent("Astérix", "Devinci")
|
||||
self.assertEqual(referent2.is_superuser, True)
|
||||
self.assertEqual(referent2, Maraudeur.objects.get_referent())
|
||||
self.test_referent_is_unique()
|
||||
|
||||
Reference in New Issue
Block a user