繁体   English   中英

如何针对特定数据库进行测试

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM