~abompard/mailman/subpolicy

« back to all changes in this revision

Viewing changes to src/mailman/model/tests/test_domain.py

  • Committer: Barry Warsaw
  • Date: 2015-04-07 02:06:28 UTC
  • mfrom: (7313.2.6 lp1423756)
  • mto: This revision was merged to the branch mainline in revision 7323.
  • Revision ID: barry@list.org-20150407020628-fkwphij7to9lc8gy
 * Domains now have a list of owners, which are ``IUser`` objects, instead of
   the single ``contact_address`` they used to have.  ``IUser`` objects now
   also have a ``is_server_owner`` flag (defaulting to False) to indicate
   whether they have superuser privileges.  Give by Abhliash Raj, with fixes
   and refinements by Barry Warsaw.  (LP: #1423756)

 * Domains can now optionally be created with owners; domain owners can be
   added after the fact; domain owners can be deleted.  Also, users now have
   an ``is_server_owner`` flag as part of their representation, which defaults
   to False, and can be PUT and PATCH'd.  Given by Abhilash Raj, with fixes
   and refinements by Barry Warsaw.  (LP: #1423756)

Show diffs side-by-side

added added

removed removed

Lines of Context:
30
30
    DomainCreatedEvent, DomainCreatingEvent, DomainDeletedEvent,
31
31
    DomainDeletingEvent, IDomainManager)
32
32
from mailman.interfaces.listmanager import IListManager
 
33
from mailman.interfaces.usermanager import IUserManager
33
34
from mailman.testing.helpers import event_subscribers
34
35
from mailman.testing.layers import ConfigLayer
35
36
from zope.component import getUtility
78
79
        # Trying to delete a missing domain gives you a KeyError.
79
80
        self.assertRaises(KeyError, self._manager.remove, 'doesnotexist.com')
80
81
 
 
82
    def test_domain_creation_no_default_owners(self):
 
83
        # If a domain is created without owners, then it has none.
 
84
        domain = self._manager.add('example.org')
 
85
        self.assertEqual(len(domain.owners), 0)
 
86
 
 
87
    def test_domain_creation_with_owner(self):
 
88
        # You can create a new domain with a single owner.
 
89
        domain = self._manager.add('example.org', owners=['anne@example.org'])
 
90
        self.assertEqual(len(domain.owners), 1)
 
91
        self.assertEqual(domain.owners[0].addresses[0].email,
 
92
                         'anne@example.org')
 
93
 
 
94
    def test_domain_creation_with_owners(self):
 
95
        # You can create a new domain with multiple owners.
 
96
        domain = self._manager.add(
 
97
            'example.org', owners=['anne@example.org',
 
98
                                   'bart@example.net'])
 
99
        self.assertEqual(len(domain.owners), 2)
 
100
        self.assertEqual(
 
101
            sorted(owner.addresses[0].email for owner in domain.owners),
 
102
            ['anne@example.org', 'bart@example.net'])
 
103
 
 
104
    def test_domain_creation_creates_new_users(self):
 
105
        # Domain creation with existing users does not create new users, but
 
106
        # any user which doesn't yet exist (and is linked to the given
 
107
        # address), gets created.
 
108
        user_manager = getUtility(IUserManager)
 
109
        user_manager.make_user('anne@example.com')
 
110
        user_manager.make_user('bart@example.com')
 
111
        domain = self._manager.add(
 
112
            'example.org', owners=['anne@example.com',
 
113
                                   'bart@example.com',
 
114
                                   'cris@example.com'])
 
115
        self.assertEqual(len(domain.owners), 3)
 
116
        self.assertEqual(
 
117
            sorted(owner.addresses[0].email for owner in domain.owners),
 
118
            ['anne@example.com', 'bart@example.com', 'cris@example.com'])
 
119
        # Now cris exists as a user.
 
120
        self.assertIsNotNone(user_manager.get_user('cris@example.com'))
 
121
 
 
122
    def test_domain_creation_with_users(self):
 
123
        # Domains can be created with IUser objects.
 
124
        user_manager = getUtility(IUserManager)
 
125
        anne = user_manager.make_user('anne@example.com')
 
126
        bart = user_manager.make_user('bart@example.com')
 
127
        domain = self._manager.add('example.org', owners=[anne, bart])
 
128
        self.assertEqual(len(domain.owners), 2)
 
129
        self.assertEqual(
 
130
            sorted(owner.addresses[0].email for owner in domain.owners),
 
131
            ['anne@example.com', 'bart@example.com'])
 
132
        def sort_key(owner):
 
133
            return owner.addresses[0].email
 
134
        self.assertEqual(sorted(domain.owners, key=sort_key), [anne, bart])
 
135
 
 
136
    def test_add_domain_owner(self):
 
137
        # Domain owners can be added after the domain is created.
 
138
        domain = self._manager.add('example.org')
 
139
        self.assertEqual(len(domain.owners), 0)
 
140
        domain.add_owner('anne@example.org')
 
141
        self.assertEqual(len(domain.owners), 1)
 
142
        self.assertEqual(domain.owners[0].addresses[0].email,
 
143
                         'anne@example.org')
 
144
 
 
145
    def test_add_multiple_domain_owners(self):
 
146
        # Multiple domain owners can be added after the domain is created.
 
147
        domain = self._manager.add('example.org')
 
148
        self.assertEqual(len(domain.owners), 0)
 
149
        domain.add_owners(['anne@example.org', 'bart@example.net'])
 
150
        self.assertEqual(len(domain.owners), 2)
 
151
        self.assertEqual([owner.addresses[0].email for owner in domain.owners],
 
152
                         ['anne@example.org', 'bart@example.net'])
 
153
 
 
154
    def test_remove_domain_owner(self):
 
155
        # Domain onwers can be removed.
 
156
        domain = self._manager.add(
 
157
            'example.org', owners=['anne@example.org',
 
158
                                   'bart@example.net'])
 
159
        domain.remove_owner('anne@example.org')
 
160
        self.assertEqual(len(domain.owners), 1)
 
161
        self.assertEqual([owner.addresses[0].email for owner in domain.owners],
 
162
                         ['bart@example.net'])
 
163
 
 
164
    def test_remove_missing_owner(self):
 
165
        # Users which aren't owners can't be removed.
 
166
        domain = self._manager.add(
 
167
            'example.org', owners=['anne@example.org',
 
168
                                   'bart@example.net'])
 
169
        self.assertRaises(ValueError, domain.remove_owner, 'cris@example.org')
 
170
        self.assertEqual(len(domain.owners), 2)
 
171
        self.assertEqual([owner.addresses[0].email for owner in domain.owners],
 
172
                         ['anne@example.org', 'bart@example.net'])
 
173
 
81
174
 
82
175
 
83
176
class TestDomainLifecycleEvents(unittest.TestCase):