From ecfaa9d137af388125baea0cb60d4738479543af Mon Sep 17 00:00:00 2001
From: Vincent Pelletier <vincent@nexedi.com>
Date: Tue, 13 May 2008 01:06:47 +0000
Subject: [PATCH] Add a stand-alone unittest script for CopySupport methods.
 Add a test to check setId concurrency behaviour.

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@20918 20353a03-c40f-0410-a6d1-a30d3c3de9de
---
 product/ERP5Type/tests/testCopySupport.py | 90 +++++++++++++++++++++++
 1 file changed, 90 insertions(+)
 create mode 100644 product/ERP5Type/tests/testCopySupport.py

diff --git a/product/ERP5Type/tests/testCopySupport.py b/product/ERP5Type/tests/testCopySupport.py
new file mode 100644
index 0000000000..53b836909c
--- /dev/null
+++ b/product/ERP5Type/tests/testCopySupport.py
@@ -0,0 +1,90 @@
+##############################################################################
+#
+# Copyright (c) 2006 Nexedi SARL and Contributors. All Rights Reserved.
+#                     Vincent Pelletier <vincent@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.
+#
+##############################################################################
+
+import unittest
+
+from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase
+#from AccessControl.SecurityManagement import newSecurityManager
+from Products.CMFActivity.Errors import ActivityPendingError
+
+class TestCopySupport(ERP5TypeTestCase):
+  """
+    Test CopySupport methods
+  """
+
+  def getBusinessTemplateList(self):
+    return ('erp5_base', )
+
+  def getTitle(self):
+    return "CopySupport"
+
+  def afterSetUp(self):
+    portal = self.portal = self.getPortalObject()
+    self.organisation_module = portal.organisation_module
+    self.person_module = portal.person_module
+
+  def test_01_setIdConcurency(self):
+    """
+      Check that it is impossible to call setId when there are remaining
+      operations from a previous setId call.
+      Also, check that external relations are correctly updated.
+    """
+    organisation = self.organisation_module.newContent(
+                     portal_type='Organisation')
+    person = self.person_module.newContent(portal_type='Person',
+               career_subordination_value=organisation)
+    get_transaction().commit()
+    self.tic()
+    self.assertEqual(0, len(self.portal.portal_activities.getMessageList()))
+    self.assertTrue(person.getCareerSubordination().startswith('organisation_module'))
+    self.assertTrue(person.getCareerSubordinationValue().aq_base is organisation.aq_base)
+    # Try to rename: must work
+    self.organisation_module.setId('new_organisation_module')
+    get_transaction().commit()
+    self.assertTrue(person.getCareerSubordination().startswith('organisation_module'))
+    initial_activity_count = len(self.portal.portal_activities.getMessageList())
+    self.assertNotEqual(0, initial_activity_count)
+    # Try to rename again with pending activities: must raise
+    self.assertRaises(ActivityPendingError, self.organisation_module.setId, 'organisation_module')
+    get_transaction().commit()
+    # Activity count must not have changed
+    self.assertEqual(initial_activity_count, len(self.portal.portal_activities.getMessageList()))
+    self.tic()
+    # Check that external relation was updated
+    self.assertTrue(person.getCareerSubordination().startswith('new_organisation_module'))
+    self.assertTrue(person.getCareerSubordinationValue().aq_base is organisation.aq_base)
+    # Rename back to original name
+    self.organisation_module.setId('organisation_module')
+    get_transaction().commit()
+    self.tic()
+    # Check that relation is back to what it was
+    self.assertTrue(person.getCareerSubordination().startswith('organisation_module'))
+    self.assertTrue(person.getCareerSubordinationValue().aq_base is organisation.aq_base)
+
+if __name__ == '__main__':
+  unittest.main()
-- 
2.30.9