[Python-bugs-list] [ python-Bugs-504723 ] Bad exceptions from pickle
noreply@sourceforge.net
noreply@sourceforge.net
Fri, 22 Mar 2002 14:18:14 -0800
Bugs item #504723, was opened at 2002-01-17 03:55
You can respond by visiting:
http://sourceforge.net/tracker/?func=detail&atid=105470&aid=504723&group_id=5470
Category: Python Library
Group: Python 2.2
>Status: Closed
>Resolution: Invalid
Priority: 5
Submitted By: Bob Alexander (bobalex)
Assigned to: Nobody/Anonymous (nobody)
Summary: Bad exceptions from pickle
Initial Comment:
Here is an annotated session that shows some incorrect
exceptions raised with bad input. I'm assuming that it
is intended that when attempting to load a pickle file,
we should only have to check for UnpicklingError, not
for several other possible exceptions.
>>> import sys
>>> sys.version
'2.2 (#1, Dec 26 2001, 16:14:13) \n[GCC 2.96 20000731
(Mandrake Linux 8.1 2.96-0.62mdk)]'
Problem 1: Attempting to load an empty file produces an
EOFError exception, but should probably produce an
UnpicklingError exception. This happens with both
pickle and cPickle.
>>> import cPickle as pickle
>>> import pickle as pk
>>> f=open("/dev/null") # Empty file
>>> ff=StringIO("asdfasdfasdfasdfasdfasdf") # Garbage
file
>>> pickle.load(f)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
EOFError
>>> pk.load(f)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "/usr/lib/python2.2/pickle.py", line 977, in
load
return Unpickler(file).load()
File "/usr/lib/python2.2/pickle.py", line 592, in
load
dispatch[key](self)
File "/usr/lib/python2.2/pickle.py", line 606, in
load_eof
raise EOFError
EOFError
Problem 2: With cPickle, loading a garbage file
produced and IndexError, not an Unpickling error.
>>> pk.load(ff)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "/usr/lib/python2.2/pickle.py", line 977, in
load
return Unpickler(file).load()
File "/usr/lib/python2.2/pickle.py", line 592, in
load
dispatch[key](self)
File "/usr/lib/python2.2/pickle.py", line 746, in
load_dict
k = self.marker()
File "/usr/lib/python2.2/pickle.py", line 600, in
marker
while stack[k] is not mark: k = k-1
IndexError: list index out of range
----------------------------------------------------------------------
>Comment By: Neil Schemenauer (nascheme)
Date: 2002-03-22 22:18
Message:
Logged In: YES
user_id=35752
I added IndexError and EOFError to the list of example
exceptions that unpickle can raise. Closing this bug.
----------------------------------------------------------------------
Comment By: Thomas W. Christopger (tchristopher)
Date: 2002-02-26 15:59
Message:
Logged In: YES
user_id=64169
Actually, I want EOFError on the file-like object
returning ''; the empty string IS an end of file
indication. That's what I'm looking for when there are a
varying number of objects, and yes, I use it a lot.
So please DO NOT make end of file return an UnpicklingError.
----------------------------------------------------------------------
Comment By: Martin v. Löwis (loewis)
Date: 2002-01-17 07:41
Message:
Logged In: YES
user_id=21627
The documentation of UnpicklingError says
Note that other exceptions may also be raised during
unpickling, including (but not necessarily limited to)
\exception{AttributeError} and \exception{ImportError}.
So I'm not so sure that there is a bug.
----------------------------------------------------------------------
You can respond by visiting:
http://sourceforge.net/tracker/?func=detail&atid=105470&aid=504723&group_id=5470