summaryrefslogtreecommitdiff
path: root/Lib/test/test_os.py
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-04-14 16:38:35 +0200
committerVictor Stinner <victor.stinner@gmail.com>2013-04-14 16:38:35 +0200
commitcc8baed8fd212f965cea48f39a169f28c5a4a636 (patch)
tree39bd8831a28812da9c6b2fe65777e02ffd4c7fdc /Lib/test/test_os.py
parent56d291705741ab97b77c7d804da162d964de69a6 (diff)
parentbd5e8cbe637b30b734684d2e5bead59855410d25 (diff)
downloadcpython-cc8baed8fd212f965cea48f39a169f28c5a4a636.tar.gz
(Merge 3.3) Close #17702: os.environ now raises KeyError with the original
environment variable name (str on UNIX), instead of using the encoded name (bytes on UNIX).
Diffstat (limited to 'Lib/test/test_os.py')
-rw-r--r--Lib/test/test_os.py18
1 files changed, 18 insertions, 0 deletions
diff --git a/Lib/test/test_os.py b/Lib/test/test_os.py
index 32a67e57c1..e6aae5c6ef 100644
--- a/Lib/test/test_os.py
+++ b/Lib/test/test_os.py
@@ -632,6 +632,24 @@ class EnvironTests(mapping_tests.BasicTestMappingProtocol):
key = 'key='
self.assertRaises(OSError, os.environ.__delitem__, key)
+ def test_key_type(self):
+ missing = 'missingkey'
+ self.assertNotIn(missing, os.environ)
+
+ try:
+ os.environ[missing]
+ except KeyError as err:
+ self.assertIs(err.args[0], missing)
+ else:
+ self.fail("KeyError not raised")
+
+ try:
+ del os.environ[missing]
+ except KeyError as err:
+ self.assertIs(err.args[0], missing)
+ else:
+ self.fail("KeyError not raised")
+
class WalkTests(unittest.TestCase):
"""Tests for os.walk()."""