From 9d2c764c5d7b0dba3107f8f9c347f2d9165f95e2 Mon Sep 17 00:00:00 2001
From: Arnaud Fontaine <arnaud.fontaine@nexedi.com>
Date: Thu, 4 Jul 2013 14:55:43 +0900
Subject: [PATCH] ZODB Components: Through Publisher, ExternalMethod
 getFuncCode() failed in development mode because there was a check whether
 Extension on FS should be reloaded even for Components.

---
 product/ERP5Type/patches/ExternalMethod.py          | 12 ++++++++++++
 .../ERP5Type/tests/testDynamicClassGeneration.py    | 13 +++++++++++++
 2 files changed, 25 insertions(+)

diff --git a/product/ERP5Type/patches/ExternalMethod.py b/product/ERP5Type/patches/ExternalMethod.py
index b16779c170..15eab4e041 100644
--- a/product/ERP5Type/patches/ExternalMethod.py
+++ b/product/ERP5Type/patches/ExternalMethod.py
@@ -43,6 +43,18 @@ if 1:
 
     ExternalMethod.getFunction = getFunction
 
+    ExternalMethod_reloadIfChanged = ExternalMethod.reloadIfChanged
+    def reloadIfChanged(self):
+        try:
+            component_module = __import__(
+                'erp5.component.extension.' + self._module,
+                fromlist=['erp5.component.extension'],
+                level=0)
+        except ImportError:
+            return ExternalMethod_reloadIfChanged(self)
+
+    ExternalMethod.reloadIfChanged = reloadIfChanged
+
     def __call__(self, *args, **kw):
         """Call an ExternalMethod
 
diff --git a/product/ERP5Type/tests/testDynamicClassGeneration.py b/product/ERP5Type/tests/testDynamicClassGeneration.py
index 0a2d11eb1c..6e813ae12a 100644
--- a/product/ERP5Type/tests/testDynamicClassGeneration.py
+++ b/product/ERP5Type/tests/testDynamicClassGeneration.py
@@ -1834,6 +1834,19 @@ class TestZodbExtensionComponent(_TestZodbComponent):
     external_method = self.getPortal().TestExternalMethod
     self.assertEqual(external_method(), 42)
 
+    # Check that the External Method returns expected result through Publisher
+    # with or without DevelopmentMode
+    path = '%s/TestExternalMethod' % self.portal.getId()
+    self.assertEqual(self.publish(path).getBody(), '42')
+
+    import Globals
+    previous_development_mode = Globals.DevelopmentMode
+    Globals.DevelopmentMode = not Globals.DevelopmentMode
+    try:
+      self.assertEqual(self.publish(path).getBody(), '42')
+    finally:
+      Globals.DevelopmentMode = previous_development_mode
+
     # Add a Python Script with the External Method defined above and check
     # that it returns 42
     from Products.PythonScripts.PythonScript import manage_addPythonScript
-- 
2.30.9