32

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

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

如何指定我的测试数据库的名称?我一直在尝试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:

我希望系统在运行我的测试时创建一个单独的数据库,大概称为“auto_tests_testsqldb”;但是,它仍然在问我有关 test_testsqldb 的问题。

任何建议表示赞赏!

4

1 回答 1

46

在 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.

于 2011-01-26T20:32:21.873 回答