Commit b1f324a8 authored by wenjie.zheng's avatar wenjie.zheng

testWorklist.py: add new workflow compatibility.

parent 287c3ae4
...@@ -26,9 +26,9 @@ ...@@ -26,9 +26,9 @@
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# #
############################################################################## ##############################################################################
import re
import unittest import unittest
from zLOG import LOG, INFO, WARNING
from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase
from Testing.ZopeTestCase.PortalTestCase import PortalTestCase from Testing.ZopeTestCase.PortalTestCase import PortalTestCase
...@@ -156,9 +156,8 @@ class TestWorklist(ERP5TypeTestCase): ...@@ -156,9 +156,8 @@ class TestWorklist(ERP5TypeTestCase):
# add new workflow compatibility # add new workflow compatibility
workflow_value = self.getWorkflowTool()[workflow_id] workflow_value = self.getWorkflowTool()[workflow_id]
if workflow_value.__class__.__name__ == 'Workflow': if workflow_value.__class__.__name__ == 'Workflow':
variable_value = workflow_value.newContent(id='variable_'+variable_id, # Will add dynamic variable in worklist.
portal_type='Variable') pass
variable_value.setReference(variable_id)
else: else:
variables = workflow_value.variables variables = workflow_value.variables
variables.addVariable(variable_id) variables.addVariable(variable_id)
...@@ -168,15 +167,63 @@ class TestWorklist(ERP5TypeTestCase): ...@@ -168,15 +167,63 @@ class TestWorklist(ERP5TypeTestCase):
def createWorklist(self, workflow_id, worklist_id, actbox_name, def createWorklist(self, workflow_id, worklist_id, actbox_name,
actbox_url=None, **kw): actbox_url=None, **kw):
# add new workflow compatibility # add new workflow compatibility
tales_re = re.compile(r'(\w+:)?(.*)')
workflow_value = self.getWorkflowTool()[workflow_id] workflow_value = self.getWorkflowTool()[workflow_id]
if workflow_value.__class__.__name__ == 'Workflow': if workflow_value.__class__.__name__ == 'Workflow':
worklist_value = workflow_value.newContent(portal_type='Worklist') worklist_value = workflow_value.newContent(portal_type='Worklist')
worklist_value.setReference(worklist_id) worklist_value.setReference(worklist_id)
worklist_value.setProperties('', # Configure new workflow:
actbox_name='%s (%%(count)s)' % actbox_name, actbox_url=actbox_url, actbox_name='%s (%%(count)s)' % actbox_name
worklist_value.setActboxName(str(actbox_name))
worklist_value.setActboxUrl(str(actbox_url))
worklist_value.setActboxCategory(str('global'))
props={k if k.startswith('guard_') else 'variable_' + k: v props={k if k.startswith('guard_') else 'variable_' + k: v
for k, v in kw.iteritems()}) for k, v in kw.iteritems()}
worklist_value.updateDynamicVariable() if 'variable_portal_type' in props:
v = props.get('variable_portal_type', None)
if v:
worklist_value.setMatchedPortalTypeList(v)
if 'variable_validation_state' in props:
v = props.get('variable_validation_state', None)
if v:
worklist_value.setMatchedValidationState('state_'+v)
if 'variable_' + self.int_catalogued_variable_id in props:
variable_ref = self.int_catalogued_variable_id
v = props.get('variable_'+self.int_catalogued_variable_id, None)
if v:
# Add a local worklist variable:
variable_value = worklist_value._getOb('variable_' + self.int_catalogued_variable_id, None)
if variable_value is None:
variable_value = worklist_value.newContent(portal_type='Worklist Variable')
variable_value.setReference(variable_ref)
variable_value.setInitialValue(str(v))
# test04 related key
if 'variable_region_uid' in props:
v = props.get('variable_region_uid', None)
if v:
variable_value = worklist_value._getOb('variable_region_uid', None)
if variable_value is None:
variable_value = worklist_value.newContent(portal_type='Worklist Variable')
variable_value.setReference('region_uid')
variable_value.setDefaultExpr(v)
if 'variable_base_category_id' in props:
variable_value = worklist_value._getOb('variable_base_category_id', None)
v = props.get('variable_base_category_id', None)
if variable_value is None:
variable_value = worklist_value.newContent(portal_type='Worklist Variable')
variable_value.setReference('base_category_id')
variable_value.setInitialValue(v)
# Update guard configuration for view and guard value.
if 'guard_roles' in props:
v = props.get('guard_roles', '')
if v:
worklist_value.setRoleList([ var.strip() for var in v.split(';') ])
if 'guard_expr' in props:
v = props.get('guard_expr', '')
if v:
worklist_value.setExpression(v)
worklist_value.getGuard()
else: else:
worklists = workflow_value.worklists worklists = workflow_value.worklists
worklists.addWorklist(worklist_id) worklists.addWorklist(worklist_id)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment