PyCharm:用Heroku运行Django测试

问题描述 投票:0回答:1

我试图在一个Django项目中从PyCharm运行单元测试而没有成功。

这是我的项目的架构:

- fugo/  (root repository)
    - .env_test
    - fugoproj/ (django project repository)
        - config/
            - settings.py

我安装了EnvFile插件来加载我的settings.py使用的.env_test变量环境。然后我在Pycharm enter image description here enter image description here上创建了一个Run / Debug配置

从此配置运行测试时,Pycharm控制台显示“没有此类设置文件设置”。找到并运行测试但失败,因为显然无法加载设置。

enter image description here

从Bash shell运行时,单元测试工作正常。我的配置有什么问题?谢谢。

EDIT to provide info about DATABASES settings variable:

在settings.py中,我使用django_heroku包(由Heroku提供)来自动配置数据库:django_heroku.settings(locals())

django_heroku.settings方法如下所示:

def settings(config, *, db_colors=False, databases=True, test_runner=True, staticfiles=True, allowed_hosts=True, logging=True, secret_key=True):

    # Database configuration.
    # TODO: support other database (e.g. TEAL, AMBER, etc, automatically.)
    if databases:
        # Integrity check.
        if 'DATABASES' not in config:
            config['DATABASES'] = {'default': None}

        if db_colors:
            # Support all Heroku databases.
            # TODO: This appears to break TestRunner.
            for (env, url) in os.environ.items():
                if env.startswith('HEROKU_POSTGRESQL'):
                    db_color = env[len('HEROKU_POSTGRESQL_'):].split('_')[0]

                    logger.info('Adding ${} to DATABASES Django setting ({}).'.format(env, db_color))

                    config['DATABASES'][db_color] = dj_database_url.parse(url, conn_max_age=MAX_CONN_AGE, ssl_require=True)

        if 'DATABASE_URL' in os.environ:
            logger.info('Adding $DATABASE_URL to default DATABASE Django setting.')

            # Configure Django for DATABASE_URL environment variable.
            config['DATABASES']['default'] = dj_database_url.config(conn_max_age=MAX_CONN_AGE, ssl_require=True)

            logger.info('Adding $DATABASE_URL to TEST default DATABASE Django setting.')

            # Enable test database if found in CI environment.
            if 'CI' in os.environ:
                config['DATABASES']['default']['TEST'] = config['DATABASES']['default']

        else:
            logger.info('$DATABASE_URL not found, falling back to previous settings!')

    if test_runner:
        # Enable test runner if found in CI environment.
        if 'CI' in os.environ:
            config['TEST_RUNNER'] = 'django_heroku.HerokuDiscoverRunner'

我的.env_test文件不包含任何DATABASE_URL变量

django heroku pycharm
1个回答
0
投票

无论如何,如果你发布你的.env_test结构可能会很好。我猜你的配置必须有一个包含这样的数据库配置的密钥。

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

否则,一个简单的解决方案是创建新的settings.py并删除Heroku函数,并直接放入数据库配置并从.env_test设置其值:

settings_test.朋友:

...

DATABASES = {
    'default': {
        'ENGINE': os.environ['database_engine'],
        'NAME': os.environ['database_name'],
    }
}

.恶女_test.朋友:

...
database_engine=<DATABASE_ENGINE>
database_name=<DATABASE_NAME>
© www.soinside.com 2019 - 2024. All rights reserved.