Как настроить Postgres для работы с pytest

Я использую django для бэкенда и pytest для обработки тестов.

Я переключил базу данных моего проекта с sqlite3 на postgres, все работает отлично, кроме тестов, почему-то все мои тесты не работают.

до переключения я мог получить доступ к моей базе данных во время тестирования с помощью следующей строки:

pytestmark = pytest.mark.django_db

но теперь после использования Postgres в качестве моей базы данных я получаю эту ошибку на всех моих тестах

UndefinedTable

The above exception was the direct cause of the following exception:

request = <SubRequest '_django_db_marker' for <Function test_logged_user_saved_recipes_url_reverse>>

    @pytest.fixture(autouse=True)
    def _django_db_marker(request):
        """Implement the django_db marker, internal to pytest-django.

        This will dynamically request the ``db``, ``transactional_db`` or
        ``django_db_reset_sequences`` fixtures as required by the django_db marker.   
        """
        marker = request.node.get_closest_marker("django_db")
        if marker:
            transaction, reset_sequences = validate_django_db(marker)
            if reset_sequences:
                request.getfixturevalue("django_db_reset_sequences")
            elif transaction:
                request.getfixturevalue("transactional_db")
            else:
>               request.getfixturevalue("db")

знает ли кто-нибудь правильный способ доступа к базе данных Postgres при использовании pytest? или может есть способ переключиться на sqlite3 db только при тестировании?

спасибо заранее

поэтому добавление этого кода в conftest.py решило проблему для меня

@pytest.fixture(scope='session')
def django_db_setup():
    settings.DATABASES['default'] = {
        'ENGINE': 'django.db.backends.postgres',
        'HOST': 'localhost',
        'NAME': 'postgres',
}

Вернуться на верх