From 7cf686934c410165a750d84bfd7e79c03d395009 Mon Sep 17 00:00:00 2001 From: Hugo Rodger-Brown Date: Sun, 10 Sep 2023 21:08:02 +0100 Subject: [PATCH] Add count return value to anonymise_queryset --- anonymiser/models.py | 5 ++++- tests/test_models.py | 6 ++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/anonymiser/models.py b/anonymiser/models.py index 0631e78..0223b47 100644 --- a/anonymiser/models.py +++ b/anonymiser/models.py @@ -115,11 +115,14 @@ def anonymise_object(self, obj: models.Model) -> None: output[field.name] = self.anonymise_field(obj, field.name) self.post_anonymise_object(obj, **output) - def anonymise_queryset(self, queryset: models.QuerySet) -> None: + def anonymise_queryset(self, queryset: models.QuerySet) -> int: """Anonymise all objects in the queryset (and SAVE).""" + count = 0 for obj in queryset: self.anonymise_object(obj) obj.save() + count += 1 + return count def post_anonymise_object( self, obj: models.Model, **updates: AnonymisationResult diff --git a/tests/test_models.py b/tests/test_models.py index 9d70adc..9878f50 100644 --- a/tests/test_models.py +++ b/tests/test_models.py @@ -90,3 +90,9 @@ def test_get_anonymisable_fields(self, user_anonymiser: UserAnonymiser) -> None: assert user_anonymiser.get_anonymisable_fields() == [ User._meta.get_field("first_name") ] + + def test_anonymise_queryset( + self, user: User, user_anonymiser: UserAnonymiser + ) -> None: + assert user_anonymiser.anonymise_queryset(User.objects.none()) == 0 + assert user_anonymiser.anonymise_queryset(User.objects.all()) == 1