source: products/qPloneComments/tags/3.0.0/tests/testQPloneCommentsConfiglet.py @ 1591

Last change on this file since 1591 was 1, checked in by myroslav, 18 years ago

Building directory structure

  • Property svn:eol-style set to native
File size: 8.7 KB
Line 
1#
2# Test configuration form working
3#
4
5import os, sys, string
6if __name__ == '__main__':
7    execfile(os.path.join(sys.path[0], 'framework.py'))
8
9from Products.PloneTestCase import PloneTestCase
10from Products.CMFCore.utils import getToolByName
11try:
12    from Products.CMFCore.permissions import ManagePortal, ReplyToItem
13except ImportError:
14    from Products.CMFCore.CMFCorePermissions import ManagePortal,ReplyToItem
15from Products.MailHost.MailHost import MailBase
16from AccessControl.SecurityManagement import noSecurityManager
17
18PRODUCT = 'qPloneComments'
19PROPERTY_SHEET = "qPloneComments"
20
21USERS = {# Common Members
22         'admin':{'passw': 'secret_admin', 'roles': ['Manager']},
23         'owner':{'passw': 'secret_owner', 'roles': ['Owner']},
24         'member':{'passw': 'secret_member', 'roles': ['Member']},
25         'reviewer':{'passw': 'secret_reviewer', 'roles': ['Reviewer']},
26         # Members for discussion manager group
27         'dm_admin':{'passw': 'secret_dm_admin', 'roles': ['Manager']},
28         'dm_owner':{'passw': 'secret_dm_owner', 'roles': ['Owner']},
29         'dm_member':{'passw': 'secret_dm_member', 'roles': ['Member']},
30         'dm_reviewer':{'passw': 'secret_dm_reviewer', 'roles': ['Reviewer']},
31        }
32COMMON_USERS_IDS = [u for u in USERS.keys() if not u.startswith('dm_')]
33COMMON_USERS_IDS.append('anonym')
34DM_USERS_IDS = [u for u in USERS.keys() if u.startswith('dm_')]
35
36PloneTestCase.installProduct(PRODUCT)
37PloneTestCase.setupPloneSite()
38
39
40def addUsers(self):
41    self.loginAsPortalOwner()
42    # Add all users
43    self.membership = getToolByName(self.portal, 'portal_membership', None)
44    for user_id in USERS.keys():
45        self.membership.addMember(user_id, USERS[user_id]['passw'] , USERS[user_id]['roles'], [])
46   
47    # Add users to Discussion Manager group
48    portal_groups = getToolByName(self.portal, 'portal_groups')
49    dm_group = portal_groups.getGroupById('DiscussionManager')
50    dm_users = [dm_group.addMember(u) for u in DM_USERS_IDS]
51
52
53class TestConfiglet(PloneTestCase.FunctionalTestCase):
54
55    def afterSetUp(self):
56        self.loginAsPortalOwner()
57
58        self.qi = self.portal.portal_quickinstaller
59        self.qi.installProduct(PRODUCT)
60        # VERY IMPORTANT to guarantee product skin's content visibility
61        self._refreshSkinData()
62
63        '''Preparation for functional testing'''
64        # Allow discussion for Document
65        portal_types = getToolByName(self.portal, 'portal_types', None)
66        doc_fti = portal_types.getTypeInfo('Document')
67        doc_fti._updateProperty('allow_discussion', 1)
68       
69        # Make sure Documents are visible by default
70        # XXX only do this for plone 3
71        self.portal.portal_workflow.setChainForPortalTypes(('Document',), 'plone_workflow')
72
73        portal_properties = getToolByName(self.portal, 'portal_properties', None)
74        self.prefs = portal_properties[PROPERTY_SHEET]
75        self.request = self.app.REQUEST
76
77        # Add Manager user - 'dm' and add him to Discussion Manager group
78        self.portal.portal_membership.addMember('dm', 'secret' , ['Manager'], [])
79        portal_groups = getToolByName(self.portal, 'portal_groups')
80        dm_group = portal_groups.getGroupById('DiscussionManager')
81        dm_group.addMember('dm')
82        #self.logout()
83        self.login('dm')
84        # For prepare mail sending - enter an e-mail adress
85        self.prefs._updateProperty('email_discussion_manager', 'discussion.manager@test.com')
86        member = self.portal.portal_membership.getAuthenticatedMember()
87        member.setMemberProperties({'email':'creator@test.com'})
88        #self.fail(member.getMemberId()+' :: '+member.getUserName()+' :: '+str(member.getRoles())+' :: '+member.getProperty('email'))
89       
90        # Add testing document to portal
91        my_doc = self.portal.invokeFactory('Document', id='my_doc')
92        self.my_doc = self.portal['my_doc']
93        self.my_doc.edit(text_format='plain', text='hello world')
94
95
96    def testAnonymousCommenting(self):
97        getPortalReplyPerm = self.portal.rolesOfPermission
98        def getReplyRoles():
99            return [r['name'] for r in getPortalReplyPerm(ReplyToItem) if r['selected']=='SELECTED']
100        # Simulate switching ON Anonymous Commenting
101        self.request.form['enable_anonymous_commenting'] = 'True'
102        self.portal.prefs_comments_setup()
103        actual_reply_permission = getReplyRoles()
104        self.assert_('Anonymous' in actual_reply_permission, \
105                     "'Reply to Item' permission set for %s. 'Anonymous' role NOT added" %  actual_reply_permission)
106        # Simulate switching OFF Anonymous Commenting
107        if self.request.form.has_key('enable_anonymous_commenting'):
108           del self.request.form['enable_anonymous_commenting']
109        self.portal.prefs_comments_setup()
110        actual_reply_permission = getReplyRoles()
111        self.assert_(not 'Anonymous' in actual_reply_permission, \
112                     "'Reply to Item' permission set for %s. 'Anonymous' role NOT erased" %  actual_reply_permission)
113
114
115    def testSwitchONModeration(self):
116        addUsers(self)
117        self.discussion = self.portal.portal_discussion
118        self.request.form['enable_anonymous_commenting'] = 'True'
119        self.request.form['enable_moderation'] = 'True'
120        self.portal.prefs_comments_setup()
121        # Create talkback for document and Add comment to my_doc
122        self.discussion.getDiscussionFor(self.my_doc)
123        self.my_doc.discussion_reply('Reply 1','text of reply')
124        # Check moderating discussion
125        # MUST ALLOW for: members of 'DiscussionMnagers' group
126        # MUST REFUSE for: NOT members of 'DiscussionMnagers' group
127        getReplies = self.discussion.getDiscussionFor(self.my_doc).getReplies
128        for u in DM_USERS_IDS:
129            self.logout()
130            self.login(u)
131            self.assert_(getReplies(), "None discussion item added or discussion forbiden for %s user" % u)
132        for u in COMMON_USERS_IDS:
133            self.logout()
134            if not u=='anonym':
135                self.login(u)
136            noSecurityManager()
137            self.assert_(not getReplies(), "Viewing discussion item allow for Anonymous user")
138
139
140    def testSwitchOFFModeration(self):
141        addUsers(self)
142        self.discussion = self.portal.portal_discussion
143        self.request.form['enable_anonymous_commenting'] = 'True'
144        self.portal.prefs_comments_setup()
145        # Create talkback for document and Add comment to my_doc
146        self.discussion.getDiscussionFor(self.my_doc)
147        self.request.form['Creator'] = self.portal.portal_membership.getAuthenticatedMember().getUserName()
148        self.request.form['subject'] = "Reply 1"
149        self.request.form['body_text'] = "text of reply"
150        self.my_doc.discussion_reply('Reply 1','text of reply')
151        # Check moderating discussion
152        # MUST ALLOW for: user with any role or Anonym
153        all_users_ids = DM_USERS_IDS + COMMON_USERS_IDS
154        for u in all_users_ids:
155            self.logout()
156            if not u=='anonym':
157                self.login(u)
158            replies = self.discussion.getDiscussionFor(self.my_doc).getReplies()
159            self.assert_(replies, "No discussion item added or discussion forbidden for %s user" % u)
160
161
162    def testApproveNotification(self):
163        # Check ON Notification Anonymous Commenting
164        self.request.form['enable_approve_notification'] = 'True'
165        self.portal.prefs_comments_setup()
166        self.assert_(self.prefs.getProperty('enable_approve_notification')==1,"Approve Notification not terned ON")
167
168        # Check OFF Notification Anonymous Commenting
169        if self.request.form.has_key('enable_approve_notification'):
170           del self.request.form['enable_approve_notification']
171        self.portal.prefs_comments_setup()
172        self.assert_(self.prefs.getProperty('enable_approve_notification')==0,"Approve Notification not terned OFF")
173
174
175    def testPublishedNotification(self):
176        # Check ON Notification Anonymous Commenting
177        self.request.form['enable_published_notification'] = 'True'
178        self.portal.prefs_comments_setup()
179        self.assert_(self.prefs.getProperty('enable_published_notification')==1,"Published Notification not terned ON")
180
181        # Check OFF Notification Anonymous Commenting
182        if self.request.form.has_key('enable_published_notification'):
183           del self.request.form['enable_published_notification']
184        self.portal.prefs_comments_setup()
185        self.assert_(self.prefs.getProperty('enable_published_notification')==0,"Published Notification not terned OFF")
186
187
188
189TESTS = [TestConfiglet]
190
191def test_suite():
192    from unittest import TestSuite, makeSuite
193    suite = TestSuite()
194    suite.addTest(makeSuite(TestConfiglet))
195    return suite
196
197if __name__ == '__main__':
198    framework()
199
Note: See TracBrowser for help on using the repository browser.