2010-12-10 09:57:35 +01:00
|
|
|
"""Test plone.app.discussion workflow and permissions.
|
|
|
|
"""
|
2022-05-02 00:39:34 +02:00
|
|
|
from ..interfaces import IConversation
|
|
|
|
from ..interfaces import IDiscussionLayer
|
|
|
|
from ..testing import PLONE_APP_DISCUSSION_INTEGRATION_TESTING
|
2009-10-17 15:50:55 +02:00
|
|
|
from AccessControl import Unauthorized
|
2015-05-03 08:16:39 +02:00
|
|
|
from plone.app.testing import login
|
|
|
|
from plone.app.testing import logout
|
|
|
|
from plone.app.testing import setRoles
|
|
|
|
from plone.app.testing import TEST_USER_ID
|
2017-01-10 18:09:01 +01:00
|
|
|
from plone.app.testing import TEST_USER_NAME
|
2016-02-05 01:39:53 +01:00
|
|
|
from Products.CMFCore.permissions import View
|
|
|
|
from Products.CMFCore.utils import _checkPermission as checkPerm
|
2015-05-03 08:16:39 +02:00
|
|
|
from zope.component import createObject
|
|
|
|
from zope.interface import alsoProvides
|
2010-09-24 15:33:21 +02:00
|
|
|
|
2017-05-08 09:24:38 +02:00
|
|
|
import unittest
|
2009-06-08 23:16:51 +02:00
|
|
|
|
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
class WorkflowSetupTest(unittest.TestCase):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Make sure the workflows are set up properly."""
|
2009-06-08 23:16:51 +02:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
layer = PLONE_APP_DISCUSSION_INTEGRATION_TESTING
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
def setUp(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal = self.layer["portal"]
|
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Manager"])
|
|
|
|
self.portal.invokeFactory("Folder", "test-folder")
|
|
|
|
self.folder = self.portal["test-folder"]
|
|
|
|
self.portal.portal_types["Document"].allow_discussion = True
|
|
|
|
self.folder.invokeFactory("Document", "doc1")
|
2010-09-24 15:33:21 +02:00
|
|
|
self.doc = self.folder.doc1
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
def test_workflows_installed(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Make sure both comment workflows have been installed properly."""
|
|
|
|
self.assertTrue(
|
|
|
|
"comment_one_state_workflow" in self.portal.portal_workflow.objectIds()
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
"comment_review_workflow" in self.portal.portal_workflow.objectIds()
|
|
|
|
)
|
2009-06-10 22:17:36 +02:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
def test_default_workflow(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Make sure one_state_workflow is the default workflow."""
|
2013-04-17 14:24:39 +02:00
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
("comment_one_state_workflow",),
|
2013-04-17 14:24:39 +02:00
|
|
|
self.portal.portal_workflow.getChainForPortalType(
|
2022-05-01 23:14:09 +02:00
|
|
|
"Discussion Item",
|
2018-06-18 17:04:41 +02:00
|
|
|
),
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
def test_review_comments_permission(self):
|
2015-05-13 14:03:11 +02:00
|
|
|
# 'Review comments' in self.portal.permissionsOfRole('Admin')
|
2009-06-10 22:17:36 +02:00
|
|
|
|
2022-05-01 23:14:09 +02:00
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Reviewer"])
|
|
|
|
self.assertTrue(
|
|
|
|
self.portal.portal_membership.checkPermission(
|
|
|
|
"Review comments", self.folder
|
|
|
|
),
|
|
|
|
self.folder,
|
|
|
|
)
|
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Member"])
|
2013-04-17 14:24:39 +02:00
|
|
|
self.assertFalse(
|
|
|
|
self.portal.portal_membership.checkPermission(
|
2022-05-01 23:14:09 +02:00
|
|
|
"Review comments",
|
2018-06-18 17:04:41 +02:00
|
|
|
self.folder,
|
2013-04-17 14:24:39 +02:00
|
|
|
),
|
2018-06-18 17:04:41 +02:00
|
|
|
self.folder,
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
2009-06-08 23:16:51 +02:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
def test_reply_to_item_permission(self):
|
|
|
|
pass
|
2009-06-08 23:16:51 +02:00
|
|
|
|
2012-01-14 07:35:59 +01:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
class PermissionsSetupTest(unittest.TestCase):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Make sure the permissions are set up properly."""
|
2010-12-10 09:57:35 +01:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
layer = PLONE_APP_DISCUSSION_INTEGRATION_TESTING
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
def setUp(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal = self.layer["portal"]
|
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Manager"])
|
2010-12-10 09:57:35 +01:00
|
|
|
mtool = self.portal.portal_membership
|
|
|
|
self.checkPermission = mtool.checkPermission
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2010-12-10 09:57:35 +01:00
|
|
|
def test_reply_to_item_permission_assigned(self):
|
|
|
|
"""Make sure the 'Reply to item' permission is properly assigned.
|
2022-05-01 23:14:09 +02:00
|
|
|
By default this permission is assigned to 'Member' and 'Manager'.
|
|
|
|
plone.app.discussion assigns this permission to 'Authenticated' as
|
|
|
|
well to emulate the behavior of the old commenting system.
|
2010-12-10 09:57:35 +01:00
|
|
|
"""
|
2022-05-01 23:14:09 +02:00
|
|
|
ReplyToItemPerm = "Reply to item"
|
2010-12-10 09:57:35 +01:00
|
|
|
# should be allowed as Member
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(self.checkPermission(ReplyToItemPerm, self.portal))
|
2010-12-10 09:57:35 +01:00
|
|
|
# should be allowed as Authenticated
|
2022-05-01 23:14:09 +02:00
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Authenticated"])
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(self.checkPermission(ReplyToItemPerm, self.portal))
|
2010-12-10 09:57:35 +01:00
|
|
|
# should be allowed as Manager
|
2022-05-01 23:14:09 +02:00
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Manager"])
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(self.checkPermission(ReplyToItemPerm, self.portal))
|
2010-12-10 09:57:35 +01:00
|
|
|
# should not be allowed as anonymous
|
2011-04-16 11:29:15 +02:00
|
|
|
logout()
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertFalse(self.checkPermission(ReplyToItemPerm, self.portal))
|
2010-12-10 09:57:35 +01:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
class CommentOneStateWorkflowTest(unittest.TestCase):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Test the comment_one_state_workflow that ships with plone.app.discussion."""
|
2009-06-18 22:57:47 +02:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
layer = PLONE_APP_DISCUSSION_INTEGRATION_TESTING
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
def setUp(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal = self.layer["portal"]
|
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Manager"])
|
|
|
|
self.portal.invokeFactory("Folder", "test-folder")
|
|
|
|
self.folder = self.portal["test-folder"]
|
2010-09-24 15:33:21 +02:00
|
|
|
self.catalog = self.portal.portal_catalog
|
|
|
|
self.workflow = self.portal.portal_workflow
|
2022-05-01 23:14:09 +02:00
|
|
|
self.folder.invokeFactory("Document", "doc1")
|
2010-09-24 15:33:21 +02:00
|
|
|
self.doc = self.folder.doc1
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
# Add a comment
|
|
|
|
conversation = IConversation(self.folder.doc1)
|
2022-05-01 23:14:09 +02:00
|
|
|
comment = createObject("plone.Comment")
|
|
|
|
comment.text = "Comment text"
|
2010-09-24 15:33:21 +02:00
|
|
|
cid = conversation.addComment(comment)
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2013-04-17 14:24:39 +02:00
|
|
|
self.comment = self.folder.doc1.restrictedTraverse(
|
2022-05-01 23:14:41 +02:00
|
|
|
f"++conversation++default/{cid}",
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.acl_users._doAddUser("member", "secret", ["Member"], [])
|
|
|
|
self.portal.acl_users._doAddUser("reviewer", "secret", ["Reviewer"], [])
|
|
|
|
self.portal.acl_users._doAddUser("manager", "secret", ["Manager"], [])
|
|
|
|
self.portal.acl_users._doAddUser("editor", " secret", ["Editor"], [])
|
|
|
|
self.portal.acl_users._doAddUser("reader", "secret", ["Reader"], [])
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
def test_initial_workflow_state(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Make sure the initial workflow state of a comment is 'private'."""
|
2018-06-18 17:04:41 +02:00
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
self.workflow.getInfoFor(self.doc, "review_state"),
|
|
|
|
"private",
|
2018-06-18 17:04:41 +02:00
|
|
|
)
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
def test_view_comments(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Make sure published comments can be viewed by everyone."""
|
2010-09-24 15:33:21 +02:00
|
|
|
# Owner is allowed
|
2015-05-13 14:03:11 +02:00
|
|
|
# self.login(default_user)
|
|
|
|
# self.assertTrue(checkPerm(View, self.doc))
|
2010-09-24 15:33:21 +02:00
|
|
|
# Member is allowed
|
2017-01-10 18:09:01 +01:00
|
|
|
login(self.portal, TEST_USER_NAME)
|
|
|
|
workflow = self.portal.portal_workflow
|
2022-05-01 23:14:09 +02:00
|
|
|
workflow.doActionFor(self.doc, "publish")
|
2017-01-10 18:09:01 +01:00
|
|
|
|
2022-05-01 23:14:09 +02:00
|
|
|
login(self.portal, "member")
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
2010-09-24 15:33:21 +02:00
|
|
|
# Reviewer is allowed
|
2022-05-01 23:14:09 +02:00
|
|
|
login(self.portal, "reviewer")
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
2010-09-24 15:33:21 +02:00
|
|
|
# Anonymous is allowed
|
2011-04-16 11:29:15 +02:00
|
|
|
logout()
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
2010-09-24 15:33:21 +02:00
|
|
|
# Editor is allowed
|
2022-05-01 23:14:09 +02:00
|
|
|
login(self.portal, "editor")
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
2010-09-24 15:33:21 +02:00
|
|
|
# Reader is allowed
|
2022-05-01 23:14:09 +02:00
|
|
|
login(self.portal, "reader")
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
2010-12-16 00:52:56 +01:00
|
|
|
|
2017-01-10 18:09:01 +01:00
|
|
|
def test_comment_on_private_content_not_visible_to_world(self):
|
|
|
|
logout()
|
|
|
|
self.assertFalse(checkPerm(View, self.comment))
|
|
|
|
|
|
|
|
def test_migration(self):
|
|
|
|
from plone.app.discussion.upgrades import upgrade_comment_workflows
|
2022-05-01 23:14:00 +02:00
|
|
|
|
2017-01-10 18:09:01 +01:00
|
|
|
# Fake permission according to earlier one_comment_workflow.
|
2022-05-01 23:14:09 +02:00
|
|
|
self.comment._View_Permission = ("Anonymous",)
|
2017-01-10 18:09:01 +01:00
|
|
|
# Anonymous can see the comment.
|
|
|
|
logout()
|
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
|
|
|
# Run the upgrade.
|
|
|
|
login(self.portal, TEST_USER_NAME)
|
|
|
|
upgrade_comment_workflows(self.portal.portal_setup)
|
|
|
|
# The workflow chain is still what we want.
|
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.portal_workflow.getChainFor("Discussion Item"),
|
|
|
|
("comment_one_state_workflow",),
|
2018-06-18 17:04:41 +02:00
|
|
|
)
|
2017-01-10 18:09:01 +01:00
|
|
|
# A Manager can still see the comment.
|
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
|
|
|
# Anonymous cannot see the comment.
|
|
|
|
logout()
|
|
|
|
self.assertFalse(checkPerm(View, self.comment))
|
|
|
|
|
2010-09-24 15:33:21 +02:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
class CommentReviewWorkflowTest(unittest.TestCase):
|
2022-05-01 23:14:09 +02:00
|
|
|
"""Test the comment_review_workflow that ships with plone.app.discussion."""
|
2009-06-18 22:57:47 +02:00
|
|
|
|
2011-04-16 11:29:15 +02:00
|
|
|
layer = PLONE_APP_DISCUSSION_INTEGRATION_TESTING
|
|
|
|
|
|
|
|
def setUp(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal = self.layer["portal"]
|
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Manager"])
|
|
|
|
self.portal.invokeFactory("Folder", "test-folder")
|
|
|
|
self.folder = self.portal["test-folder"]
|
2009-06-18 22:57:47 +02:00
|
|
|
|
|
|
|
# Allow discussion on the Document content type
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.portal_types["Document"].allow_discussion = True
|
2009-06-18 22:57:47 +02:00
|
|
|
# Set workflow for Discussion item to review workflow
|
2010-08-28 19:06:53 +02:00
|
|
|
self.portal.portal_workflow.setChainForPortalTypes(
|
2022-05-01 23:14:09 +02:00
|
|
|
("Discussion Item",),
|
|
|
|
("comment_review_workflow",),
|
2018-06-18 17:04:41 +02:00
|
|
|
)
|
2009-06-18 22:57:47 +02:00
|
|
|
|
|
|
|
# Create a conversation for this Document
|
|
|
|
conversation = IConversation(self.portal.doc1)
|
|
|
|
|
|
|
|
# Add a comment.
|
2022-05-01 23:14:09 +02:00
|
|
|
comment = createObject("plone.Comment")
|
|
|
|
comment.text = "Comment text"
|
2009-06-18 22:57:47 +02:00
|
|
|
comment_id = conversation.addComment(comment)
|
2010-08-28 19:06:53 +02:00
|
|
|
comment = self.portal.doc1.restrictedTraverse(
|
2022-05-01 23:14:41 +02:00
|
|
|
f"++conversation++default/{comment_id}",
|
2016-02-05 01:39:53 +01:00
|
|
|
)
|
2009-06-18 22:57:47 +02:00
|
|
|
|
|
|
|
self.conversation = conversation
|
|
|
|
self.comment_id = comment_id
|
|
|
|
self.comment = comment
|
|
|
|
|
2022-05-01 23:14:09 +02:00
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Reviewer"])
|
2009-06-18 22:57:47 +02:00
|
|
|
alsoProvides(self.portal.REQUEST, IDiscussionLayer)
|
|
|
|
|
|
|
|
def test_delete(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.REQUEST.form["comment_id"] = self.comment_id
|
|
|
|
view = self.comment.restrictedTraverse("@@moderate-delete-comment")
|
2009-10-17 15:50:55 +02:00
|
|
|
view()
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertFalse(self.comment_id in self.conversation.objectIds())
|
2009-10-17 15:50:55 +02:00
|
|
|
|
|
|
|
def test_delete_as_anonymous(self):
|
|
|
|
# Make sure that anonymous users can not delete comments
|
2011-04-16 11:29:15 +02:00
|
|
|
logout()
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.REQUEST.form["comment_id"] = self.comment_id
|
2018-06-18 17:04:41 +02:00
|
|
|
self.assertRaises(
|
|
|
|
Unauthorized,
|
|
|
|
self.comment.restrictedTraverse,
|
2022-05-01 23:14:09 +02:00
|
|
|
"@@moderate-delete-comment",
|
2018-06-18 17:04:41 +02:00
|
|
|
)
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(self.comment_id in self.conversation.objectIds())
|
2009-10-17 15:50:55 +02:00
|
|
|
|
|
|
|
def test_delete_as_user(self):
|
|
|
|
# Make sure that members can not delete comments
|
2011-04-16 11:29:15 +02:00
|
|
|
logout()
|
2022-05-01 23:14:09 +02:00
|
|
|
setRoles(self.portal, TEST_USER_ID, ["Member"])
|
|
|
|
self.portal.REQUEST.form["comment_id"] = self.comment_id
|
2018-06-18 17:04:41 +02:00
|
|
|
self.assertRaises(
|
|
|
|
Unauthorized,
|
|
|
|
self.comment.restrictedTraverse,
|
2022-05-01 23:14:09 +02:00
|
|
|
"@@moderate-delete-comment",
|
2018-06-18 17:04:41 +02:00
|
|
|
)
|
2011-04-15 18:23:38 +02:00
|
|
|
self.assertTrue(self.comment_id in self.conversation.objectIds())
|
2009-06-18 22:57:47 +02:00
|
|
|
|
|
|
|
def test_publish(self):
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.REQUEST.form["comment_id"] = self.comment_id
|
|
|
|
self.portal.REQUEST.form["workflow_action"] = "publish"
|
2013-04-17 14:24:39 +02:00
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
"pending",
|
2013-04-17 14:24:39 +02:00
|
|
|
self.portal.portal_workflow.getInfoFor(
|
|
|
|
self.comment,
|
2022-05-01 23:14:09 +02:00
|
|
|
"review_state",
|
2018-06-18 17:04:41 +02:00
|
|
|
),
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
2022-05-01 23:14:09 +02:00
|
|
|
view = self.comment.restrictedTraverse("@@transmit-comment")
|
2009-10-17 15:50:55 +02:00
|
|
|
view()
|
2013-04-17 14:24:39 +02:00
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
"published",
|
2013-04-17 14:24:39 +02:00
|
|
|
self.portal.portal_workflow.getInfoFor(
|
|
|
|
self.comment,
|
2022-05-01 23:14:09 +02:00
|
|
|
"review_state",
|
2018-06-18 17:04:41 +02:00
|
|
|
),
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
2009-10-17 15:50:55 +02:00
|
|
|
|
|
|
|
def test_publish_as_anonymous(self):
|
2011-04-16 11:29:15 +02:00
|
|
|
logout()
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.REQUEST.form["comment_id"] = self.comment_id
|
|
|
|
self.portal.REQUEST.form["workflow_action"] = "publish"
|
2013-04-17 14:24:39 +02:00
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
"pending",
|
|
|
|
self.portal.portal_workflow.getInfoFor(
|
2013-04-17 14:24:39 +02:00
|
|
|
self.comment,
|
2022-05-01 23:14:09 +02:00
|
|
|
"review_state",
|
2018-06-18 17:04:41 +02:00
|
|
|
),
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
|
|
|
self.assertRaises(
|
|
|
|
Unauthorized,
|
|
|
|
self.comment.restrictedTraverse,
|
2022-05-01 23:14:09 +02:00
|
|
|
"@@transmit-comment",
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
"pending",
|
2013-04-17 14:24:39 +02:00
|
|
|
self.portal.portal_workflow.getInfoFor(
|
|
|
|
self.comment,
|
2022-05-01 23:14:09 +02:00
|
|
|
"review_state",
|
2018-06-18 17:04:41 +02:00
|
|
|
),
|
2013-04-17 14:24:39 +02:00
|
|
|
)
|
2017-01-10 18:09:01 +01:00
|
|
|
|
|
|
|
def test_publish_comment_on_private_content_not_visible_to_world(self):
|
|
|
|
logout()
|
|
|
|
self.assertFalse(checkPerm(View, self.comment))
|
|
|
|
|
|
|
|
# publish comment and check again
|
|
|
|
login(self.portal, TEST_USER_NAME)
|
|
|
|
workflow = self.portal.portal_workflow
|
2022-05-01 23:14:09 +02:00
|
|
|
workflow.doActionFor(self.comment, "publish")
|
2017-01-10 18:09:01 +01:00
|
|
|
|
|
|
|
logout()
|
|
|
|
self.assertFalse(checkPerm(View, self.comment))
|
|
|
|
|
|
|
|
def test_migration(self):
|
|
|
|
from plone.app.discussion.upgrades import upgrade_comment_workflows
|
2022-05-01 23:14:00 +02:00
|
|
|
|
2017-01-10 18:09:01 +01:00
|
|
|
# Fake permission according to earlier comment_review_workflow.
|
2022-05-01 23:14:09 +02:00
|
|
|
self.comment._View_Permission = ("Anonymous",)
|
2017-01-10 18:09:01 +01:00
|
|
|
# Anonymous can see the comment.
|
|
|
|
logout()
|
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
|
|
|
# Run the upgrade.
|
|
|
|
login(self.portal, TEST_USER_NAME)
|
|
|
|
upgrade_comment_workflows(self.portal.portal_setup)
|
|
|
|
# The workflow chain is still what we want.
|
|
|
|
self.assertEqual(
|
2022-05-01 23:14:09 +02:00
|
|
|
self.portal.portal_workflow.getChainFor("Discussion Item"),
|
|
|
|
("comment_review_workflow",),
|
|
|
|
)
|
2017-01-10 18:09:01 +01:00
|
|
|
# A Manager can still see the comment.
|
|
|
|
self.assertTrue(checkPerm(View, self.comment))
|
|
|
|
# Anonymous cannot see the comment.
|
|
|
|
logout()
|
|
|
|
self.assertFalse(checkPerm(View, self.comment))
|