From 81235f03bc55a3c1ec871b6221d4f98d2b191875 Mon Sep 17 00:00:00 2001
From: Sebastien Robin <seb@nexedi.com>
Date: Thu, 29 Jul 2004 17:28:03 +0000
Subject: [PATCH] test if we uncatalog well cells

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@1305 20353a03-c40f-0410-a6d1-a30d3c3de9de
---
 product/ERP5Type/tests/testXMLMatrix.py | 104 +++++++++++++++++++++++-
 1 file changed, 102 insertions(+), 2 deletions(-)

diff --git a/product/ERP5Type/tests/testXMLMatrix.py b/product/ERP5Type/tests/testXMLMatrix.py
index 87e32da36b..1acd235cb2 100755
--- a/product/ERP5Type/tests/testXMLMatrix.py
+++ b/product/ERP5Type/tests/testXMLMatrix.py
@@ -1,6 +1,31 @@
+##############################################################################
 #
-# Skeleton ZopeTestCase
+# Copyright (c) 2004 Nexedi SARL and Contributors. All Rights Reserved.
+#          Yoshinori Okuji <yo@nexedi.com>
+#          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.
+#
+##############################################################################
 
 from random import randint
 
@@ -8,6 +33,10 @@ 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.ERP5.Document.DeliveryLine import DeliveryLine
@@ -38,7 +67,8 @@ class TestXMLMatrix(ERP5TypeTestCase):
     module = portal.purchase_order
     order = module.newContent(id='1', portal_type='Purchase Order')
 
-  def testRenameCellRange(self):
+  def test_01_RenameCellRange(self):
+    ZopeTestCase._print('\nTest Rename Cell Range ')
     # Test if renameCellRange works in XMLMatrix.
     portal = self.getPortal()
     module = portal.purchase_order
@@ -140,6 +170,76 @@ class TestXMLMatrix(ERP5TypeTestCase):
         self.assertEqual(getattr(cell, 'test_id', None), value_list[i])
       i += 1
 
+  def checkSetCellRangeAndCatalog(self,active=1):
+    # Test if set Cell range do well catalog and uncatalog
+    portal = self.getPortal()
+    if not active:
+      portal._delObject('portal_activities')
+    module = portal.purchase_order
+    module.recursiveImmediateReindexObject()
+    catalog = portal.portal_catalog
+
+    order = module._getOb('1')
+    if order.hasContent('1'): order.deleteContent('1')
+    matrix = order.newContent(id='1', portal_type='Purchase Order Line')
+    url = matrix.getUrl()
+
+    cell_range = [['1', '2', '3'], ['a', 'b', 'c']]
+    kwd = {'base_id' : 'quantity'}
+    matrix.setCellRange(*cell_range, **kwd)
+    self.assertEqual(matrix.getCellRange(**kwd), cell_range)
+
+    for place in cartesianProduct(cell_range):
+      cell = matrix.newCell(*place, **kwd)
+    self.tic()
+    matrix.recursiveImmediateReindexObject()
+    initial_cell_id_list = map(lambda x: x.getId(),matrix.objectValues())
+    for id in initial_cell_id_list:
+      cell_path = url + '/' + id
+      self.assertEquals(catalog.hasPath(cell_path),True)
+
+    cell_range = [['2', '3', '4'], ['b', 'c', 'd']]
+    matrix.setCellRange(*cell_range, **kwd)
+    self.assertEqual(matrix.getCellRange(**kwd), cell_range)
+    next_cell_id_list = map(lambda x: x.getId(),matrix.objectValues())
+    removed_id_list = filter(lambda x: x not in next_cell_id_list,initial_cell_id_list)
+    self.tic()
+    for id in next_cell_id_list:
+      cell_path = url + '/' + id
+      self.assertEquals(catalog.hasPath(cell_path),True)
+    for id in removed_id_list:
+      cell_path = url + '/' + id
+      self.assertEquals(catalog.hasPath(cell_path),False)
+
+    cell_range = [['0', '1'], ['a','b']]
+    matrix.setCellRange(*cell_range, **kwd)
+    self.assertEqual(matrix.getCellRange(**kwd), cell_range)
+    next2_cell_id_list = map(lambda x: x.getId(),matrix.objectValues())
+    removed_id_list = filter(lambda x: x not in next2_cell_id_list,next_cell_id_list)
+    self.tic()
+    for id in next2_cell_id_list:
+      cell_path = url + '/' + id
+      self.assertEquals(catalog.hasPath(cell_path),True)
+    for id in removed_id_list:
+      cell_path = url + '/' + id
+      self.assertEquals(catalog.hasPath(cell_path),False)
+
+    cell_range = [['0', '1'], ['a','b']]
+    kwd = {'base_id' : 'movement'}
+    matrix.setCellRange(*cell_range, **kwd)
+    self.assertEqual(matrix.getCellRange(**kwd), cell_range)
+    self.tic()
+    for id in next2_cell_id_list:
+      cell_path = url + '/' + id
+      self.assertEquals(catalog.hasPath(cell_path),False)
+
+  def test_02_SetCellRangeAndCatalogWithoutActivities(self):
+    ZopeTestCase._print('\nTest Set Cell Range And Catalog Without Activities ')
+    self.checkSetCellRangeAndCatalog(active=0)
+
+  def test_03_SetCellRangeAndCatalogWithActivities(self):
+    ZopeTestCase._print('\nTest Set Cell Range And Catalog With Activities ')
+    self.checkSetCellRangeAndCatalog(active=0)
 
 if __name__ == '__main__':
     framework()
-- 
2.30.9