diff options
author | Eric Smith <eric@trueblade.com> | 2010-04-02 12:30:56 +0000 |
---|---|---|
committer | Eric Smith <eric@trueblade.com> | 2010-04-02 12:30:56 +0000 |
commit | d44b2fc87c2d9bd9e390eb54d50306959d80ba87 (patch) | |
tree | b5eb61ba3a600821c69f87bf1b73562a698f8a18 /Lib/test/test_builtin.py | |
parent | 3b958e3b575dec4691419dc6488bb7be86afb409 (diff) | |
download | cpython-git-d44b2fc87c2d9bd9e390eb54d50306959d80ba87.tar.gz |
Issue 7994: Make object.__format__ with a non-empty format string a PendingDecprecationWarning. Still need to remove uses of this from various tests.
Diffstat (limited to 'Lib/test/test_builtin.py')
-rw-r--r-- | Lib/test/test_builtin.py | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/Lib/test/test_builtin.py b/Lib/test/test_builtin.py index 05686b9119..013731ceac 100644 --- a/Lib/test/test_builtin.py +++ b/Lib/test/test_builtin.py @@ -4,6 +4,7 @@ import platform import unittest from test.test_support import fcmp, have_unicode, TESTFN, unlink, \ run_unittest, check_py3k_warnings +import warnings from operator import neg import sys, cStringIO, random, UserDict @@ -1483,6 +1484,41 @@ class BuiltinTest(unittest.TestCase): self.assertRaises(TypeError, object().__format__, object()) self.assertRaises(TypeError, object().__format__, None) + # -------------------------------------------------------------------- + # Issue #7994: object.__format__ with a non-empty format string is + # pending deprecated + def test_deprecated_format_string(obj, fmt_str, should_raise_warning): + with warnings.catch_warnings(record=True) as w: + warnings.simplefilter("always", PendingDeprecationWarning) + format(obj, fmt_str) + if should_raise_warning: + self.assertEqual(len(w), 1) + self.assertIsInstance(w[0].message, PendingDeprecationWarning) + self.assertIn('object.__format__ with a non-empty format ' + 'string', str(w[0].message)) + else: + self.assertEqual(len(w), 0) + + fmt_strs = ['', 's', u'', u's'] + + class A: + def __format__(self, fmt_str): + return format('', fmt_str) + + for fmt_str in fmt_strs: + test_deprecated_format_string(A(), fmt_str, False) + + class B: + pass + + class C(object): + pass + + for cls in [object, B, C]: + for fmt_str in fmt_strs: + test_deprecated_format_string(cls(), fmt_str, len(fmt_str) != 0) + # -------------------------------------------------------------------- + # make sure we can take a subclass of str as a format spec class DerivedFromStr(str): pass self.assertEqual(format(0, DerivedFromStr('10')), ' 0') |