首页 > 解决方案 > Django 2.0 - 当我们有多个数据库时,如何处理只对一个数据库进行测试?

问题描述

首先,我是新来这里提问的,所以如果我做得不完美,请耐心等待:) 这里是...

我正在设置一个 Django2.0 API 来处理统计数据。它有自己的“默认”数据库来写东西,但我需要其他几个只读的数据库。这就是现在的设置。

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'dev_gpws',
        'USER': 'dev_gpws_user',
        'PASSWORD': 'gpws_pwd',
        'HOST': 'localhost',
        'PORT': '5432',
    },
    'other_db': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'other_db_name',
        'USER': 'other_db_user',
        'PASSWORD': 'other_db_pwd',
        'HOST': 'other_db_host',
        'PORT': '5432',
    },
}

当fabric将项目部署到staging时,部分例程是./manage.py test,导致如下错误:

(gpws) dev_gpws@af968cdb7653:~/gpws/project$ ./manage.py test
Creating test database for alias 'default'...
Creating test database for alias 'other_db'...
Got an error creating the test database: ERREUR:  permission denied to create database

other_db_user考虑到只读用户是完全有意义的,所以我想禁用 django 对该数据库的测试。有干净的方法吗?此外,此统计应用程序稍后将与相当多的数据库链接,因此我宁愿使用易于扩展的解决方案。

提前感谢您提供的任何提示!

编辑:为了澄清,我需要在测试时访问 read_only 数据库,但 django 不应该创建 test_databases,它应该使用它给出的暂存数据库:)

标签: djangodjango-databasedjango-tests

解决方案


推荐阅读