[Zope-Checkins] SVN: Zope/branches/2.12/src/Zope2/App/ Use Tres' handy upgradeException function, to make the ExceptionHookTest work across Python versions
Hanno Schlichting
hannosch at hannosch.eu
Tue Jul 14 04:38:03 EDT 2009
Log message for revision 101882:
Use Tres' handy upgradeException function, to make the ExceptionHookTest work across Python versions
Changed:
U Zope/branches/2.12/src/Zope2/App/startup.py
U Zope/branches/2.12/src/Zope2/App/tests/testExceptionHook.py
-=-
Modified: Zope/branches/2.12/src/Zope2/App/startup.py
===================================================================
--- Zope/branches/2.12/src/Zope2/App/startup.py 2009-07-14 06:33:00 UTC (rev 101881)
+++ Zope/branches/2.12/src/Zope2/App/startup.py 2009-07-14 08:38:03 UTC (rev 101882)
@@ -23,6 +23,7 @@
from App.config import getConfiguration
from time import asctime
from types import StringType, ListType
+from zExceptions import upgradeException
from zExceptions import Redirect
from zExceptions import Unauthorized
from ZODB.POSException import ConflictError
@@ -167,8 +168,10 @@
def __call__(self, published, REQUEST, t, v, traceback):
try:
+ t, v = upgradeException(t, v)
+
if t is SystemExit or issubclass(t, Redirect):
- raise
+ raise t, v, traceback
if issubclass(t, ConflictError):
self.logConflicts(v, REQUEST)
Modified: Zope/branches/2.12/src/Zope2/App/tests/testExceptionHook.py
===================================================================
--- Zope/branches/2.12/src/Zope2/App/tests/testExceptionHook.py 2009-07-14 06:33:00 UTC (rev 101881)
+++ Zope/branches/2.12/src/Zope2/App/tests/testExceptionHook.py 2009-07-14 08:38:03 UTC (rev 101882)
@@ -115,19 +115,21 @@
class ExceptionHookTest(ExceptionHookTestCase):
def testStringException1(self):
+ from zExceptions import Unauthorized
def f():
- raise 'unauthorized', 'x'
+ raise 'Unauthorized', 'x'
if sys.version_info < (2, 6):
- self.assertRaises('unauthorized', self.call, None, None, f)
+ self.assertRaises(Unauthorized, self.call, None, None, f)
else:
# Raising a string exception causes a TypeError on Python 2.6
self.assertRaises(TypeError, self.call, None, None, f)
def testStringException2(self):
+ from zExceptions import Redirect
def f():
- raise 'redirect', 'x'
+ raise 'Redirect', 'x'
if sys.version_info < (2, 6):
- self.assertRaises('redirect', self.call, None, None, f)
+ self.assertRaises(Redirect, self.call, None, None, f)
else:
# Raising a string exception causes a TypeError on Python 2.6
self.assertRaises(TypeError, self.call, None, None, f)
More information about the Zope-Checkins
mailing list