我有一个加载了数据的现有数据库“ A ”,这是我正在集成的另一个项目的一部分。我正在使用多数据库 Django 支持并将我需要持久保存在Django 建模的数据库“ B ”中的东西。
现在我想运行测试,这会为我创建两个测试数据库。问题是测试数据库“A”没有表或数据。
有没有办法避免为“ A ”(这是一个只读的非生产数据库)创建测试数据库并直接使用“ A ”?
我有一个加载了数据的现有数据库“ A ”,这是我正在集成的另一个项目的一部分。我正在使用多数据库 Django 支持并将我需要持久保存在Django 建模的数据库“ B ”中的东西。
现在我想运行测试,这会为我创建两个测试数据库。问题是测试数据库“A”没有表或数据。
有没有办法避免为“ A ”(这是一个只读的非生产数据库)创建测试数据库并直接使用“ A ”?
如果我没看错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 ”上运行。