source: products/quintagroup.plonecomments/trunk/quintagroup/plonecomments/tests/testQPloneCommentsConfiglet.py @ 1222

Last change on this file since 1222 was 880, checked in by mylan, 17 years ago

Up version.

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