mirror of
https://github.com/python/cpython.git
synced 2024-11-24 18:34:43 +08:00
#17296: backport fix for issue 1692335, naive exception pickling.
This commit is contained in:
parent
5f79409889
commit
1cb0cb2fcd
@ -10,6 +10,15 @@ import errno
|
||||
from test.support import (TESTFN, captured_output, check_impl_detail,
|
||||
cpython_only, gc_collect, run_unittest, unlink)
|
||||
|
||||
class NaiveException(Exception):
|
||||
def __init__(self, x):
|
||||
self.x = x
|
||||
|
||||
class SlottedNaiveException(Exception):
|
||||
__slots__ = ('x',)
|
||||
def __init__(self, x):
|
||||
self.x = x
|
||||
|
||||
# XXX This is not really enough, each *operation* should be tested!
|
||||
|
||||
class ExceptionTests(unittest.TestCase):
|
||||
@ -272,6 +281,10 @@ class ExceptionTests(unittest.TestCase):
|
||||
{'args' : ('\u3042', 0, 1, 'ouch'),
|
||||
'object' : '\u3042', 'reason' : 'ouch',
|
||||
'start' : 0, 'end' : 1}),
|
||||
(NaiveException, ('foo',),
|
||||
{'args': ('foo',), 'x': 'foo'}),
|
||||
(SlottedNaiveException, ('foo',),
|
||||
{'args': ('foo',), 'x': 'foo'}),
|
||||
]
|
||||
try:
|
||||
exceptionList.append(
|
||||
@ -291,7 +304,8 @@ class ExceptionTests(unittest.TestCase):
|
||||
raise
|
||||
else:
|
||||
# Verify module name
|
||||
self.assertEqual(type(e).__module__, 'builtins')
|
||||
if not type(e).__name__.endswith('NaiveException'):
|
||||
self.assertEqual(type(e).__module__, 'builtins')
|
||||
# Verify no ref leaks in Exc_str()
|
||||
s = str(e)
|
||||
for checkArgName in expected:
|
||||
|
@ -10,6 +10,9 @@ What's New in Python 3.2.4
|
||||
Core and Builtins
|
||||
-----------------
|
||||
|
||||
- Issue #1692335: Move initial args assignment to
|
||||
BaseException.__new__ to help pickling of naive subclasses.
|
||||
|
||||
- Issue #17275: Corrected class name in init error messages of the C version of
|
||||
BufferedWriter and BufferedRandom.
|
||||
|
||||
|
@ -29,6 +29,12 @@ BaseException_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||
self->dict = NULL;
|
||||
self->traceback = self->cause = self->context = NULL;
|
||||
|
||||
if (args) {
|
||||
self->args = args;
|
||||
Py_INCREF(args);
|
||||
return (PyObject *)self;
|
||||
}
|
||||
|
||||
self->args = PyTuple_New(0);
|
||||
if (!self->args) {
|
||||
Py_DECREF(self);
|
||||
@ -41,12 +47,15 @@ BaseException_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||
static int
|
||||
BaseException_init(PyBaseExceptionObject *self, PyObject *args, PyObject *kwds)
|
||||
{
|
||||
PyObject *tmp;
|
||||
|
||||
if (!_PyArg_NoKeywords(Py_TYPE(self)->tp_name, kwds))
|
||||
return -1;
|
||||
|
||||
Py_DECREF(self->args);
|
||||
tmp = self->args;
|
||||
self->args = args;
|
||||
Py_INCREF(self->args);
|
||||
Py_XDECREF(tmp);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user