merge default

This commit is contained in:
Michael Foord 2011-03-14 19:03:30 -04:00
commit ee354eabc9
4 changed files with 40 additions and 0 deletions

View File

@ -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}')

View File

@ -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)

View File

@ -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

View File

@ -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.