New submission from Stefan M <mstefa...@gmail.com>:

After issue7455 was fixed, a test was created to reflect the fix 
(Lib/test/pickletester.py @ AbstractPickleModuleTests.test_bad_input). The test 
makes sure that an UnpicklingError is raised whenever pickled data attempts to 
pop on an empty stack.
Although tests on AbstractPickleModuleTests normally only run on the C 
implementation of pickle (on which UnpicklingError is thrown), they may also 
run on the Python implementation if the C implementation of pickle is not 
available (which throws IndexError). I'm not sure if it's still reasonable to 
assume that it's possible for the C implementation of pickle not to exist (the 
python module does), as I've discovered this by forcefully disabling the C 
implementation.

>>> pickle.Unpickler(io.BytesIO(b'0')).load()
_pickle.UnpicklingError: unpickling stack underflow

>>> pickle._Unpickler(io.BytesIO(b'0')).load()
IndexError: list assignment index out of range

The current fix involves adding IndexError to the list of exceptions that may 
be raised and moving the testcase to AbstractPickleTests (where the tests are 
ran against both the C and Python impl).

As I'm working on improving pickle in protocol v4, it might be worth 
considering adding more consistency to the exceptions that are being raised by 
the Python unpickler.

----------
components: Tests
files: pickletester.py.patch
keywords: patch
messages: 162919
nosy: alexandre.vassalotti, collinwinter, mstefanro
priority: normal
severity: normal
status: open
title: pickle: Possibly misplaced test
type: behavior
versions: Python 3.4
Added file: http://bugs.python.org/file26019/pickletester.py.patch

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue15079>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
http://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to