[英]How to test against specific database
我工作的公司有一个测试服务器,里面存放着所有的测试数据。 我正在尝试添加一些非常需要的单元测试,这些单元测试在测试服务器上引用了我们的 Django 数据库。 我遇到的问题是正在创建测试数据库,而不是指向我提供的数据库。 如果在系统参数中进行测试,我曾尝试设置数据库,如下所示:
if 'test' in sys.argv:
DATABASES = {
'default': { # VM Testing
'ENGINE': 'sql_server.pyodbc',
'NAME': 'x',
'USER': 'x',
'PASSWORD': "x",
'HOST': 'x.x.x.x', #
'PORT': '',
'OPTIONS': {
'driver': 'FreeTDS',
'dsn': 'mssql_staging_1',
'extra_params': 'TDS_VERSION=8.0',
'use_legacy_datetime': False
},
},
}
DEBUG = False
TEMPLATE_DEBUG = False
虽然它进入了这个 if 语句,但在运行 python manage.py test 时仍然会创建测试数据库。 有什么建议吗? FWIW 到目前为止我所有的测试都使用 DRF 及其 APITestCase 类。 谢谢!
编辑:
我尝试运行 python manage.py test -k 但是 Django 仍然使用默认的测试数据库。 我投入了一组跟踪进行检查,没有发现任何物体。 终端输出是:
Using existing test database for alias 'default'...
这是我更新的更新设置:
DATABASES = {
'default': {
'ENGINE': 'sql_server.pyodbc',
'NAME': 'x',
'USER': 'x',
'PASSWORD': "x",
'HOST': 'x.x.x.x',
'PORT': '',
'OPTIONS': {
'driver': 'FreeTDS',
'dsn': 'mssql_staging_1',
'extra_params': 'TDS_VERSION=8.0',
'use_legacy_datetime': False
}
},
'replica': {
'ENGINE': 'sql_server.pyodbc',
'NAME': 'x',
'USER': 'x',
'PASSWORD': "x",
'HOST': 'x.x.x.xreplica',
'PORT': '',
'OPTIONS': {
'driver': 'FreeTDS',
'dsn': 'mssql_staging_1',
'extra_params': 'TDS_VERSION=8.0',
'use_legacy_datetime': False
},
'TEST': {
'MIRROR': 'default',
}
}
}
通过执行以下操作,我终于能够让我的测试运行器工作:
我将测试条件从暂存设置文件移动到测试设置文件(称为 testing.py)
数据库设置:
if 'test' in sys.argv:
# WILL NOT WORK WHEN IF IS MISSING
DATABASES = {
'default': { # VM Testing
'ENGINE': 'sql_server.pyodbc',
'NAME': 'x',
'USER': 'x',
'PASSWORD': "x",
'HOST': 'x.x.x.x',
'PORT': '',
'OPTIONS': {
'driver': 'FreeTDS',
'dsn': 'mssql_staging_1',
'extra_params': 'TDS_VERSION=8.0',
'use_legacy_datetime': False
},
'TEST': {
'MIRROR': 'default',
}
},
}
并使用以下命令运行我的测试:
python manage.py test --settings=Project.settings.testing -k
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.