summaryrefslogtreecommitdiff
path: root/Lib/test
diff options
context:
space:
mode:
authorEddie Elizondo <eelizondo@fb.com>2019-11-05 07:16:14 -0800
committerMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2019-11-05 07:16:14 -0800
commitb3966639d28313809774ca3859a347b9007be8d2 (patch)
tree9724c4c0efe096bb5a58fa7eabbf176deb656d90 /Lib/test
parent5e01a6542a1beb552a17e16b71dc0ba9fc6adcfb (diff)
downloadcpython-git-b3966639d28313809774ca3859a347b9007be8d2.tar.gz
bpo-35381 Remove all static state from posixmodule (GH-15892)
After #9665, this moves the remaining types in posixmodule to be heap-allocated to make it compatible with PEP384 as well as modifying all the type accessors to fully make the type opaque. The original PR that got messed up a rebase: https://github.com/python/cpython/pull/10854. All the issues in that commit have now been addressed since https://github.com/python/cpython/pull/11661 got committed. This change also removes any state from the data segment and onto the module state itself. https://bugs.python.org/issue35381 Automerge-Triggered-By: @encukou
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_os.py30
1 files changed, 30 insertions, 0 deletions
diff --git a/Lib/test/test_os.py b/Lib/test/test_os.py
index d2bd9c2f23..bf40cb1e8f 100644
--- a/Lib/test/test_os.py
+++ b/Lib/test/test_os.py
@@ -3638,6 +3638,24 @@ class ExportsTests(unittest.TestCase):
self.assertIn('walk', os.__all__)
+class TestDirEntry(unittest.TestCase):
+ def setUp(self):
+ self.path = os.path.realpath(support.TESTFN)
+ self.addCleanup(support.rmtree, self.path)
+ os.mkdir(self.path)
+
+ def test_uninstantiable(self):
+ self.assertRaises(TypeError, os.DirEntry)
+
+ def test_unpickable(self):
+ filename = create_file(os.path.join(self.path, "file.txt"), b'python')
+ entry = [entry for entry in os.scandir(self.path)].pop()
+ self.assertIsInstance(entry, os.DirEntry)
+ self.assertEqual(entry.name, "file.txt")
+ import pickle
+ self.assertRaises(TypeError, pickle.dumps, entry, filename)
+
+
class TestScandir(unittest.TestCase):
check_no_resource_warning = support.check_no_resource_warning
@@ -3672,6 +3690,18 @@ class TestScandir(unittest.TestCase):
else:
self.assertEqual(stat1, stat2)
+ def test_uninstantiable(self):
+ scandir_iter = os.scandir(self.path)
+ self.assertRaises(TypeError, type(scandir_iter))
+ scandir_iter.close()
+
+ def test_unpickable(self):
+ filename = self.create_file("file.txt")
+ scandir_iter = os.scandir(self.path)
+ import pickle
+ self.assertRaises(TypeError, pickle.dumps, scandir_iter, filename)
+ scandir_iter.close()
+
def check_entry(self, entry, name, is_dir, is_file, is_symlink):
self.assertIsInstance(entry, os.DirEntry)
self.assertEqual(entry.name, name)