mirror of
https://github.com/python/cpython.git
synced 2025-07-25 12:14:38 +00:00

svn+ssh://pythondev@svn.python.org/python/trunk ........ r57155 | brett.cannon | 2007-08-17 11:51:57 -0700 (Fri, 17 Aug 2007) | 2 lines Clarify the comment about setting the PYTHON variable for the Doc Makefile. ........ r57156 | brett.cannon | 2007-08-17 11:59:58 -0700 (Fri, 17 Aug 2007) | 3 lines Remove news entry for test.test_support.guard_warnings_filter as it has been removed. ........ r57158 | facundo.batista | 2007-08-17 12:16:44 -0700 (Fri, 17 Aug 2007) | 9 lines Added a flag (_send_traceback_header) to the SimpleXMLRPCServer class that allows sending back exception/stack trace information about internal server errors (this flag defaults to False to avoid sending such information unless explicitly enabled). Added tests to verify behavior of this new feature (these tests are skipped on win32 because of problems with WSAEWOULDBLOCK). Renamed HTTPTestCase to SimpleServerTestCase. [GSoC - Alan McIntyre] ........ r57160 | brett.cannon | 2007-08-17 13:16:15 -0700 (Fri, 17 Aug 2007) | 2 lines Make test_warnings re-entrant. ........ r57175 | georg.brandl | 2007-08-17 23:05:56 -0700 (Fri, 17 Aug 2007) | 2 lines Fix PDB command descriptions. ........ r57182 | brett.cannon | 2007-08-18 11:30:36 -0700 (Sat, 18 Aug 2007) | 3 lines Remove Mikael as the maintainer of BeOS at his request. With no maintainer should the port be deprecated in 2.6? ........ r57199 | georg.brandl | 2007-08-19 11:43:50 -0700 (Sun, 19 Aug 2007) | 2 lines Fix stray backticks. ........ r57211 | hyeshik.chang | 2007-08-19 23:49:18 -0700 (Sun, 19 Aug 2007) | 2 lines Add cheot-ga-keut composed make-up sequence support in EUC-KR codec. ........ r57216 | guido.van.rossum | 2007-08-20 08:18:04 -0700 (Mon, 20 Aug 2007) | 4 lines Add a hack (originally devised in a slightly different form by Thomas Wouters) to prevent spurious tracebacks when a daemon thread's cleanup happens to wake up when the world around it has already been destroyed. ........
112 lines
4.6 KiB
Python
112 lines
4.6 KiB
Python
import warnings
|
|
import os
|
|
import sys
|
|
import unittest
|
|
from test import test_support
|
|
|
|
from test import warning_tests
|
|
|
|
class TestModule(unittest.TestCase):
|
|
def setUp(self):
|
|
self.ignored = [w[2].__name__ for w in warnings.filters
|
|
if w[0]=='ignore' and w[1] is None and w[3] is None]
|
|
|
|
def test_warn_default_category(self):
|
|
with test_support.catch_warning() as w:
|
|
for i in range(4):
|
|
text = 'multi %d' %i # Different text on each call
|
|
warnings.warn(text)
|
|
self.assertEqual(str(w.message), text)
|
|
self.assert_(w.category is UserWarning)
|
|
|
|
def test_warn_specific_category(self):
|
|
with test_support.catch_warning() as w:
|
|
text = 'None'
|
|
for category in [DeprecationWarning, FutureWarning,
|
|
PendingDeprecationWarning, RuntimeWarning,
|
|
SyntaxWarning, UserWarning, Warning]:
|
|
if category.__name__ in self.ignored:
|
|
text = 'filtered out' + category.__name__
|
|
warnings.warn(text, category)
|
|
self.assertNotEqual(w.message, text)
|
|
else:
|
|
text = 'unfiltered %s' % category.__name__
|
|
warnings.warn(text, category)
|
|
self.assertEqual(str(w.message), text)
|
|
self.assert_(w.category is category)
|
|
|
|
def test_filtering(self):
|
|
with test_support.catch_warning() as w:
|
|
warnings.filterwarnings("error", "", Warning, "", 0)
|
|
self.assertRaises(UserWarning, warnings.warn, 'convert to error')
|
|
|
|
warnings.resetwarnings()
|
|
text = 'handle normally'
|
|
warnings.warn(text)
|
|
self.assertEqual(str(w.message), text)
|
|
self.assert_(w.category is UserWarning)
|
|
|
|
warnings.filterwarnings("ignore", "", Warning, "", 0)
|
|
text = 'filtered out'
|
|
warnings.warn(text)
|
|
self.assertNotEqual(str(w.message), text)
|
|
|
|
warnings.resetwarnings()
|
|
warnings.filterwarnings("error", "hex*", Warning, "", 0)
|
|
self.assertRaises(UserWarning, warnings.warn, 'hex/oct')
|
|
text = 'nonmatching text'
|
|
warnings.warn(text)
|
|
self.assertEqual(str(w.message), text)
|
|
self.assert_(w.category is UserWarning)
|
|
|
|
def test_options(self):
|
|
# Uses the private _setoption() function to test the parsing
|
|
# of command-line warning arguments
|
|
with test_support.catch_warning():
|
|
self.assertRaises(warnings._OptionError,
|
|
warnings._setoption, '1:2:3:4:5:6')
|
|
self.assertRaises(warnings._OptionError,
|
|
warnings._setoption, 'bogus::Warning')
|
|
self.assertRaises(warnings._OptionError,
|
|
warnings._setoption, 'ignore:2::4:-5')
|
|
warnings._setoption('error::Warning::0')
|
|
self.assertRaises(UserWarning, warnings.warn, 'convert to error')
|
|
|
|
def test_filename(self):
|
|
with test_support.catch_warning() as w:
|
|
warning_tests.inner("spam1")
|
|
self.assertEqual(os.path.basename(w.filename), "warning_tests.py")
|
|
warning_tests.outer("spam2")
|
|
self.assertEqual(os.path.basename(w.filename), "warning_tests.py")
|
|
|
|
def test_stacklevel(self):
|
|
# Test stacklevel argument
|
|
# make sure all messages are different, so the warning won't be skipped
|
|
with test_support.catch_warning() as w:
|
|
warning_tests.inner("spam3", stacklevel=1)
|
|
self.assertEqual(os.path.basename(w.filename), "warning_tests.py")
|
|
warning_tests.outer("spam4", stacklevel=1)
|
|
self.assertEqual(os.path.basename(w.filename), "warning_tests.py")
|
|
|
|
warning_tests.inner("spam5", stacklevel=2)
|
|
self.assertEqual(os.path.basename(w.filename), "test_warnings.py")
|
|
warning_tests.outer("spam6", stacklevel=2)
|
|
self.assertEqual(os.path.basename(w.filename), "warning_tests.py")
|
|
|
|
warning_tests.inner("spam7", stacklevel=9999)
|
|
self.assertEqual(os.path.basename(w.filename), "sys")
|
|
|
|
|
|
def test_main(verbose=None):
|
|
# Obscure hack so that this test passes after reloads or repeated calls
|
|
# to test_main (regrtest -R).
|
|
if '__warningregistry__' in globals():
|
|
del globals()['__warningregistry__']
|
|
if hasattr(warning_tests, '__warningregistry__'):
|
|
del warning_tests.__warningregistry__
|
|
if hasattr(sys, '__warningregistry__'):
|
|
del sys.__warningregistry__
|
|
test_support.run_unittest(TestModule)
|
|
|
|
if __name__ == "__main__":
|
|
test_main(verbose=True)
|