From e9a5a549e41fee42bdcab34024d52fdf0620948c Mon Sep 17 00:00:00 2001 From: Mark Dickinson Date: Tue, 6 Apr 2010 15:19:40 +0000 Subject: [PATCH] Fix incorrect stacklevel for struct warnings. (Partial backport of r78690). --- Lib/test/test_struct.py | 24 ++++++++++++++++++++++++ Modules/_struct.c | 12 ++++++------ 2 files changed, 30 insertions(+), 6 deletions(-) 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, '