4

我有一个加载了数据的现有数据库“ A ”,这是我正在集成的另一个项目的一部分。我正在使用多数据库 Django 支持并将我需要持久保存在Django 建模的数据库“ B ”中的东西。

现在我想运行测试,这会为我创建两个测试数据库。问题是测试数据库“A”没有表或数据。

有没有办法避免为“ A ”(这是一个只读的非生产数据库)创建测试数据库并直接使用“ A ”?

4

1 回答 1

2

如果我没看错django.test.simple.DjangoTestSuiteRunner.setup_databases,您可以通过为数据库定义设置来避免创建测试'TEST_MIRROR'数据库。

该选项旨在用于测试主/从配置,但如果将镜像设置为与配置选项的数据库相同的数据库,则可以达到预期效果:

DATABASES = { 
    'A': {
        'ENGINE': ..., # standard configuration goes here
        'TEST_MIRROR': 'A',
    }, 
    'B': {
        'ENGINE': ..., # no TEST_MIRROR, a test database will be created for B
    } 
} 

不会为“ A ”创建测试数据库,而是将其替换TEST_MIRROR为“ A ”,因此测试将按预期在“ A ”和“ test_B ”上运行。

于 2013-05-23T00:27:53.147 回答