diff options
| author | Aditya | 2016-04-12 17:49:27 +0530 |
|---|---|---|
| committer | Barry Warsaw | 2016-05-03 15:49:43 -0400 |
| commit | f0e2b8b42c47c1447d5677e1e77f38b0d409c652 (patch) | |
| tree | 00850761a1f92e08f8699944935e326a9aec3a4b /src | |
| parent | 1dc48f90d97b290e1506c3b4eb478cb75ce3e327 (diff) | |
| download | mailman-f0e2b8b42c47c1447d5677e1e77f38b0d409c652.tar.gz mailman-f0e2b8b42c47c1447d5677e1e77f38b0d409c652.tar.zst mailman-f0e2b8b42c47c1447d5677e1e77f38b0d409c652.zip | |
Diffstat (limited to 'src')
| -rw-r--r-- | src/mailman/rules/tests/test_moderation.py | 78 |
1 files changed, 77 insertions, 1 deletions
diff --git a/src/mailman/rules/tests/test_moderation.py b/src/mailman/rules/tests/test_moderation.py index 05bae5e1b..3ff18cd2e 100644 --- a/src/mailman/rules/tests/test_moderation.py +++ b/src/mailman/rules/tests/test_moderation.py @@ -21,10 +21,12 @@ import unittest from mailman.app.lifecycle import create_list from mailman.interfaces.action import Action +from mailman.interfaces.bans import IBanManager from mailman.interfaces.member import MemberRole from mailman.interfaces.usermanager import IUserManager from mailman.rules import moderation -from mailman.testing.helpers import specialized_message_from_string as mfs +from mailman.testing.helpers import ( + set_preferred, specialized_message_from_string as mfs) from mailman.testing.layers import ConfigLayer from zope.component import getUtility @@ -207,3 +209,77 @@ A message body. result = rule.check(self._mlist, msg, msgdata) self.assertTrue(result) self.assertEqual(msgdata.get('moderation_action'), 'hold') + + def test_linked_address_nonmembermoderation(self): + self._mlist.default_member_action = Action.accept + self._mlist.default_nonmember_action = Action.hold + user_manager = getUtility(IUserManager) + kane = user_manager.create_user('kane@example.com') + set_preferred(kane) + self._mlist.subscribe(kane, MemberRole.member) + kane.link(user_manager.create_address('kane2@example.com')) + rule = moderation.NonmemberModeration() + msg = mfs("""\ +From: kane2@example.com +To: test@example.com +Subject: A test message +Message-ID: <ant> +MIME-Version: 1.0 + +A message body. +""") + # The NonmemberModeration rule should evaluate + # to False since the linked user is subscribed to the list + msgdata = {} + result = rule.check(self._mlist, msg, msgdata) + self.assertFalse(result) + + def test_linked_address_membermoderation(self): + self._mlist.default_member_action = Action.accept + self._mlist.default_nonmember_action = Action.hold + user_manager = getUtility(IUserManager) + kane = user_manager.create_user('kane@example.com') + set_preferred(kane) + self._mlist.subscribe(kane, MemberRole.member) + kane.link(user_manager.create_address('kane2@example.com')) + rule = moderation.MemberModeration() + msg = mfs("""\ +From: kane2@example.com +To: test@example.com +Subject: A test message +Message-ID: <ant> +MIME-Version: 1.0 + +A message body. +""") + # The MemberModeration rule should evaluate + # to True since the linked user is subscribed to the list + msgdata = {} + result = rule.check(self._mlist, msg, msgdata) + self.assertTrue(result) + + def test_banned_address_linked_to_user_moderation(self): + self._mlist.default_member_action = Action.accept + self._mlist.default_nonmember_action = Action.hold + user_manager = getUtility(IUserManager) + kane = user_manager.create_user('kane@example.com') + set_preferred(kane) + self._mlist.subscribe(kane, MemberRole.member) + kane.link(user_manager.create_address('kane2@example.com')) + IBanManager(self._mlist).ban('kane2@example.com') + rule = moderation.MemberModeration() + msg = mfs("""\ +From: kane2@example.com +To: test@example.com +Subject: A test message +Message-ID: <ant> +MIME-Version: 1.0 + +A message body. +""") + msgdata = {} + result = rule.check(self._mlist, msg, msgdata) + self.assertFalse(result) + rule = moderation.NonmemberModeration() + result = rule.check(self._mlist, msg, msgdata) + self.assertTrue(result) |
