eds/cms/tests.py

69 lines
2.3 KiB
Python
Raw Permalink Normal View History

2018-05-23 15:17:03 +02:00
import os
2018-05-22 16:04:39 +02:00
from django.conf import settings
from django.contrib.auth.models import User
from django.core import mail
2018-07-13 09:55:42 +02:00
from django.db.models import Sum, F
from django.test import TestCase
2018-05-22 16:04:39 +02:00
from django.urls import reverse
2018-05-28 10:32:35 +02:00
2018-05-23 15:17:03 +02:00
from cms.models import Domaine, Processus, Module
2018-05-22 16:04:39 +02:00
class PdfTestCase(TestCase):
2018-05-23 15:17:03 +02:00
fixtures = ['enseignant.json', 'domaine.json', 'processus.json', 'module.json']
2018-05-22 16:04:39 +02:00
@classmethod
def setUpTestData(cls):
User.objects.create_superuser('me', 'me@example.org', 'mepassword')
def setUp(self):
self.client.login(username='me', password='mepassword')
2018-05-23 15:17:03 +02:00
def test_index(self):
response = self.client.get('')
self.assertGreater(len(response.content), 200)
2018-05-22 16:04:39 +02:00
def test_plan_pdf(self):
response = self.client.get(reverse('plan-pdf'))
self.assertEqual(
2018-05-23 15:17:03 +02:00
response['content-disposition'],
'attachment; filename="EDS_plan_formation.pdf"'
2018-05-22 16:04:39 +02:00
)
2018-05-23 15:17:03 +02:00
self.assertEqual(response['content-type'], 'application/pdf')
2018-05-22 16:04:39 +02:00
self.assertGreater(len(response.content), 200)
2018-05-23 15:17:03 +02:00
2018-05-23 21:16:25 +02:00
def test_periodes_pdf(self):
response = self.client.get(reverse('periodes-pdf'))
self.assertEqual(
response['content-disposition'],
'attachment; filename="periode_formation.pdf"'
)
self.assertEqual(response['content-type'], 'application/pdf')
self.assertGreater(len(response.content), 200)
2018-05-23 15:17:03 +02:00
def test_periode_presentiel(self):
tot = 0
for m in Module.objects.all():
tot += m.total_presentiel
self.assertEqual(tot, 1200)
def test_periode_pratique(self):
tot = Module.objects.aggregate(Sum('pratique_prof'))
self.assertEqual(tot['pratique_prof__sum'], 1200)
def test_periode_travail_perso(self):
tot = Module.objects.aggregate(Sum('travail_perso'))
2018-05-23 21:16:25 +02:00
self.assertEqual(tot['travail_perso__sum'], 1200)
def test_periode(self):
liste = Module.objects.filter(pratique_prof=0)
context = {}
for i in range(1, 7):
semestre = 'sem{}'.format(i)
context.update({
semestre: liste.exclude(semestre=0),
'tot{}'.format(i): liste.aggregate(Sum(F(semestre)))['{}__sum'.format(semestre)]
})
print(context)