[CMF-checkins] SVN: CMF/branches/1.5/C CMFCore.FSPythonScript: FSPythonScripts forgot to add __file__ to

Stefan H. Holek stefan at epy.co.at
Thu Feb 16 17:47:16 EST 2006


Log message for revision 41635:
  CMFCore.FSPythonScript: FSPythonScripts forgot to add __file__ to
  the script globals. This broke warnings.warn() when a stacklevel
  argument pointing into the script was passed (2).
  

Changed:
  U   CMF/branches/1.5/CHANGES.txt
  U   CMF/branches/1.5/CMFCore/FSPythonScript.py
  A   CMF/branches/1.5/CMFCore/tests/fake_skins/fake_skin/test_warn.py
  U   CMF/branches/1.5/CMFCore/tests/test_FSPythonScript.py

-=-
Modified: CMF/branches/1.5/CHANGES.txt
===================================================================
--- CMF/branches/1.5/CHANGES.txt	2006-02-16 13:56:23 UTC (rev 41634)
+++ CMF/branches/1.5/CHANGES.txt	2006-02-16 22:47:15 UTC (rev 41635)
@@ -2,6 +2,10 @@
 
   Bug Fixes
 
+    - CMFCore.FSPythonScript: FSPythonScripts forgot to add __file__ to
+      the script globals. This broke warnings.warn() when a stacklevel
+      argument pointing into the script was passed (2).
+
     - CMFSetup.workflow: Workflows managing no permissions at all could
       make the CMFSetup workflow exporter fail.
       (http://www.zope.org/Collectors/CMF/397)

Modified: CMF/branches/1.5/CMFCore/FSPythonScript.py
===================================================================
--- CMF/branches/1.5/CMFCore/FSPythonScript.py	2006-02-16 13:56:23 UTC (rev 41634)
+++ CMF/branches/1.5/CMFCore/FSPythonScript.py	2006-02-16 22:47:15 UTC (rev 41635)
@@ -148,6 +148,7 @@
         new_globals = f.func_globals.copy()
         new_globals['__traceback_supplement__'] = (
             FSPythonScriptTracebackSupplement, self)
+        new_globals['__file__'] = self._filepath
         if bound_names:
             new_globals.update(bound_names)
         if f.func_defaults:

Added: CMF/branches/1.5/CMFCore/tests/fake_skins/fake_skin/test_warn.py
===================================================================
--- CMF/branches/1.5/CMFCore/tests/fake_skins/fake_skin/test_warn.py	2006-02-16 13:56:23 UTC (rev 41634)
+++ CMF/branches/1.5/CMFCore/tests/fake_skins/fake_skin/test_warn.py	2006-02-16 22:47:15 UTC (rev 41635)
@@ -0,0 +1 @@
+context.warn_me()


Property changes on: CMF/branches/1.5/CMFCore/tests/fake_skins/fake_skin/test_warn.py
___________________________________________________________________
Name: svn:eol-style
   + native

Modified: CMF/branches/1.5/CMFCore/tests/test_FSPythonScript.py
===================================================================
--- CMF/branches/1.5/CMFCore/tests/test_FSPythonScript.py	2006-02-16 13:56:23 UTC (rev 41634)
+++ CMF/branches/1.5/CMFCore/tests/test_FSPythonScript.py	2006-02-16 22:47:15 UTC (rev 41635)
@@ -12,12 +12,14 @@
 from time import sleep
 
 from OFS.Folder import Folder
+from OFS.SimpleItem import SimpleItem
 from Products.StandardCacheManagers import RAMCacheManager
 
 from Products.CMFCore.FSPythonScript import FSPythonScript
 from Products.CMFCore.FSMetadata import FSMetadata
 from Products.CMFCore.tests.base.testcase import FSDVTest
 from Products.CMFCore.tests.base.testcase import SecurityTest
+from Products.CMFCore.tests.base.testcase import WarningInterceptor
 
 
 class FSPSMaker(FSDVTest):
@@ -143,10 +145,44 @@
         FSPSMaker.tearDown(self)
 
 
+class WarnMe(SimpleItem):
+    """Emits a UserWarning when called"""
+
+    def __init__(self, stacklevel):
+        self._stacklevel = stacklevel
+
+    def __call__(self):
+        import warnings
+        warnings.warn('foo', stacklevel=self._stacklevel)
+
+
+class FSPythonScriptWarningsTests(SecurityTest, FSPSMaker, WarningInterceptor):
+
+    def setUp( self ):
+        SecurityTest.setUp(self)
+        FSPSMaker.setUp(self)
+        self._trap_warning_output()
+
+    def tearDown(self):
+        self._free_warning_output()
+        FSPSMaker.tearDown(self)
+        SecurityTest.tearDown(self)
+
+    def testFSPSWarn(self):
+        self.root._setObject('warn_me', WarnMe(2))
+        self.root._setObject('warn1', self._makeOne('warn1', 'test_warn.py'))
+        # This used to raise an error:
+        #   File "/usr/local/python2.3/lib/python2.3/warnings.py", line 63, in warn_explicit
+        #     if module[-3:].lower() == ".py":
+        # TypeError: unsubscriptable object
+        self.root.warn1()
+
+
 def test_suite():
     return TestSuite((
         makeSuite(FSPythonScriptTests),
         makeSuite(FSPythonScriptCustomizationTests),
+        makeSuite(FSPythonScriptWarningsTests),
         ))
 
 if __name__ == '__main__':



More information about the CMF-checkins mailing list