【问题标题】:Django PyTest - Database access not allowed Error even with django_db and fixtures?Django PyTest - 即使使用 django_db 和固定装置,也不允许数据库访问错误?
【发布时间】:2021-02-20 18:51:35
【问题描述】:

我在 django 中学习 PyTest,遇到了我无法解决的问题。

我收到此错误:

____________________________________________________________________________________________________________ ERROR collecting prices_tool/tests/test_views.py ____________________________________________________________________________________________________________
prices_tool/tests/test_views.py:9: in <module>
    from prices_tool.views import results
prices_tool/views.py:14: in <module>
    from prices_tool.forms import SearchForm, FreeSearchForm
prices_tool/forms.py:7: in <module>
    class FreeSearchForm(forms.Form):
prices_tool/forms.py:11: in FreeSearchForm
    for make in makes:
../prices_tool-env/lib/python3.8/site-packages/django/db/models/query.py:287: in __iter__
    self._fetch_all()
../prices_tool-env/lib/python3.8/site-packages/django/db/models/query.py:1308: in _fetch_all
    self._result_cache = list(self._iterable_class(self))
../prices_tool-env/lib/python3.8/site-packages/django/db/models/query.py:111: in __iter__
    for row in compiler.results_iter(chunked_fetch=self.chunked_fetch, chunk_size=self.chunk_size):
../prices_tool-env/lib/python3.8/site-packages/django/db/models/sql/compiler.py:1108: in results_iter
    results = self.execute_sql(MULTI, chunked_fetch=chunked_fetch, chunk_size=chunk_size)
../prices_tool-env/lib/python3.8/site-packages/django/db/models/sql/compiler.py:1154: in execute_sql
    cursor = self.connection.cursor()
../prices_tool-env/lib/python3.8/site-packages/django/utils/asyncio.py:26: in inner
    return func(*args, **kwargs)
../prices_tool-env/lib/python3.8/site-packages/django/db/backends/base/base.py:259: in cursor
    return self._cursor()
../prices_tool-env/lib/python3.8/site-packages/django/db/backends/base/base.py:235: in _cursor
    self.ensure_connection()
E   RuntimeError: Database access not allowed, use the "django_db" mark, or the "db" or "transactional_db" fixtures to enable it.
========================================================================================================================== short test summary info ===========================================================================================================================
ERROR prices_tool/tests/test_views.py - RuntimeError: Database access not allowed, use the "django_db" mark, or the "db" or "transactional_db" fixtures to enable it.
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! Interrupted: 1 error during collection !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
============================================================================================================================== 1 error in 0.47s ==============================================================================================================================

似乎我无法从我的views.py 中导入任何方法。当然,我尝试添加@pytest.mark.django_db 它没有用。我用谷歌搜索了一下,在这里找到了一些帖子,并在我的conftest.py 中添加了这个:

@pytest.fixture(autouse=True)
def enable_db_access_for_all_tests(db):
    pass

当这不起作用时,我什至尝试过:

@pytest.fixture(scope='session')
def django_db_setup():
    settings.DATABASES['default'] = {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'path/to/dbfile.sqlite3',
    }

但没有任何修复或更改错误消息。我该如何解决这个问题?

感谢和干杯!

【问题讨论】:

标签: python django pytest pytest-django


【解决方案1】:

我找到了解决问题的方法。我不确定这是否是明智之举,但现在这是显而易见的解决方案。

只需将问题视图的导入移到@pytest.mark.django_db下方即可。

例如:

@pytest.mark.django_db
class TestViews:
    def test_view(self, client):
        path = reverse('results')
        request = RequestFactory().get(path)
        request.user = mixer.blend(User)

        context = {
            'info': info
        }

        from prices_tool.views import results
        response = results(request, context)
        assert response.status_code == 200

通过这种方式,您将避免由于某些视图正在导入数据库内容而发生的错误。

【讨论】:

  • 可能你在导入中有一些全局元素在导入时执行,例如没有包裹在函数中
猜你喜欢
  • 2022-06-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-02-08
  • 2018-04-28
  • 2020-10-04
相关资源
最近更新 更多