tests.py 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. # -*- coding: utf-8 -*-
  2. import datetime
  3. from decimal import Decimal
  4. from django.test import TestCase, Client
  5. from coin.members.tests import MemberTestsUtils
  6. from coin.members.models import Member, LdapUser
  7. from coin.billing.models import Invoice
  8. from coin.offers.models import Offer, OfferSubscription
  9. from coin.billing.create_subscriptions_invoices import create_member_invoice_for_a_period
  10. from coin.billing.create_subscriptions_invoices import create_all_members_invoices_for_a_period
  11. class BillingInvoiceCreationTests(TestCase):
  12. def setUp(self):
  13. # Créé une offre
  14. self.offer = Offer(name='Offre', billing_period=3, period_fees=30,
  15. initial_fees=50, type='dsl')
  16. self.offer.save()
  17. # Créé un membre
  18. self.ldap_cn = MemberTestsUtils.get_random_ldap_cn()
  19. self.member = Member(first_name='Balthazar', last_name='Picsou',
  20. ldap_cn=self.ldap_cn)
  21. self.member.save()
  22. # Créé un abonnement
  23. self.subscription = OfferSubscription(
  24. subscription_date=datetime.date(2014, 1, 10),
  25. member=self.member,
  26. offer=self.offer)
  27. self.subscription.save()
  28. def tearDown(self):
  29. # Supprime l'utilisateur LDAP créé
  30. LdapUser.objects.get(pk=self.ldap_cn).delete()
  31. def test_first_subscription_invoice_has_initial_fees(self):
  32. """
  33. Test que la première facture générée pour un abonnement possède les
  34. frais de mise en service
  35. """
  36. # Demande la création de la première facture
  37. invoice = create_member_invoice_for_a_period(
  38. self.member, datetime.date(2014, 1, 1))
  39. # La facture doit avoir les frais de mise en service
  40. # Pour tester cela on tri par montant d'item décroissant.
  41. # Comme dans l'offre créé, les initial_fees sont plus élevées que
  42. # les period_fees, il doit sortir en premier
  43. self.assertEqual(invoice.details.order_by('-amount').first().amount, 50)
  44. def test_prorata_for_first_month_subscription(self):
  45. """
  46. Test que la première facture d'un abonnement est facturée au prorata du
  47. nombre de jours restants
  48. """
  49. #Créé la facture pour le mois de janvier
  50. invoice = create_member_invoice_for_a_period(self.member, datetime.date(2014,1,1))
  51. #Comme l'abonnement a été souscris le 10/01 et que la période de
  52. #facturation est de 3 mois, alors le prorata doit être :
  53. #janvier : 22j (31-9)
  54. #fevrier : 28j
  55. #mars : 31j
  56. #22+28+31 / 31+28+31
  57. quantity = Decimal((22.0+28.0+31.0)/(31.0+28.0+31.0))
  58. for detail in invoice.details.all():
  59. if detail.amount != 50:
  60. self.assertEqual(detail.quantity.quantize(Decimal('0.01')),
  61. quantity.quantize(Decimal('0.01')))
  62. def test_subscription_cant_be_charged_twice(self):
  63. """
  64. Test qu'un abonnement ne peut pas être facturé deux fois
  65. (pas de chevauchement possible)
  66. """
  67. # Créé une facture
  68. invoice = Invoice(member=self.member)
  69. invoice.save()
  70. # Créé une facturation pour cet abonnement pour la première période
  71. # de janvier à mars
  72. invoice.details.create(label=self.offer.name,
  73. amount=self.offer.period_fees,
  74. offersubscription=self.subscription,
  75. period_from=datetime.date(2014, 1, 1),
  76. period_to=datetime.date(2014, 3, 31))
  77. # Créé une facturation pour cet abonnement pour une seconde période
  78. # de juin à aout
  79. invoice.details.create(label=self.offer.name,
  80. amount=self.offer.period_fees,
  81. offersubscription=self.subscription,
  82. period_from=datetime.date(2014, 6, 1),
  83. period_to=datetime.date(2014, 8, 31))
  84. # Demande la génération d'une facture pour février
  85. # Elle doit renvoyer None car l'offre est déjà facturée de
  86. # janvier à mars
  87. invoice_test_1 = create_member_invoice_for_a_period(
  88. self.member, datetime.date(2014, 2, 1))
  89. self.assertEqual(invoice_test_1, None)
  90. # Demande la création d'une facture pour avril
  91. # Elle doit fonctionner, mais devrait avoir une période de facturation
  92. # que de 2 mois, d'avril à mai car il y a déjà une facture pour
  93. # la période de juin à aout
  94. invoice_test_2 = create_member_invoice_for_a_period(
  95. self.member, datetime.date(2014, 4, 1))
  96. self.assertEqual(invoice_test_2.details.first().period_from,
  97. datetime.date(2014, 4, 1))
  98. self.assertEqual(invoice_test_2.details.first().period_to,
  99. datetime.date(2014, 5, 31))
  100. class BillingPDFTests(TestCase):
  101. def test_download_invoice_pdf_return_a_pdf(self):
  102. """
  103. Test que le téléchargement d'une facture en format pdf retourne bien un
  104. pdf
  105. """
  106. # Créé un membre
  107. ldap_cn = MemberTestsUtils.get_random_ldap_cn()
  108. member = Member(first_name='A', last_name='A',
  109. ldap_cn=ldap_cn)
  110. member.save()
  111. member.change_password('1234')
  112. # Créé une facture
  113. invoice = Invoice(member=member)
  114. invoice.save()
  115. # Se connect en tant que le membre
  116. client = Client()
  117. client.login(username=ldap_cn, password='1234')
  118. # Tente de télécharger la facture
  119. response = client.get('/billing/invoice/%i/pdf' % invoice.id)
  120. # Vérifie return code 200 et contient chaine %PDF-1.
  121. self.assertContains(response, '%PDF-1.', status_code=200, html=False)
  122. LdapUser.objects.get(pk=ldap_cn).delete()
  123. def test_that_only_owner_of_invoice_can_download_it_as_pdf(self):
  124. """
  125. Test qu'une facture ne peut pas être téléchargée par quelqu'un qui n'en
  126. est pas le propriétaire.
  127. Test qu'une erreur 403 est bien retournée en cas de tentative
  128. infructueuse
  129. """
  130. # Créé un membre A
  131. member_a_login = MemberTestsUtils.get_random_ldap_cn()
  132. member_a_pwd = '1234'
  133. member_a = Member(first_name='A', last_name='A',
  134. ldap_cn=member_a_login)
  135. member_a.save()
  136. member_a.change_password(member_a_pwd)
  137. # Créé un membre B
  138. member_b_login = MemberTestsUtils.get_random_ldap_cn()
  139. member_b_pwd = '1234'
  140. member_b = Member(first_name='B', last_name='B',
  141. ldap_cn=member_b_login)
  142. member_b.save()
  143. member_b.change_password(member_b_pwd)
  144. # Créé une facture pour le membre A
  145. invoice_a = Invoice(member=member_a)
  146. invoice_a.save()
  147. # Simule une connexion en tant que A
  148. client = Client()
  149. client.login(username=member_a_login, password=member_a_pwd)
  150. # Tente de télécharger la facture de A en tant que A
  151. response = client.get('/billing/invoice/%i/pdf' % invoice_a.id)
  152. # Vérifie que B a reçu retour OK 200
  153. self.assertEqual(response.status_code, 200)
  154. # Simule une connexion en tant que B
  155. client = Client()
  156. client.login(username=member_b_login, password=member_b_pwd)
  157. # Tente de télécharger la facture de A en tant que B
  158. response = client.get('/billing/invoice/%i/pdf' % invoice_a.id)
  159. # Vérifie que B a reçu retour Forbidden 403
  160. self.assertEqual(response.status_code, 403)
  161. LdapUser.objects.get(pk=member_a_login).delete()
  162. LdapUser.objects.get(pk=member_b_login).delete()