Pytest и Django транзакционная база данных - PullRequest
0 голосов
/ 11 июня 2019

Я использую производственную базу данных для тестов (фактически это тестовая база данных в докере).Вопрос в том, как сделать так, чтобы тесты выполнялись в транзакциях с этой базой данных.Мне нужно то же поведение, что и @pytest.mark.django_db(transaction=True), но с производственной базой данных.

Текущая настройка:

conftest.py

@pytest.fixture(scope='session')
def django_db_setup():
    """Avoid creating/setting up the test database"""
    pass


@pytest.fixture
def db(request, django_db_setup, django_db_blocker):
    django_db_blocker.unblock()


@pytest.fixture
def myfixture(db):
    ...
    return SomeObject

test_example.py

def test_something(db, myfixture):
    assert ...

1 Ответ

0 голосов
/ 13 июня 2019

Наконец-то я нашел решение.

Добавить код загрузки светильников в db приспособление:

conftest.py

from django.core.management import call_command

@pytest.fixture
def db(request, django_db_setup, django_db_blocker):
    django_db_blocker.unblock()
    call_command('loaddata', 'fixture.json')

И используйте @pytest.mark.django_db(transaction=True) с тестами:

test_example.py

@pytest.mark.django_db(transaction=True)
def test_something(db, myfixture):
    assert ...

После каждого теста pytest будет очищать вашу базу данных и заполнять ее данными о приборах.

...