From 3bc9065c083e6ca87aa909c14c58a8de268f62ea Mon Sep 17 00:00:00 2001 From: Ran Benita Date: Tue, 7 Dec 2021 16:06:18 +0200 Subject: [PATCH] Make `pytest.mark.django_db(reset_sequences=True)` imply `transaction=True` again Regressed in `4.5.0`. Though it would have been better if it hadn't, changing it now is a breaking change so needs to be fixed. --- docs/changelog.rst | 10 ++++++++++ pytest_django/fixtures.py | 2 +- tests/test_database.py | 7 ++++++- 3 files changed, 17 insertions(+), 2 deletions(-) diff --git a/docs/changelog.rst b/docs/changelog.rst index ee4a06d5..d120e7cc 100644 --- a/docs/changelog.rst +++ b/docs/changelog.rst @@ -1,6 +1,16 @@ Changelog ========= +v4.5.2 (2021-12-07) +------------------- + +Bugfixes +^^^^^^^^ + +* Fix regression in v4.5.0 - ``pytest.mark.django_db(reset_sequence=True)`` now + implies ``transaction=True`` again. + + v4.5.1 (2021-12-02) ------------------- diff --git a/pytest_django/fixtures.py b/pytest_django/fixtures.py index 9cb73269..36020dcc 100644 --- a/pytest_django/fixtures.py +++ b/pytest_django/fixtures.py @@ -167,7 +167,7 @@ def _django_db_helper( serialized_rollback, ) = False, False, None, False - transactional = transactional or ( + transactional = transactional or reset_sequences or ( "transactional_db" in request.fixturenames or "live_server" in request.fixturenames ) diff --git a/tests/test_database.py b/tests/test_database.py index df0d6470..510f4bff 100644 --- a/tests/test_database.py +++ b/tests/test_database.py @@ -287,11 +287,16 @@ def test_reset_sequences_disabled(self, request) -> None: marker = request.node.get_closest_marker("django_db") assert not marker.kwargs - @pytest.mark.django_db(transaction=True, reset_sequences=True) + @pytest.mark.django_db(reset_sequences=True) def test_reset_sequences_enabled(self, request) -> None: marker = request.node.get_closest_marker("django_db") assert marker.kwargs["reset_sequences"] + @pytest.mark.django_db(transaction=True, reset_sequences=True) + def test_transaction_reset_sequences_enabled(self, request) -> None: + marker = request.node.get_closest_marker("django_db") + assert marker.kwargs["reset_sequences"] + @pytest.mark.django_db(databases=['default', 'replica', 'second']) def test_databases(self, request) -> None: marker = request.node.get_closest_marker("django_db")