From df8858122b635b92916aadde2026b225c1a8c4e9 Mon Sep 17 00:00:00 2001 From: Christian Hess Date: Tue, 20 Feb 2024 15:51:59 -0300 Subject: [PATCH] fix: make is_active_for_user consider when everyone is False fixes #401 --- waffle/models.py | 6 +++++- waffle/tests/test_models.py | 12 +++++++++--- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/waffle/models.py b/waffle/models.py index ffa58e7d..d119a711 100644 --- a/waffle/models.py +++ b/waffle/models.py @@ -233,6 +233,9 @@ def is_active_for_user(self, user: AbstractBaseUser) -> bool | None: if self.everyone: return True + if self.everyone is False: + return False + if self.authenticated and user.is_authenticated: return True @@ -396,7 +399,8 @@ def _get_group_ids(self) -> set[Any]: def is_active_for_user(self, user: AbstractBaseUser) -> bool | None: is_active = super().is_active_for_user(user) - if is_active: + + if is_active is True or is_active is False: return is_active user_ids = self._get_user_ids() diff --git a/waffle/tests/test_models.py b/waffle/tests/test_models.py index 7ec9b4a7..eabe4060 100644 --- a/waffle/tests/test_models.py +++ b/waffle/tests/test_models.py @@ -1,3 +1,4 @@ +from django.contrib.auth import get_user_model from django.test import TestCase from waffle import ( @@ -5,8 +6,6 @@ get_waffle_sample_model, get_waffle_switch_model, ) -from django.contrib.auth.models import User - class ModelsTests(TestCase): def test_natural_keys(self): @@ -33,6 +32,13 @@ def test_flag_is_not_active_for_none_requests(self): self.assertEqual(flag.is_active(None), False) def test_is_active_for_user_when_everyone_is_active(self): + user = get_user_model()(username='john.doe') flag = get_waffle_flag_model().objects.create(name='test-flag') flag.everyone = True - self.assertEqual(flag.is_active_for_user(User()), True) \ No newline at end of file + self.assertEqual(flag.is_active_for_user(user), True) + + def test_is_active_for_user_when_everyone_is_disabled(self): + user = get_user_model()(username='john.doe') + flag = get_waffle_flag_model().objects.create(name='test-flag') + flag.everyone = False + self.assertEqual(flag.is_active_for_user(user), False)