我使用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的问题。
感谢任何建议!
答案 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
。