在 settings.py 中指定 Django 测试数据库名称
Posted
技术标签:
【中文标题】在 settings.py 中指定 Django 测试数据库名称【英文标题】:Specify Django Test Database names in settings.py 【发布时间】:2011-06-16 02:45:12 【问题描述】:我正在使用 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】:在 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
。
【讨论】:
+1 非常感谢,TEST_NAME 键正是我要找的!没想到要查看测试文档以获取设置信息。 在 Django 1.10 中,现在是"TEST" : "NAME" : "auto_tests",
(参见 docs.djangoproject.com/en/dev/ref/settings/#test)以上是关于在 settings.py 中指定 Django 测试数据库名称的主要内容,如果未能解决你的问题,请参考以下文章