From d5b0573f8bdf12c4c16e3df7ae1392bb3ada6d9a Mon Sep 17 00:00:00 2001
From: Sebastien Robin <seb@nexedi.com>
Date: Tue, 5 Apr 2005 13:24:57 +0000
Subject: [PATCH] Added test when we rename an object

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@2794 20353a03-c40f-0410-a6d1-a30d3c3de9de
---
 product/ERP5/tests/testERP5Category.py | 215 +++++++++++++++++++++++++
 1 file changed, 215 insertions(+)
 create mode 100755 product/ERP5/tests/testERP5Category.py

diff --git a/product/ERP5/tests/testERP5Category.py b/product/ERP5/tests/testERP5Category.py
new file mode 100755
index 0000000000..bfdbf3795a
--- /dev/null
+++ b/product/ERP5/tests/testERP5Category.py
@@ -0,0 +1,215 @@
+##############################################################################
+#
+# Copyright (c) 2004 Nexedi SARL and Contributors. All Rights Reserved.
+#          Sebastien Robin <seb@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, sys
+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 Products.ERP5Type.Base import _aq_reset
+from Products.ERP5.Document.Organisation import Organisation
+from Products.ERP5Type.Tool.ClassTool import _aq_reset
+from DateTime import DateTime
+from Products.ERP5.Document.Person import Person
+from AccessControl.SecurityManagement import newSecurityManager, noSecurityManager
+from zLOG import LOG
+import time
+
+class Test(ERP5TypeTestCase):
+
+  # Different variables used for this test
+  run_all_test = 1
+  portal_type = 'Organisation'
+  base_cat = 'abc'
+  cat_list = [base_cat + '/1',base_cat + '/2']
+  new_cat_list = [base_cat + '/3',base_cat + '/2']
+  deep_cat_list = [base_cat + '/1/1',base_cat + '/2/1']
+  new_deep_cat_list = [base_cat + '/3/1',base_cat + '/2/1']
+
+  def getTitle(self):
+    """
+    """
+    return "ERP5 Categories"
+
+
+  def getBusinessTemplateList(self):
+    """
+      Return the list of business templates.
+
+    """
+    return ()
+
+  def enableActivityTool(self):
+    """
+    You can override this. Return if we should create (1) or not (0) an activity tool
+    """
+    return 0
+
+
+  def getPortalId(self):
+    return self.getPortal().getId()
+
+  def logMessage(self,message):
+    ZopeTestCase._print('\n%s ' % message)
+    LOG('Testing... ',0,message)
+
+  def getOrderLine(self):
+    return self.getSaleOrderModule()['1']['1']
+
+  def getPredicate(self):
+    return self.getSalePackingListModule()['1']
+
+  def afterSetUp(self):
+    self.login()
+    # This add the base category size
+    portal_categories = self.getCategoryTool()
+    bc = self.base_cat
+    portal_categories.newContent(portal_type='Base Category',id=bc)
+    self.cat1 = portal_categories[bc].newContent(id='1',portal_type='Category')
+    self.deep_cat1 = self.cat1.newContent(id='1',portal_type='Category')
+    self.cat2 = portal_categories[bc].newContent(id='2',portal_type='Category')
+    self.deep_cat2 = self.cat2.newContent(id='1',portal_type='Category')
+    portal_categories[self.base_cat].recursiveImmediateReindexObject()
+
+    portal_type = self.getTypeTool()[self.portal_type]
+    portal_type.base_category_list = [self.base_cat]
+    organisation_module = self.getOrganisationModule()
+    self.organisation = organisation_module.newContent(id='1',portal_type=self.portal_type)
+    self.organisation.immediateReindexObject()
+    self.telephone = self.organisation.newContent(id='1',portal_type='Telephone')
+    self.organisation2 = organisation_module.newContent(id='2',portal_type=self.portal_type)
+    self.organisation2.immediateReindexObject()
+    self.telephone2 = self.organisation2.newContent(id='1',portal_type='Telephone')
+
+    # We have no place to put a Predicate, we will put it in the
+    # Organisation Module
+    portal = self.getPortal()
+    type_tool = self.getTypeTool()
+    module_type = type_tool['%s Module' % self.portal_type]
+    module_type.allowed_content_types += ('Predicate Group',)
+    module = self.getOrganisationModule()
+    predicate = module.newContent(id='predicate',portal_type='Predicate Group')
+    predicate.setCriterion('quantity',identity=None,min=None,max=None)
+    predicate.immediateReindexObject()
+    self.predicate = predicate
+
+    get_transaction().commit(1) # If we don't commit, then we can't rename
+
+  def login(self, quiet=0):
+    uf = self.getPortal().acl_users
+    uf._doAddUser('seb', '', ['Manager'], [])
+    user = uf.getUserById('seb').__of__(uf)
+    newSecurityManager(None, user)
+
+  def test_01(self, quiet=0, run=run_all_test):
+    if not run: return
+    if not quiet:
+      self.logMessage('Rename Category')
+    organisation = self.organisation
+    organisation.setCategoryList(self.cat_list)
+    self.failIfDifferentSet(organisation.getCategoryList(),self.cat_list)
+    portal_categories = self.getCategoryTool()
+    portal_categories[self.base_cat]['1'].edit(id='3')
+    self.failIfDifferentSet(organisation.getCategoryList(),self.new_cat_list)
+
+  def test_02(self, quiet=0, run=run_all_test):
+    if not run: return
+    if not quiet:
+      self.logMessage('Rename Category Tree')
+    organisation = self.organisation
+    organisation.setCategoryList(self.deep_cat_list)
+    self.failIfDifferentSet(organisation.getCategoryList(),self.deep_cat_list)
+    portal_categories = self.getCategoryTool()
+    portal_categories[self.base_cat]['1'].edit(id='3')
+    self.failIfDifferentSet(organisation.getCategoryList(),self.new_deep_cat_list)
+
+  def test_03(self, quiet=0, run=run_all_test):
+    if not run: return
+    if not quiet:
+      self.logMessage('Rename Related Object')
+    organisation = self.organisation
+    organisation2 = self.organisation2
+    organisation.setAbcValueList([organisation2])
+    self.assertEquals(organisation.getAbcValueList(),[organisation2])
+    self.assertEquals(organisation.getAbcIdList(),['2'])
+    organisation2.edit(id='new_id')
+    self.assertEquals(organisation.getAbcValueList(),[organisation2])
+    self.assertEquals(organisation.getAbcIdList(),['new_id'])
+
+  def test_04(self, quiet=0, run=run_all_test):
+    if not run: return
+    if not quiet:
+      self.logMessage('Rename Object With a related Sub Object')
+    telephone2 = self.telephone2
+    organisation = self.organisation
+    organisation2 = self.organisation2
+    organisation.setAbcValueList([telephone2])
+    self.assertEquals(organisation.getAbcValueList(),[telephone2])
+    self.assertEquals(organisation.getAbcList(),['organisation/2/1'])
+    organisation2.edit(id='new_id')
+    self.assertEquals(organisation.getAbcValueList(),[telephone2])
+    self.assertEquals(organisation.getAbcList(),['organisation/new_id/1'])
+
+  def test_05(self, quiet=0, run=run_all_test):
+    if not run: return
+    if not quiet:
+      self.logMessage('Rename Membership Criterion Category')
+    predicate = self.predicate
+    predicate.setMembershipCriterionBaseCategoryList(self.base_cat)
+    predicate.setMembershipCriterionCategoryList(self.cat_list)
+    self.failIfDifferentSet(predicate.getMembershipCriterionCategoryList(),self.cat_list)
+    portal_categories = self.getCategoryTool()
+    portal_categories[self.base_cat]['1'].edit(id='3')
+    get_transaction().commit()
+    self.failIfDifferentSet(predicate.getMembershipCriterionCategoryList(),self.new_cat_list)
+
+
+
+
+if __name__ == '__main__':
+    framework()
+else:
+    import unittest
+    def test_suite():
+        suite = unittest.TestSuite()
+        suite.addTest(unittest.makeSuite(Test))
+        return suite
+
-- 
2.30.9