summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Lib/dumbdbm.py11
-rw-r--r--Lib/test/test_dumbdbm.py16
2 files changed, 21 insertions, 6 deletions
diff --git a/Lib/dumbdbm.py b/Lib/dumbdbm.py
index 9e9ffcc..2c7931d 100644
--- a/Lib/dumbdbm.py
+++ b/Lib/dumbdbm.py
@@ -236,4 +236,15 @@ def open(file, flag=None, mode=0666):
"""
# flag argument is currently ignored
+
+ # Modify mode depending on the umask
+ try:
+ um = _os.umask(0)
+ _os.umask(um)
+ except AttributeError:
+ pass
+ else:
+ # Turn off any bits that are set in the umask
+ mode = mode & (~um)
+
return _Database(file, mode)
diff --git a/Lib/test/test_dumbdbm.py b/Lib/test/test_dumbdbm.py
index a1e34da..e5dfe1d 100644
--- a/Lib/test/test_dumbdbm.py
+++ b/Lib/test/test_dumbdbm.py
@@ -40,17 +40,21 @@ class DumbDBMTestCase(unittest.TestCase):
def test_dumbdbm_creation_mode(self):
# On platforms without chmod, don't do anything.
- if not hasattr(os, 'chmod'):
+ if not (hasattr(os, 'chmod') and hasattr(os, 'umask')):
return
- f = dumbdbm.open(_fname, 'c', 0632)
- f.close()
-
+ try:
+ old_umask = os.umask(0002)
+ f = dumbdbm.open(_fname, 'c', 0637)
+ f.close()
+ finally:
+ os.umask(old_umask)
+
import stat
st = os.stat(_fname + '.dat')
- self.assertEqual(stat.S_IMODE(st.st_mode), 0632)
+ self.assertEqual(stat.S_IMODE(st.st_mode), 0635)
st = os.stat(_fname + '.dir')
- self.assertEqual(stat.S_IMODE(st.st_mode), 0632)
+ self.assertEqual(stat.S_IMODE(st.st_mode), 0635)
def test_close_twice(self):
f = dumbdbm.open(_fname)