[通过PyCharm在Docker中运行Django测试时无法将主机名“ db”转换为地址

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

我有一个带有PostgreSQL后端的简单Django项目:

version: '3'
services:
  db:
    image: postgres:12
    ports:
      - '5432:5432'
    volumes:
      - postgres_data:/var/lib/postgresql/data/
    environment:
      POSTGRES_USER: pycharm
      POSTGRES_PASSWORD: pw123
      POSTGRES_DB: pycharm

  app:
    build: .
    command: python manage.py runserver 0.0.0.0:8000
    ports:
      - '8000:8000'
    volumes:
      - .:/app
    depends_on:
      - db

volumes:
  postgres_data:

[在settings.py中具有以下数据库设置:

DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.postgresql",
        "NAME": "pycharm",
        "USER": "pycharm",
        "PASSWORD": "pw123",
        "HOST": "db",
    }
}

和一个简单的测试:

from django.test import TestCase

class MyTestCase(TestCase):

    def test_example(self):
        assert 1 == 1

当我使用docker-compose运行项目时,一切都很好:

docker-compose up

我可以执行进入运行django应用程序的容器并成功执行测试:

docker-compose run app bash
$ python manage.py test demo.tests.MyTestCase
Creating test database for alias 'default'...
System check identified no issues (0 silenced).
.
----------------------------------------------------------------------
Ran 1 test in 0.002s

OK
Destroying test database for alias 'default'...

我想在PyCharm中运行测试,而不必每次都执行到容器中。我已经使用Docker设置了远程解释器。但是,当我在PyCharm中运行测试时,出现以下错误:

django.db.utils.OperationalError:无法将主机名“ db”转换为地址:名称或服务未知

[当我在PyCharm中运行测试时,似乎应用程序容器找不到数据库容器。这带来了两个问题:

  1. 反正有解决此问题的方法,以便应用程序容器可以找到数据库容器吗?我知道docker networking on localhost is tricky

  2. 反正有设置测试的地方,因此它们不需要连接到数据库容器吗?我觉得Djangopsycopg2应该能够启动模拟PostgreSQL服务进行测试。

过去我解决此问题的一种方法是将其设置为use sqlite3 for my test database;但是,我使用的字段与sqlite不兼容(例如ArrayField),因此这不是一种选择。

python django postgresql docker pycharm
1个回答
0
投票

在您的yml文件中尝试更改

services:
  db:
    image: postgres:11

在您的settings.py中:

 DATABASES = {
        "default": {
            "ENGINE": "django.db.backends.postgresql_psycopg2",
            "NAME": "pycharm",
            "USER": "pycharm",
            "PASSWORD": "pw123",
            "HOST": "db",
            "PORT":5432,
        }
    }
© www.soinside.com 2019 - 2024. All rights reserved.