我有一个带有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中运行测试时,似乎应用程序容器找不到数据库容器。这带来了两个问题:
总有办法解决此问题,以便应用程序容器可以找到数据库容器吗?我知道docker networking on localhost is tricky。
总有没有设置测试,因此它们不需要连接到数据库容器?我觉得Django
或psycopg2
应该能够启动模拟PostgreSQL服务进行测试。
我过去解决此问题的一种方法是使用use sqlite3 for my test database;但是,我使用的字段与sqlite不兼容(例如ArrayField),因此这不是一种选择。
答案 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。
where the network mode value comes from the network you get from docker inspect db