错误 运行 python 2/3 升级后的 django 测试,unittest.loader._FailedTest

Errors running django tests after python 2/3 upgrade, unittest.loader._FailedTest

我正在帮助我的团队将他们的应用程序从 python 2 升级到 3,并且 运行 在单元测试中遇到错误。当我 运行 测试时:

python3 manage.py test groupapp --settings=settings.deploy_dev

我收到以下错误。但是如果我 运行 有:

python3 manage.py test groupapp.tests --settings=settings.deploy_dev

没有发生错误。值得注意的是,即使我从测试文件夹中删除了所有测试后,这些错误也会发生,据我所知,它们没有连接到实际的测试用例。

我不明白 python 3 中这两个调用之间的区别。在 python 2 中,如果我 运行 这两个调用我得到相同的结果(没有测试失败).

groupapp_v2.groupapp.admin (unittest.loader._FailedTest) ... ERROR
groupapp_v2.groupapp.models (unittest.loader._FailedTest) ... ERROR

======================================================================
ERROR: groupapp_v2.groupapp.admin (unittest.loader._FailedTest)
----------------------------------------------------------------------
ImportError: Failed to import test module: groupapp_v2.groupapp.admin
Traceback (most recent call last):
  File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/unittest/loader.py", line 462, in _find_test_path
    package = self._get_module_from_name(name)
  File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/unittest/loader.py", line 369, in _get_module_from_name
    __import__(name)
  File "/Users/matthew/bitbucket/consortium-website/groupapp_v2/groupapp/admin/__init__.py", line 73, in <module>
    admin.site.register(Grid, GridAdmin)
  File "/Users/matthew/virtualenv/groupapp-python3.6/lib/python3.6/site-packages/django/contrib/admin/sites.py", line 110, in register
    raise AlreadyRegistered('The model %s is already registered' % model.__name__)
django.contrib.admin.sites.AlreadyRegistered: The model Grid is already registered


======================================================================
ERROR: groupapp_v2.groupapp.models (unittest.loader._FailedTest)
----------------------------------------------------------------------
ImportError: Failed to import test module: groupapp_v2.groupapp.models
Traceback (most recent call last):
  File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/unittest/loader.py", line 462, in _find_test_path
    package = self._get_module_from_name(name)
  File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/unittest/loader.py", line 369, in _get_module_from_name
    __import__(name)
  File "/Users/matthew/bitbucket/consortium-website/groupapp_v2/groupapp/models/__init__.py", line 7, in <module>
    from .deployable import *
  File "/Users/matthew/bitbucket/consortium-website/groupapp_v2/groupapp/models/deployable.py", line 22, in <module>
    class Keyword_LibraryM2M(Model):
  File "/Users/matthew/virtualenv/groupapp-python3.6/lib/python3.6/site-packages/django/db/models/base.py", line 118, in __new__
    "INSTALLED_APPS." % (module, name)
RuntimeError: Model class groupapp_v2.groupapp.models.deployable.Keyword_LibraryM2M doesn't declare an explicit app_label and isn't in an application in INSTALLED_APPS.```

unittest 中的测试发现(默认的 Django 测试 运行ner)从 2.7 到 3 发生了很大变化。您尝试做的实际上是 Django 文档中调用测试的两种不同方式:

# Run all the tests in the animals.tests module
$ ./manage.py test animals.tests

# Run all the tests found within the 'animals' package
$ ./manage.py test animals

您的应用程序可能有更多测试发现您明确告诉 运行ner 运行 的那些,这不是您的应用程序的问题,这只是库的问题.