在settings.py中指定Django测试数据库名称

时间:2011-01-26 20:01:26

标签: django testing settings django-testing django-settings

我使用python对象指定数据库:

DATABASES = {
 'default':{
   'ENGINE':'mysql',
   'NAME':'testsqldb',
   'USER':'<username>',
   'PASSWORD':'<password>',
 },
 'dynamic_data':{
   'ENGINE': 'sqlite3',
   'NAME':'',
   'USER':'',
   'PASSWORD':''
 },
}

如何指定测试数据库的名称?我一直在尝试在settings.py文件中使用TEST_NAME = 'auto_tests'。但是,当我运行python manage.py tests <app_name>时,我收到以下消息:

Creating test database 'default'...
Got an error creating the test database: (1007, "Can't create database 'test_testsqldb'; database exists")
Type 'yes' if you would like to try deleting the test database 'test_testsqldb', or 'no' to cancel:

我希望系统在运行我的测试时创建一个单独的数据库,大概叫做'auto_tests_testsqldb';但是,它还在问我关于test_testsqldb的问题。

感谢任何建议!

1 个答案:

答案 0 :(得分:31)

在Django 1.6及更低版本中,TEST_NAME应该是您的某个数据库字典的键。但在Django 1.7及更高版本中,您使用TEST密钥,该密钥是测试数据库的设置字典。

你可能想要:

DATABASES = {
 'default':{
   'ENGINE':'mysql',
   'NAME':'testsqldb',
   'USER':'<username>',
   'PASSWORD':'<password>',
   'TEST': {
       'NAME': 'auto_tests',
   }
 },
 'dynamic_data':{
   'ENGINE': 'sqlite3',
   'NAME':'',
   'USER':'',
   'PASSWORD':''
 },
}

或者,也许您想要为测试使用不同的引擎?在这种情况下,我认为您只需创建一个单独的设置文件进行测试。它可以从您的标准设置模块导入并覆盖DATABASES