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

时间:2019-12-14 21:47:27

标签: python django postgresql docker pycharm

我有一个带有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),因此这不是一种选择。

2 个答案:

答案 0 :(得分:1)

在您的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,
        }
    }

答案 1 :(得分:0)

每次我创建一个新的pycharm / docker项目时,这都会吸引我。

Pycharm不了解db网络,您需要更改pycharm运行配置,以将db_default(或任何网络名称)添加为pycharm运行配置上的network_mode。

run/debug config

where the network mode value comes from the network you get from docker inspect db