使用PyCharm在Docker容器内运行Django测试用例时出错(AppRegistryNotReady)



我在这里看到了一个类似的解决方案:

https://intellij-support.jetbrains.com/hc/en-us/community/posts/360002753800-Django-console-not-working-properly-on-docker

我已经实现了上述解决方案。奇怪的是,我可以在PyCharm中打开Django控制台而不会出错。我已经通过执行以下操作确认Django控制台正在我的Docker容器中运行:


>>> import socket
>>> socket.gethostname()
'f6f418ce5d14'

我有一个入口点脚本(bash脚本(,它在Docker容器中执行以下内容而不会出错:


python manage.py migrate
python manage.py loaddata --format json /srv/app/api/opp/management/fixtures/dev.json

但是,当PyCharm尝试使用PyCharm自己的nose测试运行程序执行测试用例时,就会出现错误。以下是PyCharm在使用Docker容器运行Django测试用例时的输出摘录:


app_1 | Installed 127 object(s) from 1 fixture(s)
app_1 | app_1 | Launching Nosetest with arguments /opt/.pycharm_helpers/pycharm/_jb_nosetest_runner.py /srv/app/api/opp/tests in /srv/app/api
app_1 | 
app_1 | app_1 | app_1 | app_1 | app_1 | app_1 | app_1 | app_1 | 
error in setup context
Traceback (most recent call last):
File "/usr/local/lib/python3.8/site-packages/nose/suite.py", line 210, in run
self.setUp()
File "/usr/local/lib/python3.8/site-packages/nose/suite.py", line 293, in setUp
self.setupContext(ancestor)
File "/usr/local/lib/python3.8/site-packages/nose/suite.py", line 316, in setupContext
try_run(context, names)
File "/usr/local/lib/python3.8/site-packages/nose/util.py", line 471, in try_run
return func()
File "/usr/local/lib/python3.8/site-packages/django/test/testcases.py", line 1131, in setUpClass
call_command('loaddata', *cls.fixtures, **{'verbosity': 0, 'database': db_name})
File "/usr/local/lib/python3.8/site-packages/django/core/management/__init__.py", line 102, in call_command
app_name = get_commands()[command_name]
File "/usr/local/lib/python3.8/site-packages/django/core/management/__init__.py", line 68, in get_commands
for app_config in reversed(list(apps.get_app_configs())):
File "/usr/local/lib/python3.8/site-packages/django/apps/registry.py", line 144, in get_app_configs
self.check_apps_ready()
File "/usr/local/lib/python3.8/site-packages/django/apps/registry.py", line 135, in check_apps_ready
raise AppRegistryNotReady("Apps aren't loaded yet.")
django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet.

似乎是PyCharm提供的测试运行程序导致了这个问题。根据我看到的输出,我相信PyCharm测试运行程序在运行测试用例之前没有执行以下命令:


import django
django.setup()

我试着在Docker容器中找到PyCharm测试,这样我就可以手动编辑它。但是,我找不到它。帮帮我,欧比-万·卡诺比,你是我唯一的希望!

今天我逐行浏览了我的Dockerfile和docker-compose.yaml文件。我发现有一些问题与Docker和PyCharm完全无关。我从一个学院里复制了一些其他的Bash配置脚本。事实证明,问题在于没有安装所有正确的alpine软件包,并且在设置Bash变量时有两个额外的空间。例如,而不是这条错误的线:

VARIABLE = "some value"

我应该有:

VARIABLE = "some value"

不用说,错过了这么琐碎的事情,我觉得有点傻。但是,当时我还不知道如何解决python内部的Docker问题:3-alpine映像。我在这里发布我的答案/非答案,以防其他被误导的灵魂,比如我自己,发现它有用。

相关内容

最新更新