summaryrefslogtreecommitdiff
path: root/src/mailman/rules/tests/test_moderation.py
diff options
context:
space:
mode:
authorAditya2016-04-12 17:49:27 +0530
committerBarry Warsaw2016-05-03 15:49:43 -0400
commitf0e2b8b42c47c1447d5677e1e77f38b0d409c652 (patch)
tree00850761a1f92e08f8699944935e326a9aec3a4b /src/mailman/rules/tests/test_moderation.py
parent1dc48f90d97b290e1506c3b4eb478cb75ce3e327 (diff)
downloadmailman-f0e2b8b42c47c1447d5677e1e77f38b0d409c652.tar.gz
mailman-f0e2b8b42c47c1447d5677e1e77f38b0d409c652.tar.zst
mailman-f0e2b8b42c47c1447d5677e1e77f38b0d409c652.zip
Diffstat (limited to 'src/mailman/rules/tests/test_moderation.py')
-rw-r--r--src/mailman/rules/tests/test_moderation.py78
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)