merge default
This commit is contained in:
commit
ee354eabc9
|
@ -42,6 +42,19 @@ class TestTemplate(unittest.TestCase):
|
||||||
s = Template('$who likes $$')
|
s = Template('$who likes $$')
|
||||||
eq(s.substitute(dict(who='tim', what='ham')), 'tim likes $')
|
eq(s.substitute(dict(who='tim', what='ham')), 'tim likes $')
|
||||||
|
|
||||||
|
def test_invalid(self):
|
||||||
|
class MyPattern(Template):
|
||||||
|
pattern = r"""
|
||||||
|
(?:
|
||||||
|
(?P<invalid>) |
|
||||||
|
(?P<escaped>%(delim)s) |
|
||||||
|
@(?P<named>%(id)s) |
|
||||||
|
@{(?P<braced>%(id)s)}
|
||||||
|
)
|
||||||
|
"""
|
||||||
|
s = MyPattern('$')
|
||||||
|
self.assertRaises(ValueError, s.substitute, dict())
|
||||||
|
|
||||||
def test_percents(self):
|
def test_percents(self):
|
||||||
eq = self.assertEqual
|
eq = self.assertEqual
|
||||||
s = Template('%(foo)s $foo ${foo}')
|
s = Template('%(foo)s $foo ${foo}')
|
||||||
|
|
|
@ -112,6 +112,30 @@ class ModuleTest(unittest.TestCase):
|
||||||
self.assertRaises(ValueError, fmt.format, "{0}", 10, 20, i=100)
|
self.assertRaises(ValueError, fmt.format, "{0}", 10, 20, i=100)
|
||||||
self.assertRaises(ValueError, fmt.format, "{i}", 10, 20, i=100)
|
self.assertRaises(ValueError, fmt.format, "{i}", 10, 20, i=100)
|
||||||
|
|
||||||
|
def test_vformat_assert(self):
|
||||||
|
cls = string.Formatter()
|
||||||
|
kwargs = {
|
||||||
|
"i": 100
|
||||||
|
}
|
||||||
|
self.assertRaises(ValueError, cls._vformat,
|
||||||
|
cls.format, "{0}", kwargs, set(), -2)
|
||||||
|
|
||||||
|
def test_convert_field(self):
|
||||||
|
cls = string.Formatter()
|
||||||
|
self.assertEqual(cls.format("{0!s}", 'foo'), 'foo')
|
||||||
|
self.assertRaises(ValueError, cls.format, "{0!h}", 'foo')
|
||||||
|
|
||||||
|
def test_get_field(self):
|
||||||
|
cls = string.Formatter()
|
||||||
|
class MyClass:
|
||||||
|
name = 'lumberjack'
|
||||||
|
x = MyClass()
|
||||||
|
self.assertEqual(cls.format("{0.name}", x), 'lumberjack')
|
||||||
|
|
||||||
|
lookup = ["eggs", "and", "spam"]
|
||||||
|
self.assertEqual(cls.format("{0[2]}", lookup), 'spam')
|
||||||
|
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
support.run_unittest(ModuleTest)
|
support.run_unittest(ModuleTest)
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,7 @@ Oliver Andrich
|
||||||
Ross Andrus
|
Ross Andrus
|
||||||
Jon Anglin
|
Jon Anglin
|
||||||
Éric Araujo
|
Éric Araujo
|
||||||
|
Alicia Arlen
|
||||||
Jason Asbahr
|
Jason Asbahr
|
||||||
David Ascher
|
David Ascher
|
||||||
Chris AtLee
|
Chris AtLee
|
||||||
|
|
|
@ -203,6 +203,8 @@ Tools/Demos
|
||||||
Tests
|
Tests
|
||||||
-----
|
-----
|
||||||
|
|
||||||
|
- Issue #11505: improves test coverage of string.py
|
||||||
|
|
||||||
- Issue #11490: test_subprocess:test_leaking_fds_on_error no longer gives a
|
- Issue #11490: test_subprocess:test_leaking_fds_on_error no longer gives a
|
||||||
false positive if the last directory in the path is inaccessible.
|
false positive if the last directory in the path is inaccessible.
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue