我有以下django测试用例,它给了我错误:
class MyTesting(unittest.TestCase):
def setUp(self):
self.u1 = User.objects.create(username='user1')
self.up1 = UserProfile.objects.create(user=self.u1)
def testA(self):
...
def testB(self):
...
当我运行我的测试时,testA
将成功通过,但在testB
启动之前,我得到以下错误:
IntegrityError: column username is not unique
很明显,它试图在每个测试用例之前创建self.u1
,并发现它已经存在于数据库中。如何在每个测试用例之后正确地清理它,以便后续的用例能够正确运行?
发布于 2010-05-15 22:35:57
在每个测试用例之前和之后调用单元测试上的setUp
和tearDown
方法。定义删除已创建用户的tearDown
方法。
class MyTesting(unittest.TestCase):
def setUp(self):
self.u1 = User.objects.create(username='user1')
self.up1 = UserProfile.objects.create(user=self.u1)
def testA(self):
...
def tearDown(self):
self.up1.delete()
self.u1.delete()
我也建议create user profiles使用post_save
signal,除非你真的想为每个用户手动创建用户配置文件。
删除评论的后续:
当Django删除一个对象时,它模拟了DELETE CASCADE上的SQL约束的行为--换句话说,任何具有指向要删除的对象的外键的对象都将被删除。
在您的示例中,用户配置文件指向user,因此您应该先删除该用户,然后同时删除该配置文件。
发布于 2012-12-30 00:09:30
如果您希望django在每次测试运行后自动刷新测试数据库,那么您应该扩展django.test.TestCase
,而不是像您目前正在做的那样扩展django.utils.unittest.TestCase
。
在每次测试后转储数据库是一种很好的做法,这样您就可以额外确保测试的一致性,但请注意,由于这种额外的开销,测试的运行速度会变慢。
请参阅"Writing Tests" Django Docs中的WARNING部分。
发布于 2010-05-15 22:35:16
准确地说,setUp
之所以存在,就是为了在每个测试用例之前运行一次。
逆向方法在每个测试用例之后运行一次,名为tearDown
:这是删除self.u1
等的地方(假设只调用self.u1.delete()
,除非您除了删除对象之外还有补充的专用清理需求)。
https://stackoverflow.com/questions/2840467
复制相似问题