From: Mark Dickinson Date: Tue, 6 Apr 2010 15:19:40 +0000 (+0000) Subject: Fix incorrect stacklevel for struct warnings. (Partial backport of r78690). X-Git-Tag: v2.6.6rc1~477 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e9a5a549e41fee42bdcab34024d52fdf0620948c;p=python Fix incorrect stacklevel for struct warnings. (Partial backport of r78690). --- diff --git a/Lib/test/test_struct.py b/Lib/test/test_struct.py index cda7dee6cd..ad754df51a 100644 --- a/Lib/test/test_struct.py +++ b/Lib/test/test_struct.py @@ -2,6 +2,7 @@ import array import unittest import struct import warnings +import inspect warnings.filterwarnings("ignore", "struct integer overflow masking is deprecated", DeprecationWarning) @@ -106,6 +107,29 @@ class StructTest(unittest.TestCase): self.assertRaises(struct.error, struct.unpack, 'iii', s) self.assertRaises(struct.error, struct.unpack, 'i', s) + def test_warnings_stacklevel(self): + # Python versions between 2.6 and 2.6.5 were producing + # warning messages at the wrong stacklevel. + def inner(fn, *args): + return inspect.currentframe().f_lineno, fn(*args) + + def check_warning_stacklevel(fn, *args): + with warnings.catch_warnings(record=True) as w: + # "always" to make sure __warningregistry__ isn't affected + warnings.simplefilter("always") + lineno, result = inner(fn, *args) + for warn in w: + self.assertEqual(warn.lineno, lineno) + + # out of range warnings + check_warning_stacklevel(struct.pack, '