-
Notifications
You must be signed in to change notification settings - Fork 4
/
test_workflow_subscriber.py
51 lines (40 loc) · 2.2 KB
/
test_workflow_subscriber.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# -*- coding: utf-8 -*-
"""Tests for workflow subscriber."""
from collective.fingerpointing.config import PROJECTNAME
from collective.fingerpointing.interfaces import IFingerPointingSettings
from collective.fingerpointing.testing import INTEGRATION_TESTING
from logging import INFO
from plone import api
from plone.app.testing import setRoles
from plone.app.testing import TEST_USER_ID
from testfixtures import LogCapture
import unittest
class WorkflowSubscribersTestCase(unittest.TestCase):
"""Tests content type life cycle subscribers."""
layer = INTEGRATION_TESTING
def setUp(self):
self.portal = self.layer['portal']
setRoles(self.portal, TEST_USER_ID, ['Manager'])
# disable lifecycle audit
record = IFingerPointingSettings.__identifier__ + '.audit_lifecycle'
api.portal.set_registry_record(record, False)
def test_workflow_transitions(self):
expected = (
('collective.fingerpointing', 'INFO', u'user=test ip=127.0.0.1 action=workflow transition object=<NewsItem at foo> transition=submit'),
('collective.fingerpointing', 'INFO', u'user=test ip=127.0.0.1 action=workflow transition object=<NewsItem at foo> transition=publish'),
('collective.fingerpointing', 'INFO', u'user=test ip=127.0.0.1 action=workflow transition object=<NewsItem at foo> transition=retract'),
)
with LogCapture('collective.fingerpointing', level=INFO) as log:
obj = api.content.create(self.portal, 'News Item', 'foo')
api.content.transition(obj=obj, transition='submit')
api.content.transition(obj=obj, transition='publish')
api.content.transition(obj=obj, transition='retract')
log.check(*expected)
def test_susbcriber_ignored_when_package_not_installed(self):
# events should not raise errors if package is not installed
qi = self.portal['portal_quickinstaller']
qi.uninstallProducts(products=[PROJECTNAME])
obj = api.content.create(self.portal, 'News Item', 'foo')
api.content.transition(obj=obj, transition='submit')
api.content.transition(obj=obj, transition='publish')
api.content.transition(obj=obj, transition='retract')