############################################################################## # # Copyright (c) 2004, 2005, 2006 Nexedi SARL and Contributors. # All Rights Reserved. # Romain Courteaud <romain@nexedi.com> # # WARNING: This program as such is intended to be used by professional # programmers who take the whole responsability of assessing all potential # consequences resulting from its eventual inadequacies and bugs # End users who are looking for a ready-to-use solution with commercial # garantees and support are strongly adviced to contract a Free Software # Service Company # # This program is Free Software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # ############################################################################## # # Skeleton ZopeTestCase # from random import randint import os import sys import unittest import time if __name__ == '__main__': execfile(os.path.join(sys.path[0], 'framework.py')) # Needed in order to have a log file inside the current folder os.environ['EVENT_LOG_FILE'] = os.path.join(os.getcwd(), 'zLOG.log') os.environ['EVENT_LOG_SEVERITY'] = '-300' from Testing import ZopeTestCase from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase from AccessControl.SecurityManagement import newSecurityManager, \ noSecurityManager from DateTime import DateTime from Acquisition import aq_base, aq_inner from zLOG import LOG from Products.ERP5Type.DateUtils import addToDate from Products.ERP5Type.tests.Sequence import Sequence, SequenceList from zExceptions import BadRequest from Products.ERP5Type import product_path from Products.CMFCore.utils import getToolByName from Products.ERP5Type.Tool.ClassTool import _aq_reset class TestBase(ERP5TypeTestCase): run_all_test = 1 quiet = 1 object_portal_type = "Organisation" not_defined_property_id = "azerty_qwerty" not_defined_property_value = "qwerty_azerty" temp_class = "Amount" defined_property_id = "title" defined_property_value = "a_wonderful_title" not_related_to_temp_object_property_id = "string_index" not_related_to_temp_object_property_value = "a_great_index" def getTitle(self): return "Base" def getBusinessTemplateList(self): """ """ return ('erp5_base',) def login(self, quiet=0, run=run_all_test): uf = self.getPortal().acl_users uf._doAddUser('rc', '', ['Manager'], []) user = uf.getUserById('rc').__of__(uf) newSecurityManager(None, user) def enableLightInstall(self): """ You can override this. Return if we should do a light install (1) or not (0) """ return 1 def enableActivityTool(self): """ You can override this. Return if we should create (1) or not (0) an activity tool. """ return 1 def afterSetUp(self, quiet=1, run=run_all_test): self.login() portal = self.getPortal() self.category_tool = self.getCategoryTool() portal_catalog = self.getCatalogTool() #portal_catalog.manage_catalogClear() self.createCategories() #Overwrite immediateReindexObject() with a crashing method def crashingMethod(self): self.ImmediateReindexObjectIsCalled() from Products.ERP5Type.Document.Organisation import Organisation Organisation.immediateReindexObject = crashingMethod Organisation.recursiveImmediateReindexObject = crashingMethod def beforeTearDown(self): # Remove crashing method from Products.ERP5Type.Document.Organisation import Organisation del Organisation.immediateReindexObject del Organisation.recursiveImmediateReindexObject def createCategories(self): """ Light install create only base categories, so we create some categories for testing them """ category_list = ['testGroup1', 'testGroup2'] if len(self.category_tool.group.contentValues()) == 0 : for category_id in category_list: o = self.category_tool.group.newContent(portal_type='Category', id=category_id) def stepTic(self,**kw): self.tic() def stepRemoveWorkflowsRelated(self, sequence=None, sequence_list=None, **kw): """ Remove workflow related to the portal type """ self.getWorkflowTool().setChainForPortalTypes( ['Organisation'], ()) _aq_reset() def stepAssociateWorkflows(self, sequence=None, sequence_list=None, **kw): """ Associate workflow to the portal type """ self.getWorkflowTool().setChainForPortalTypes( ['Organisation'], ('validation_workflow', 'edit_workflow')) _aq_reset() def stepAssociateWorkflowsExcludingEdit(self, sequence=None, sequence_list=None, **kw): """ Associate workflow to the portal type """ self.getWorkflowTool().setChainForPortalTypes( ['Organisation'], ('validation_workflow',)) _aq_reset() def stepCreateObject(self, sequence=None, sequence_list=None, **kw): """ Create a object_instance which will be tested. """ portal = self.getPortal() module = portal.getDefaultModule(self.object_portal_type) object_instance = module.newContent(portal_type=self.object_portal_type) sequence.edit( object_instance=object_instance, current_title='', current_group_value=None ) def stepCheckTitleValue(self, sequence=None, sequence_list=None, **kw): """ Check if getTitle return a correect value """ object_instance = sequence.get('object_instance') current_title = sequence.get('current_title') self.assertEquals(object_instance.getTitle(), current_title) def stepSetDifferentTitleValueWithEdit(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') current_title = sequence.get('current_title') new_title_value = '%s_a' % current_title object_instance.edit(title=new_title_value) sequence.edit( current_title=new_title_value ) def stepCheckIfActivitiesAreCreated(self, sequence=None, sequence_list=None, **kw): """ Check if there is a activity in activity queue. """ portal = self.getPortal() get_transaction().commit() message_list = portal.portal_activities.getMessageList() method_id_list = [x.method_id for x in message_list] # XXX FIXME: how many activities should be created normally ? # Sometimes it's one, sometimes 2... self.failUnless(len(message_list) > 0) self.failUnless(len(message_list) < 3) for method_id in method_id_list: self.failUnless(method_id in ["immediateReindexObject", "recursiveImmediateReindexObject"]) def stepSetSameTitleValueWithEdit(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') object_instance.edit(title=object_instance.getTitle()) def stepCheckIfMessageQueueIsEmpty(self, sequence=None, sequence_list=None, **kw): """ Check if there is no activity in activity queue. """ portal = self.getPortal() message_list = portal.portal_activities.getMessageList() self.assertEquals(len(message_list), 0) def test_01_areActivitiesWellLaunchedByPropertyEdit(self, quiet=quiet, run=run_all_test): """ Test if setter does not call a activity if the attribute value is not changed. """ if not run: return sequence_list = SequenceList() # Test without workflows associated to the portal type sequence_string = '\ RemoveWorkflowsRelated \ CreateObject \ Tic \ CheckTitleValue \ SetDifferentTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameTitleValueWithEdit \ CheckTitleValue \ CheckIfMessageQueueIsEmpty \ SetDifferentTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) # Test with workflows associated to the portal type sequence_string = '\ AssociateWorkflows \ CreateObject \ Tic \ CheckTitleValue \ SetDifferentTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetDifferentTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) # Test with workflows associated to the portal type, excluding edit_workflow sequence_string = '\ AssociateWorkflowsExcludingEdit \ CreateObject \ Tic \ CheckTitleValue \ SetDifferentTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameTitleValueWithEdit \ CheckIfMessageQueueIsEmpty \ CheckTitleValue \ SetDifferentTitleValueWithEdit \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepCheckGroupValue(self, sequence=None, sequence_list=None, **kw): """ Check if getTitle return a correect value """ object_instance = sequence.get('object_instance') current_group_value = sequence.get('current_group_value') self.assertEquals(object_instance.getGroupValue(), current_group_value) def stepSetDifferentGroupValueWithEdit(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') current_group_value = sequence.get('current_group_value') group1 = object_instance.portal_categories.\ restrictedTraverse('group/testGroup1') group2 = object_instance.portal_categories.\ restrictedTraverse('group/testGroup2') if (current_group_value is None) or \ (current_group_value == group2) : new_group_value = group1 else: new_group_value = group2 # new_group_value = '%s_a' % current_title object_instance.edit(group_value=new_group_value) sequence.edit( current_group_value=new_group_value ) def stepSetSameGroupValueWithEdit(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') object_instance.edit(group_value=object_instance.getGroupValue()) def test_02_areActivitiesWellLaunchedByCategoryEdit(self, quiet=quiet, run=run_all_test): """ Test if setter does not call a activity if the attribute value is not changed. """ if not run: return sequence_list = SequenceList() # Test without workflows associated to the portal type sequence_string = '\ RemoveWorkflowsRelated \ CreateObject \ Tic \ CheckGroupValue \ SetDifferentGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameGroupValueWithEdit \ CheckIfMessageQueueIsEmpty \ SetDifferentGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) # Test with workflows associated to the portal type sequence_string = '\ AssociateWorkflows \ CreateObject \ Tic \ CheckGroupValue \ SetDifferentGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetDifferentGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) # Test with workflows associated to the portal type, excluding edit_workflow sequence_string = '\ AssociateWorkflowsExcludingEdit \ CreateObject \ Tic \ CheckGroupValue \ SetDifferentGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameGroupValueWithEdit \ CheckIfMessageQueueIsEmpty \ SetDifferentGroupValueWithEdit \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepSetDifferentTitleValueWithSetter(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') current_title = sequence.get('current_title') new_title_value = '%s_a' % current_title object_instance.setTitle(new_title_value) sequence.edit( current_title=new_title_value ) def stepSetSameTitleValueWithSetter(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') object_instance.setTitle(object_instance.getTitle()) def test_03_areActivitiesWellLaunchedByPropertySetter(self, quiet=quiet, run=run_all_test): """ Test if setter does not call a activity if the attribute value is not changed. """ if not run: return sequence_list = SequenceList() # Test without workflows associated to the portal type sequence_string = '\ RemoveWorkflowsRelated \ CreateObject \ Tic \ CheckTitleValue \ SetDifferentTitleValueWithSetter \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameTitleValueWithSetter \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetDifferentTitleValueWithSetter \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) # Test with workflows associated to the portal type sequence_string = '\ AssociateWorkflows \ CreateObject \ Tic \ CheckTitleValue \ SetDifferentTitleValueWithSetter \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameTitleValueWithSetter \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetDifferentTitleValueWithSetter \ CheckIfActivitiesAreCreated \ CheckTitleValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepSetDifferentGroupValueWithSetter(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') current_group_value = sequence.get('current_group_value') group1 = object_instance.portal_categories.\ restrictedTraverse('group/testGroup1') group2 = object_instance.portal_categories.\ restrictedTraverse('group/testGroup2') if (current_group_value is None) or \ (current_group_value == group2) : new_group_value = group1 else: new_group_value = group2 # new_group_value = '%s_a' % current_title object_instance.setGroupValue(new_group_value) sequence.edit( current_group_value=new_group_value ) def stepSetSameGroupValueWithSetter(self, sequence=None, sequence_list=None, **kw): """ Set a different title value """ object_instance = sequence.get('object_instance') object_instance.setGroupValue(object_instance.getGroupValue()) def test_04_areActivitiesWellLaunchedByCategorySetter(self, quiet=quiet, run=run_all_test): """ Test if setter does not call a activity if the attribute value is not changed. """ if not run: return sequence_list = SequenceList() # Test without workflows associated to the portal type sequence_string = '\ RemoveWorkflowsRelated \ CreateObject \ Tic \ CheckGroupValue \ SetDifferentGroupValueWithSetter \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameGroupValueWithSetter \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetDifferentGroupValueWithSetter \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) # Test with workflows associated to the portal type sequence_string = '\ AssociateWorkflows \ CreateObject \ Tic \ CheckGroupValue \ SetDifferentGroupValueWithSetter \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetSameGroupValueWithSetter \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ SetDifferentGroupValueWithSetter \ CheckIfActivitiesAreCreated \ CheckGroupValue \ Tic \ CheckIfMessageQueueIsEmpty \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepSetObjectNotDefinedProperty(self, sequence=None, sequence_list=None, **kw): """ Set a not defined property on the object_instance. """ object_instance = sequence.get('object_instance') object_instance.setProperty(self.not_defined_property_id, self.not_defined_property_value) def stepCheckNotDefinedPropertySaved(self, sequence=None, sequence_list=None, **kw): """ Check if a not defined property is stored on the object_instance. """ object_instance = sequence.get('object_instance') self.assertEquals(self.not_defined_property_value, getattr(object_instance, self.not_defined_property_id)) def stepCheckGetNotDefinedProperty(self, sequence=None, sequence_list=None, **kw): """ Check getProperty with a not defined property. """ object_instance = sequence.get('object_instance') self.assertEquals(self.not_defined_property_value, object_instance.getProperty(self.not_defined_property_id)) def stepCheckObjectPortalType(self, sequence=None, sequence_list=None, **kw): """ Check the portal type of the object_instance. """ object_instance = sequence.get('object_instance') object_instance.getPortalType() self.assertEquals(self.object_portal_type, object_instance.getPortalType()) def stepCreateTempObject(self, sequence=None, sequence_list=None, **kw): """ Create a temp object_instance which will be tested. """ portal = self.getPortal() from Products.ERP5Type.Document import newTempOrganisation tmp_object = newTempOrganisation(portal, "a_wonderful_id") sequence.edit( object_instance=tmp_object, current_title='', current_group_value=None ) def test_05_getPropertyWithoutPropertySheet(self, quiet=quiet, run=run_all_test): """ Test if set/getProperty work without any property sheet. """ if not run: return sequence_list = SequenceList() # Test on object_instance. sequence_string = '\ CreateObject \ SetObjectNotDefinedProperty \ CheckNotDefinedPropertySaved \ CheckGetNotDefinedProperty \ ' sequence_list.addSequenceString(sequence_string) # Test on temp object_instance. sequence_string = '\ CreateTempObject \ CheckObjectPortalType \ SetObjectNotDefinedProperty \ CheckNotDefinedPropertySaved \ CheckGetNotDefinedProperty \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepCreateTempClass(self, sequence=None, sequence_list=None, **kw): """ Create a temp object_instance which will be tested. """ portal = self.getPortal() from Products.ERP5Type.Document import newTempAmount tmp_object = newTempAmount(portal, "another_wonderful_id") sequence.edit( object_instance=tmp_object, current_title='', current_group_value=None ) def stepCheckTempClassPortalType(self, sequence=None, sequence_list=None, **kw): """ Check the portal type of the object_instance. Check that the portal type does not exist. """ object_instance = sequence.get('object_instance') object_instance.getPortalType() self.assertEquals(self.temp_class, object_instance.getPortalType()) self.assertFalse(self.temp_class in \ object_instance.portal_types.listContentTypes()) def stepSetObjectDefinedProperty(self, sequence=None, sequence_list=None, **kw): """ Set a defined property on the object_instance. """ object_instance = sequence.get('object_instance') object_instance.setProperty(self.defined_property_id, self.defined_property_value) def stepCheckDefinedPropertySaved(self, sequence=None, sequence_list=None, **kw): """ Check if a defined property is stored on the object_instance. """ object_instance = sequence.get('object_instance') self.assertEquals(self.defined_property_value, getattr(object_instance, self.defined_property_id)) def stepCheckGetDefinedProperty(self, sequence=None, sequence_list=None, **kw): """ Check getProperty with a defined property. """ object_instance = sequence.get('object_instance') self.assertEquals(self.defined_property_value, object_instance.getProperty(self.defined_property_id)) def stepSetObjectNotRelatedProperty(self, sequence=None, sequence_list=None, **kw): """ Set a defined property on the object_instance. """ object_instance = sequence.get('object_instance') object_instance.setProperty( self.not_related_to_temp_object_property_id, self.not_related_to_temp_object_property_value) def stepCheckNotRelatedPropertySaved(self, sequence=None, sequence_list=None, **kw): """ Check if a defined property is stored on the object_instance. """ object_instance = sequence.get('object_instance') self.assertEquals(self.not_related_to_temp_object_property_value, getattr(object_instance, self.not_related_to_temp_object_property_id)) def stepCheckGetNotRelatedProperty(self, sequence=None, sequence_list=None, **kw): """ Check getProperty with a defined property. """ object_instance = sequence.get('object_instance') self.assertEquals(self.not_related_to_temp_object_property_value, object_instance.getProperty( self.not_related_to_temp_object_property_id)) def test_06_getPropertyOnTempClass(self, quiet=quiet, run=1): """ Test if set/getProperty work in temp object without a portal type with the same name. """ if not run: return sequence_list = SequenceList() # Test on temp tempAmount. sequence_string = '\ CreateTempClass \ CheckTempClassPortalType \ SetObjectDefinedProperty \ CheckDefinedPropertySaved \ CheckGetDefinedProperty \ SetObjectNotDefinedProperty \ CheckNotDefinedPropertySaved \ CheckGetNotDefinedProperty \ SetObjectNotRelatedProperty \ CheckNotRelatedPropertySaved \ CheckGetNotRelatedProperty \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepCheckEditMethod(self, sequence=None, sequence_list=None, **kw): """ Check if edit method works. """ object_instance = sequence.get('object_instance') object_instance.edit(title='toto') self.assertEquals(object_instance.getTitle(),'toto') object_instance.edit(title='tutu') self.assertEquals(object_instance.getTitle(),'tutu') def stepSetEditProperty(self, sequence=None, sequence_list=None, **kw): """ Check if edit method works. """ object_instance = sequence.get('object_instance') self.assertRaises(BadRequest,object_instance.setProperty, 'edit', "now this object is 'read only !!!'") def test_07_setEditProperty(self, quiet=quiet, run=run_all_test): """ Test if setProperty erase existing accessors/methods. """ if not run: return sequence_list = SequenceList() # Test on temp tempAmount. sequence_string = '\ CreateObject \ CheckEditMethod \ SetEditProperty \ CheckEditMethod \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def stepCreateBaseCategory(self, sequence=None, sequence_list=None, **kw): """ Create a base category. """ portal = self.getPortal() module = portal.portal_categories object_instance = module.newContent(portal_type="Base Category") sequence.edit( object_instance=object_instance, ) def stepSetBadTalesExpression(self, sequence=None, sequence_list=None, **kw): """ Set a wrong tales expression """ object_instance = sequence.get('object_instance') tales_expression = "python: 1 + 'a'" object_instance.edit(acquisition_portal_type_list=tales_expression) sequence.edit( tales_expression=tales_expression, ) def stepCheckTalesExpression(self, sequence=None, sequence_list=None, **kw): """ Set a wrong tales expression """ object_instance = sequence.get('object_instance') tales_expression = sequence.get('tales_expression') self.assertEquals(object_instance.getAcquisitionPortalTypeList(evaluate=0), tales_expression) def stepSetGoodTalesExpression(self, sequence=None, sequence_list=None, **kw): """ Set a wrong tales expression """ object_instance = sequence.get('object_instance') tales_expression = "python: 1 + 1" object_instance.edit(acquisition_portal_type_list=tales_expression) sequence.edit( tales_expression=tales_expression, ) def test_07_setEditTalesExpression(self, quiet=quiet, run=run_all_test): """ Test if edit update a tales expression. """ if not run: return sequence_list = SequenceList() sequence_string = '\ CreateBaseCategory \ SetBadTalesExpression \ CheckTalesExpression \ SetGoodTalesExpression \ CheckTalesExpression \ ' sequence_list.addSequenceString(sequence_string) sequence_list.play(self, quiet=quiet) def test_08_emptyObjectHasNoTitle(self, quiet=quiet, run=run_all_test): """Test that an empty object has no title. """ if not run: return portal = self.getPortal() portal_type = "Organisation" module = portal.getDefaultModule(portal_type=portal_type) obj = module.newContent(portal_type=portal_type) # XXX title is an empty string by default, but it's still unsure wether it # should be None or '' self.assertEquals('', obj.getProperty("title")) self.assertEquals('', obj.getTitle()) def test_09_setPropertyDefinedProperty(self, quiet=quiet, run=run_all_test): """Test for setProperty on Base, when the property is defined. """ if not run: return portal = self.getPortal() portal_type = "Organisation" module = portal.getDefaultModule(portal_type=portal_type) obj = module.newContent(portal_type=portal_type) title = 'Object title' obj.setProperty('title', title) self.assertEquals(obj.getProperty('title'), title) obj.setProperty('title', title) self.assertEquals(obj.getProperty('title'), title) obj.edit(title=title) self.assertEquals(obj.getProperty('title'), title) def test_10_setPropertyNotDefinedProperty(self, quiet=quiet, run=run_all_test): """Test for setProperty on Base, when the property is not defined. """ if not run: return portal = self.getPortal() portal_type = "Organisation" module = portal.getDefaultModule(portal_type=portal_type) obj = module.newContent(portal_type=portal_type) property_value = 'Object title' property_name = 'a_dummy_not_exising_property' obj.setProperty(property_name, property_value) self.assertEquals(obj.getProperty(property_name), property_value) obj.setProperty(property_name, property_value) self.assertEquals(obj.getProperty(property_name), property_value) obj.edit(**{property_name: property_value}) self.assertEquals(obj.getProperty(property_name), property_value) def test_11_setPropertyPropertyDefinedOnInstance(self, quiet=quiet, run=run_all_test): """Test for setProperty on Base, when the property is defined on the instance, the typical example is 'workflow_history' property. """ if not run: return portal = self.getPortal() portal_type = "Organisation" module = portal.getDefaultModule(portal_type=portal_type) obj = module.newContent(portal_type=portal_type) property_value = 'Property value' property_name = 'a_dummy_object_property' setattr(obj, property_name, property_value) self.assertRaises(BadRequest, obj.setProperty, property_name, property_value) self.assertRaises(BadRequest, obj.setProperty, 'workflow_history', property_value) def test_12_editTempObject(self, quiet=quiet, run=run_all_test): """Simple test to edit a temp object. """ portal = self.getPortal() from Products.ERP5Type.Document import newTempOrganisation tmp_object = newTempOrganisation(portal, "a_wonderful_id") tmp_object.edit(title='new title') self.assertEquals('new title', tmp_object.getTitle()) def test_13_aqDynamicWithNonExistentWorkflow(self, quiet=quiet, run=run_all_test): """Test if _aq_dynamic still works even if an associated workflow is not present in the portal. This may cause an infinite recursion.""" if not run: return portal = self.getPortal() portal_type = "Organisation" module = portal.getDefaultModule(portal_type = portal_type) obj = module.newContent(portal_type = portal_type) # Add a non-existent workflow. pw = self.getWorkflowTool() dummy_worlflow_id = 'never_existent_workflow' pw.manage_addWorkflow('dc_workflow (Web-configurable workflow)', dummy_worlflow_id) cbt = pw._chains_by_type props = {} for id, wf_ids in cbt.iteritems(): if id == portal_type: wf_ids = list(wf_ids) + [dummy_worlflow_id] props['chain_%s' % id] = ','.join(wf_ids) pw.manage_changeWorkflows('', props = props) pw.manage_delObjects([dummy_worlflow_id]) # Make sure that _aq_dynamic will be called again. _aq_reset() try: self.assertRaises(AttributeError, obj.thisMethodShouldNotBePresent) finally: # Make sure that the artificial workflow is not referred to any longer. cbt = pw._chains_by_type props = {} for id, wf_ids in cbt.iteritems(): if id == portal_type: # Remove the non-existent workflow. wf_ids = [wf_id for wf_id in wf_ids \ if wf_id != dummy_worlflow_id] props['chain_%s' % id] = ','.join(wf_ids) pw.manage_changeWorkflows('', props = props) class TestERP5PropertyManager(unittest.TestCase): """Tests for ERP5PropertyManager. """ def _makeOne(self, *args, **kw): from Products.ERP5Type.patches.PropertyManager import ERP5PropertyManager ob = ERP5PropertyManager(*args, **kw) # add missing methods for createExpressionContext ob.getPortalObject = lambda : None ob.absolute_url = lambda: '' return ob def test_setProperty(self): """_setProperty adds a new property if not present.""" ob = self._makeOne('ob') dummy_property_value = 'test string value' ob._setProperty('a_dummy_property', dummy_property_value) # the property appears in property map self.failUnless('a_dummy_property' in [x['id'] for x in ob.propertyMap()]) # the value and can be retrieved using getProperty self.assertEquals(ob.getProperty('a_dummy_property'), dummy_property_value) # the value is also stored as a class attribute self.assertEquals(ob.a_dummy_property, dummy_property_value) def test_setPropertyExistingProperty(self): """_setProperty raises an error if the property already exists.""" ob = self._makeOne('ob') # make sure that title property exists self.failUnless('title' in [x['id'] for x in ob.propertyMap()]) # trying to call _setProperty will with an existing property raises: # BadRequest: Invalid or duplicate property id: title self.assertRaises(BadRequest, ob._setProperty, 'title', 'property value') def test_updatePropertyExistingProperty(self): """_updateProperty should be used if the existing property already exists. """ ob = self._makeOne('ob') # make sure that title property exists self.failUnless('title' in [x['id'] for x in ob.propertyMap()]) prop_value = 'title value' ob._updateProperty('title', prop_value) self.assertEquals(ob.getProperty('title'), prop_value) self.assertEquals(ob.title, prop_value) def test_setPropertyTypeInt(self): """You can specify the type of the property in _setProperty""" ob = self._makeOne('ob') dummy_property_value = 3 ob._setProperty('a_dummy_property', dummy_property_value, type='int') self.assertEquals(['int'], [x['type'] for x in ob.propertyMap() if x['id'] == 'a_dummy_property']) self.assertEquals(type(ob.getProperty('a_dummy_property')), type(1)) def test_setPropertyTALESType(self): """ERP5PropertyManager can use TALES Type for properties, TALES will then be evaluated in getProperty. """ ob = self._makeOne('ob') dummy_property_value = 'python: 1+2' ob._setProperty('a_dummy_property', dummy_property_value, type='tales') self.assertEquals(ob.getProperty('a_dummy_property'), 1+2) def test_getPropertyNonExistantProps(self): """getProperty return None if the value is not found. """ ob = self._makeOne('ob') self.assertEquals(ob.getProperty('a_dummy_property'), None) def test_getPropertyDefaultValue(self): """getProperty accepts a default value, if the property is not defined. """ ob = self._makeOne('ob') self.assertEquals(ob.getProperty('a_dummy_property', 100), 100) prop_value = 3 ob._setProperty('a_dummy_property', prop_value) self.assertEquals(ob.getProperty('a_dummy_property', 100), prop_value) if __name__ == '__main__': framework() else: import unittest def test_suite(): suite = unittest.TestSuite() suite.addTest(unittest.makeSuite(TestBase)) suite.addTest(unittest.makeSuite(TestERP5PropertyManager)) return suite