summaryrefslogtreecommitdiff
path: root/Lib/test
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2002-10-25 21:52:00 +0000
committerFred Drake <fdrake@acm.org>2002-10-25 21:52:00 +0000
commit0eebd5cef982686b9438b35d4c4ed395f437ff3e (patch)
tree49c7affd13defeba3e18990e2a9818fd83482aee /Lib/test
parent98e3b29b5969b7738c4c2e1e21fea47357ea6aa0 (diff)
downloadcpython-git-0eebd5cef982686b9438b35d4c4ed395f437ff3e.tar.gz
Implement a safer and more predictable interpolation approach.
Closes SF bug #511737.
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_cfgparser.py17
1 files changed, 16 insertions, 1 deletions
diff --git a/Lib/test/test_cfgparser.py b/Lib/test/test_cfgparser.py
index 6d93c61227..b221598229 100644
--- a/Lib/test/test_cfgparser.py
+++ b/Lib/test/test_cfgparser.py
@@ -289,10 +289,25 @@ class RawConfigParserTestCase(TestCaseBase):
('name', 'value')])
+class SafeConfigParserTestCase(ConfigParserTestCase):
+ config_class = ConfigParser.SafeConfigParser
+
+ def test_safe_interpolation(self):
+ # See http://www.python.org/sf/511737
+ cf = self.fromstring("[section]\n"
+ "option1=xxx\n"
+ "option2=%(option1)s/xxx\n"
+ "ok=%(option1)s/%%s\n"
+ "not_ok=%(option2)s/%%s")
+ self.assertEqual(cf.get("section", "ok"), "xxx/%s")
+ self.assertEqual(cf.get("section", "not_ok"), "xxx/xxx/%s")
+
+
def test_main():
suite = unittest.TestSuite()
suite.addTests([unittest.makeSuite(ConfigParserTestCase),
- unittest.makeSuite(RawConfigParserTestCase)])
+ unittest.makeSuite(RawConfigParserTestCase),
+ unittest.makeSuite(SafeConfigParserTestCase)])
test_support.run_suite(suite)
if __name__ == "__main__":