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

Last change on this file since 3114 was 3114, checked in by kroman0, 13 years ago

Pyflakes and pep8 fixes

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