]> granicus.if.org Git - python/commitdiff
Issue 12717: Fix-up an earlier backport in ConfigParser.
authorRaymond Hettinger <python@rcn.com>
Tue, 9 Aug 2011 19:07:15 +0000 (12:07 -0700)
committerRaymond Hettinger <python@rcn.com>
Tue, 9 Aug 2011 19:07:15 +0000 (12:07 -0700)
Lib/ConfigParser.py
Lib/test/test_cfgparser.py

index 6cf3c2ac5d81c2d6a80159cc9cb667ab034eeb1a..963a4187e489ed68f31ebd5a6fad4af9c61ffba7 100644 (file)
@@ -570,7 +570,7 @@ class _Chainmap(_UserDict.DictMixin):
     def keys(self):
         result = []
         seen = set()
-        for mapping in self_maps:
+        for mapping in self._maps:
             for key in mapping:
                 if key not in seen:
                     result.append(key)
index d44a415f12fa1fe02867472e2331e6a79c5c4f1e..4885c8c6499e170138e4ff8a884e4d03aca0495b 100644 (file)
@@ -529,6 +529,27 @@ class SafeConfigParserTestCase(ConfigParserTestCase):
 class SafeConfigParserTestCaseNoValue(SafeConfigParserTestCase):
     allow_no_value = True
 
+class TestChainMap(unittest.TestCase):
+    def test_issue_12717(self):
+        d1 = dict(red=1, green=2)
+        d2 = dict(green=3, blue=4)
+        dcomb = d2.copy()
+        dcomb.update(d1)
+        cm = ConfigParser._Chainmap(d1, d2)
+        self.assertIsInstance(cm.keys(), list)
+        self.assertEqual(set(cm.keys()), set(dcomb.keys()))      # keys()
+        self.assertEqual(set(cm.values()), set(dcomb.values()))  # values()
+        self.assertEqual(set(cm.items()), set(dcomb.items()))    # items()
+        self.assertEqual(set(cm), set(dcomb))                    # __iter__ ()
+        self.assertEqual(cm, dcomb)                              # __eq__()
+        self.assertEqual([cm[k] for k in dcomb], dcomb.values()) # __getitem__()
+        klist = 'red green blue black brown'.split()
+        self.assertEqual([cm.get(k, 10) for k in klist],
+                         [dcomb.get(k, 10) for k in klist])      # get()
+        self.assertEqual([k in cm for k in klist],
+                         [k in dcomb for k in klist])            # __contains__()
+        self.assertEqual([cm.has_key(k) for k in klist],
+                         [dcomb.has_key(k) for k in klist])      # has_key()
 
 class Issue7005TestCase(unittest.TestCase):
     """Test output when None is set() as a value and allow_no_value == False.
@@ -591,6 +612,7 @@ def test_main():
         SafeConfigParserTestCaseNoValue,
         SortedTestCase,
         Issue7005TestCase,
+        TestChainMap,
         )