diff options
author | Łukasz Langa <lukasz@langa.pl> | 2014-09-04 08:36:33 (GMT) |
---|---|---|
committer | Łukasz Langa <lukasz@langa.pl> | 2014-09-04 08:36:33 (GMT) |
commit | 949053bff2c3137f7e2a14213c291ae6bce072b4 (patch) | |
tree | 9caa63aaf5a76bbc89b3bbe74e9d25af2d51fa5b /Lib/test/test_configparser.py | |
parent | f29468118b3c2327034ef36e6efd26f96375aa7b (diff) | |
download | cpython-949053bff2c3137f7e2a14213c291ae6bce072b4.zip cpython-949053bff2c3137f7e2a14213c291ae6bce072b4.tar.gz cpython-949053bff2c3137f7e2a14213c291ae6bce072b4.tar.bz2 |
Fix #19546: onfigparser exceptions expose implementation details. Patch by Claudiu Popa.
Diffstat (limited to 'Lib/test/test_configparser.py')
-rw-r--r-- | Lib/test/test_configparser.py | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/Lib/test/test_configparser.py b/Lib/test/test_configparser.py index 742b12b..b439501 100644 --- a/Lib/test/test_configparser.py +++ b/Lib/test/test_configparser.py @@ -1763,6 +1763,58 @@ class InlineCommentStrippingTestCase(unittest.TestCase): self.assertEqual(s['k2'], 'v2') self.assertEqual(s['k3'], 'v3;#//still v3# and still v3') +class ExceptionContextTestCase(unittest.TestCase): + """ Test that implementation details doesn't leak + through raising exceptions. """ + + def test_get_basic_interpolation(self): + parser = configparser.ConfigParser() + parser.read_string(""" + [Paths] + home_dir: /Users + my_dir: %(home_dir1)s/lumberjack + my_pictures: %(my_dir)s/Pictures + """) + cm = self.assertRaises(configparser.InterpolationMissingOptionError) + with cm: + parser.get('Paths', 'my_dir') + self.assertIs(cm.exception.__suppress_context__, True) + + def test_get_extended_interpolation(self): + parser = configparser.ConfigParser( + interpolation=configparser.ExtendedInterpolation()) + parser.read_string(""" + [Paths] + home_dir: /Users + my_dir: ${home_dir1}/lumberjack + my_pictures: ${my_dir}/Pictures + """) + cm = self.assertRaises(configparser.InterpolationMissingOptionError) + with cm: + parser.get('Paths', 'my_dir') + self.assertIs(cm.exception.__suppress_context__, True) + + def test_missing_options(self): + parser = configparser.ConfigParser() + parser.read_string(""" + [Paths] + home_dir: /Users + """) + with self.assertRaises(configparser.NoSectionError) as cm: + parser.options('test') + self.assertIs(cm.exception.__suppress_context__, True) + + def test_missing_section(self): + config = configparser.ConfigParser() + with self.assertRaises(configparser.NoSectionError) as cm: + config.set('Section1', 'an_int', '15') + self.assertIs(cm.exception.__suppress_context__, True) + + def test_remove_option(self): + config = configparser.ConfigParser() + with self.assertRaises(configparser.NoSectionError) as cm: + config.remove_option('Section1', 'an_int') + self.assertIs(cm.exception.__suppress_context__, True) if __name__ == '__main__': unittest.main() |