在 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 &lt;app_name&gt; 时,我收到以下消息:

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 测试数据库名称的主要内容,如果未能解决你的问题,请参考以下文章

Django的基本使用

在 Heroku 上的 Django 应用中启用 CORS

django 中每个应用程序的单独媒体设置

27_扩展User模型

23-自定义用户模型

如何在 Django 邮件中指定名称?