我正在编写一些带有unique=True
andblank=False
和等约束的模型null=False
。我正在尝试为带有鼻子的模型编写测试。但是,如果我编写这样的测试:
from job_sites.models import Site, SiteType
@raises(IntegrityError)
def test_empty_site():
s = Site()
s.save()
@raises(IntegrityError)
def test_empty_site_type():
st = SiteType()
st.save()
我得到一个这样的 DatabaseError:
DatabaseError: current transaction is aborted, commands ignored until end of transaction block
在它运行第一个测试之后。
当我期待错误时,运行 DJango 模型测试的正确方法是什么?
作为参考,模型如下所示:
class SiteType(models.Model):
site_type_id = models.AutoField(primary_key=True)
site_type = models.CharField(max_length=32, unique=True, blank=False, null=False, default=None)
site_type_abbrev = models.CharField(max_length=32, blank=True)
class Meta:
db_table = u'site_types'
class Site(models.Model):
site_id = models.AutoField(primary_key=True, blank=False, null=False, db_index=True)
site_name = models.CharField(max_length=128, blank=False, null=False, db_index=True)
site_type = models.ForeignKey(SiteType, blank=True, null=True)
date_entered = models.DateTimeField(auto_now_add=True)
class Meta:
db_table = u'sites'
我的约束和默认值如下所示:
ALTER TABLE site_types ADD CONSTRAINT site_types_site_type_name_minlen CHECK (char_length(site_type) > 0);
ALTER TABLE sites ALTER COLUMN date_entered SET DEFAULT now();
ALTER TABLE sites ADD CONSTRAINT sites_site_name_minlen CHECK (char_length(site_name) > 0);