使用SQLJYERANGO transaction引发IntegrityDjRori测试

2024-06-10 00:55:15 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试将一个使用LiveServerTestCase进行测试的现有django1.6项目移植到django1.7。我已经将初始的数据固定装置转换为数据迁移。当我这么做的时候,我所有的实时服务器测试都失败了,因为数据被刷新了。然后,我偶然发现了TransactionTestCase的序列化的\u rollback选项,并将其添加到我的测试类中。但是,现在我在运行测试时遇到以下错误:

sqlite3.IntegrityError: UNIQUE constraint failed: django_content_type.app_label, django_content_type.model

我在一个示例应用程序中复制了这个问题:https://github.com/tctimmeh/djangomigrate

模型:

^{pr2}$

数据迁移:

def createData(apps, schema_editor):
    SomeData = apps.get_model('mtestapp', 'SomeData')
    db_alias = schema_editor.connection.alias
    SomeData.objects.using(db_alias).bulk_create([
        SomeData(value = 1),
    ])

class Migration(migrations.Migration):
    dependencies = [
        ('mtestapp', '0001_initial'),
    ]
    operations = [
        RunPython(createData)
    ]

以及测试:

class TestIt(TransactionTestCase):
    serialized_rollback = True
    def test_one(self):
        self.assertEqual(1, SomeData.objects.all().count())
    def test_two(self):
        self.assertEqual(1, SomeData.objects.all().count())

其中一个测试通过了。另一个提出了上述的完整性错误。知道为什么会这样吗?在

编辑:我深入研究了一下,它看起来像django.contrib.contenttypesapp有一个post_migrate管理命令,该命令在刷新测试数据库后运行。有没有办法阻止命令运行?在


Tags: 数据django命令selfmodelobjectsdeftype
3条回答

我在不同的情况下遇到了同样的问题。 我删除了serialized_rollback = True,并在setUp()方法中手动添加了测试数据。在

您需要add your application to available_apps,这样Django的行为就好像只有来自这个应用程序的模型可用。在您的测试用例中,您有:

class TestIt(TransactionTestCase):
  serialized_rollback = True
  available_apps = ['mtestapp']

  def test_one(self):
    self.assertTrue(True)

  def test_two(self):
    self.assertTrue(True)

这在django1.9中已修复:https://code.djangoproject.com/ticket/23727

对于早期版本,我通过重新创建静态数据作为每个测试的设置步骤来解决这个问题。在

相关问题 更多 >