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

Mic*_*ant 28 testing django settings django-testing django-settings

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

DATABASES = {
 'default':{
   'ENGINE':'mysql',
   'NAME':'testsqldb',
   'USER':'<username>',
   'PASSWORD':'<password>',
 },
 'dynamic_data':{
   'ENGINE': 'sqlite3',
   'NAME':'',
   'USER':'',
   'PASSWORD':''
 },
}
Run Code Online (Sandbox Code Playgroud)

如何指定测试数据库的名称?我一直试图TEST_NAME = 'auto_tests'在settings.py文件中使用.但是,当我运行时,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:
Run Code Online (Sandbox Code Playgroud)

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

任何建议表示赞赏!

Smi*_*ris 35

在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':''
 },
}
Run Code Online (Sandbox Code Playgroud)

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

  • 在 Django 1.10 中,现在是 `"TEST" : {"NAME" : "auto_tests"},`(参见 https://docs.djangoproject.com/en/dev/ref/settings/#test) (2认同)