So I have a problem in writing my unit tests for a Check and Unique constraint. Here are the their definition:
# assert that a partner can have only one headquarter
constraints = [
   models.UniqueConstraint(
       fields=['partner', 'active'],
       condition=models.Q(headquarter=True),
       name='HQ already set.'
     )
]
# assert every partner contant has at least one of email/phone number pair defined
constraints = [            
   models.CheckConstraint(
       check= (
                 models.Q(email__isnull=False) &
                 models.Q(phone_number__isnull=False)
              ),
       name='E-mail or phone number should be set.'
   )
]
And the unit test asserts which fails:
from django.db.utils import IntegrityError
....
# HQ already defined so it should work
with self.assertRaises(Exception) as raised:
    partnerHQCopy.save()
self.assertEqual(IntegrityError, type(raised.exception))
.....
# The contact added has both email and phone number None
with self.assertRaises(Exception) as raised:
    partnerContact.save()
self.assertEqual(IntegrityError, type(raised.exception))
And the traceback:
======================================================================
ERROR: test_unique_hq_for_partner (partners.tests.PartnerModelsTestCases)
----------------------------------------------------------------------
.....
sqlite3.IntegrityError: UNIQUE constraint failed: partners_partnerbranch.partner_id, partners_partnerbranch.active
.....
django.db.utils.IntegrityError: UNIQUE constraint failed: partners_partnerbranch.partner_id, partners_partnerbranch.active
======================================================================
ERROR: test_partner_contact_no_email_no_phone (partners.tests.PartnerModelsTestCases)
----------------------------------------------------------------------
.....
sqlite3.IntegrityError: CHECK constraint failed: E-mail or phone number should be set.
.....
django.db.utils.IntegrityError: CHECK constraint failed: E-mail or phone number should be set.
 
    