diff options
| author | Barry Warsaw | 2016-01-07 18:33:01 -0500 |
|---|---|---|
| committer | Barry Warsaw | 2016-01-07 18:33:01 -0500 |
| commit | 433ce1580295a410ebe83b731e54672c13e04e15 (patch) | |
| tree | 2474a30749d66260cad28945210ee778f32436ce /src/mailman/model/tests | |
| parent | 4f549f8655857aef64ed8c92c3339c32f5e942db (diff) | |
| download | mailman-433ce1580295a410ebe83b731e54672c13e04e15.tar.gz mailman-433ce1580295a410ebe83b731e54672c13e04e15.tar.zst mailman-433ce1580295a410ebe83b731e54672c13e04e15.zip | |
Refactor some tests and documentation.
Increase coverage.
Add ISubscriptionService.find_member() as per discussion.
Diffstat (limited to 'src/mailman/model/tests')
| -rw-r--r-- | src/mailman/model/tests/test_subscriptions.py | 260 |
1 files changed, 260 insertions, 0 deletions
diff --git a/src/mailman/model/tests/test_subscriptions.py b/src/mailman/model/tests/test_subscriptions.py new file mode 100644 index 000000000..3e97bd427 --- /dev/null +++ b/src/mailman/model/tests/test_subscriptions.py @@ -0,0 +1,260 @@ +# Copyright (C) 2016 by the Free Software Foundation, Inc. +# +# This file is part of GNU Mailman. +# +# GNU Mailman is free software: you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free +# Software Foundation, either version 3 of the License, or (at your option) +# any later version. +# +# GNU Mailman is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for +# more details. +# +# You should have received a copy of the GNU General Public License along with +# GNU Mailman. If not, see <http://www.gnu.org/licenses/>. + +"""Test the subscription service.""" + +__all__ = [ + 'TestSubscriptionService', + ] + + +import unittest + +from mailman.app.lifecycle import create_list +from mailman.interfaces.listmanager import NoSuchListError +from mailman.interfaces.member import MemberRole +from mailman.interfaces.subscriptions import ( + ISubscriptionService, TooManyMembersError) +from mailman.interfaces.usermanager import IUserManager +from mailman.testing.helpers import subscribe +from mailman.testing.layers import ConfigLayer +from mailman.utilities.datetime import now +from zope.component import getUtility + + +class TestSubscriptionService(unittest.TestCase): + layer = ConfigLayer + + def setUp(self): + self._mlist = create_list('test@example.com') + self._mlist.admin_immed_notify = False + self._user_manager = getUtility(IUserManager) + self._service = getUtility(ISubscriptionService) + + def test_find_member_address_no_user(self): + # Find address-based memberships when no user is linked to the address. + address = self._user_manager.create_address( + 'anne@example.com', 'Anne Address') + self._mlist.subscribe(address) + members = self._service.find_members('anne@example.com') + self.assertEqual(len(members), 1) + self.assertEqual(members[0].address, address) + + def test_find_member_address_with_user(self): + # Find address-based memberships when a user is linked to the address. + user = self._user_manager.create_user( + 'anne@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Subscribe the address. + self._mlist.subscribe(address) + members = self._service.find_members('anne@example.com') + self.assertEqual(len(members), 1) + self.assertEqual(members[0].user, user) + + def test_find_member_user(self): + # Find user-based memberships by address. + user = self._user_manager.create_user( + 'anne@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Subscribe the user. + self._mlist.subscribe(user) + members = self._service.find_members('anne@example.com') + self.assertEqual(len(members), 1) + self.assertEqual(members[0].user, user) + + def test_find_member_user_secondary_address(self): + # Find user-based memberships using a secondary address. + user = self._user_manager.create_user( + 'anne@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Create a secondary address. + address_2 = self._user_manager.create_address( + 'anne2@example.com', 'Anne User 2') + address_2.user = user + # Subscribe the user. + self._mlist.subscribe(user) + # Search for the secondary address. + members = self._service.find_members('anne2@example.com') + self.assertEqual(len(members), 1) + self.assertEqual(members[0].user, user) + + def test_wont_find_member_secondary_address(self): + # A user is subscribed with one of their address, and a search is + # performed on another of their addresses. This is not supported; the + # subscription is not returned. + user = self._user_manager.create_user( + 'anne@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Create a secondary address. + address_2 = self._user_manager.create_address( + 'anne2@example.com', 'Anne User 2') + address_2.verified_on = now() + address_2.user = user + # Subscribe the secondary address. + self._mlist.subscribe(address_2) + # Search for the primary address. + members = self._service.find_members('anne@example.com') + self.assertEqual(len(members), 0) + + def test_find_member_user_id(self): + # Find user-based memberships by user_id. + user = self._user_manager.create_user( + 'anne@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Subscribe the user. + self._mlist.subscribe(user) + members = self._service.find_members(user.user_id) + self.assertEqual(len(members), 1) + self.assertEqual(members[0].user, user) + + def test_find_member_user_id_controlled_addresses(self): + # Find address-based memberships by user_id when a secondary address is + # subscribed. + user = self._user_manager.create_user( + 'anne@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Create a secondary address. + address_2 = self._user_manager.create_address( + 'anne2@example.com', 'Anne User 2') + address_2.verified_on = now() + address_2.user = user + # Create a third address. + address_3 = self._user_manager.create_address( + 'anne3@example.com', 'Anne User 3') + address_3.verified_on = now() + address_3.user = user + # Subscribe the secondary address only. + self._mlist.subscribe(address_2) + members = self._service.find_members(user.user_id) + self.assertEqual(len(members), 1) + self.assertEqual(members[0].address, address_2) + + def test_find_member_sorting(self): + # Check that the memberships are properly sorted. + user = self._user_manager.create_user( + 'anne1@example.com', 'Anne User') + address = user.addresses[0] + address.verified_on = now() + user.preferred_address = address + # Create a secondary address. + address_2 = self._user_manager.create_address( + 'anne2@example.com', 'Anne User 2') + address_2.verified_on = now() + address_2.user = user + # Create a third address. + address_3 = self._user_manager.create_address( + 'anne3@example.com', 'Anne User 3') + address_3.verified_on = now() + address_3.user = user + # Create three lists. + mlist1 = create_list('test1@example.com') + mlist1.admin_immed_notify = False + mlist2 = create_list('test2@example.com') + mlist2.admin_immed_notify = False + mlist3 = create_list('test3@example.com') + mlist3.admin_immed_notify = False + # Subscribe the addresses in random order + # https://www.xkcd.com/221/ + mlist3.subscribe(address_3, MemberRole.moderator) + mlist3.subscribe(address_3, MemberRole.owner) + mlist3.subscribe(address_3, MemberRole.member) + mlist3.subscribe(address_2, MemberRole.member) + mlist3.subscribe(address_2, MemberRole.owner) + mlist3.subscribe(address_2, MemberRole.moderator) + mlist3.subscribe(address, MemberRole.owner) + mlist3.subscribe(address, MemberRole.member) + mlist3.subscribe(address, MemberRole.moderator) + mlist2.subscribe(address_2, MemberRole.moderator) + mlist2.subscribe(address_2, MemberRole.member) + mlist2.subscribe(address_2, MemberRole.owner) + mlist2.subscribe(address_3, MemberRole.moderator) + mlist2.subscribe(address_3, MemberRole.member) + mlist2.subscribe(address_3, MemberRole.owner) + mlist2.subscribe(address, MemberRole.owner) + mlist2.subscribe(address, MemberRole.moderator) + mlist2.subscribe(address, MemberRole.member) + mlist1.subscribe(address_2, MemberRole.moderator) + mlist1.subscribe(address, MemberRole.member) + mlist1.subscribe(address_3, MemberRole.owner) + # The results should be sorted first by list id, then by address, then + # by member role. + members = self._service.find_members(user.user_id) + self.assertEqual(len(members), 21) + self.assertListEqual( + [(m.list_id.partition('.')[0], + m.address.email.partition('@')[0], + m.role) + for m in members], + [('test1', 'anne1', MemberRole.member), + ('test1', 'anne2', MemberRole.moderator), + ('test1', 'anne3', MemberRole.owner), + ('test2', 'anne1', MemberRole.member), + ('test2', 'anne1', MemberRole.owner), + ('test2', 'anne1', MemberRole.moderator), + ('test2', 'anne2', MemberRole.member), + ('test2', 'anne2', MemberRole.owner), + ('test2', 'anne2', MemberRole.moderator), + ('test2', 'anne3', MemberRole.member), + ('test2', 'anne3', MemberRole.owner), + ('test2', 'anne3', MemberRole.moderator), + ('test3', 'anne1', MemberRole.member), + ('test3', 'anne1', MemberRole.owner), + ('test3', 'anne1', MemberRole.moderator), + ('test3', 'anne2', MemberRole.member), + ('test3', 'anne2', MemberRole.owner), + ('test3', 'anne2', MemberRole.moderator), + ('test3', 'anne3', MemberRole.member), + ('test3', 'anne3', MemberRole.owner), + ('test3', 'anne3', MemberRole.moderator), + ]) + + def test_find_members_shortcut(self): + members = self._service.find_members() + self.assertEqual(len(members), 0) + + def test_find_members_no_results(self): + members = self._service.find_members('zack@example.com') + self.assertEqual(len(members), 0) + self.assertEqual(list(members), []) + + def test_find_member_error(self): + # .find_member() can only return zero or one memberships. Anything + # else is an error. + subscribe(self._mlist, 'Anne') + subscribe(self._mlist, 'Anne', MemberRole.owner) + with self.assertRaises(TooManyMembersError) as cm: + self._service.find_member('aperson@example.com') + self.assertEqual(cm.exception.subscriber, 'aperson@example.com') + self.assertEqual(cm.exception.list_id, None) + self.assertEqual(cm.exception.role, None) + + def test_leave_no_such_list(self): + # Trying to leave a nonexistent list raises an exception. + self.assertRaises(NoSuchListError, self._service.leave, + 'bogus.example.com', 'anne@example.com') |
