]> granicus.if.org Git - python/commitdiff
Issue #22665: Add missing get_terminal_size and SameFileError to shutil.__all__.
authorBerker Peksag <berker.peksag@gmail.com>
Sat, 1 Nov 2014 09:04:06 +0000 (11:04 +0200)
committerBerker Peksag <berker.peksag@gmail.com>
Sat, 1 Nov 2014 09:04:06 +0000 (11:04 +0200)
Lib/shutil.py
Lib/test/test_shutil.py
Misc/NEWS

index 0cd6ec48e1d9c11a1dda55ba5c1630f6264a812f..b5e7cbe3d5daa62be82046b8631d5e4e00c6d93d 100644 (file)
@@ -36,7 +36,8 @@ __all__ = ["copyfileobj", "copyfile", "copymode", "copystat", "copy", "copy2",
            "register_archive_format", "unregister_archive_format",
            "get_unpack_formats", "register_unpack_format",
            "unregister_unpack_format", "unpack_archive",
-           "ignore_patterns", "chown", "which"]
+           "ignore_patterns", "chown", "which", "get_terminal_size",
+           "SameFileError"]
            # disk_usage is added later, if available on the platform
 
 class Error(OSError):
index 66b3fb19572f023e077edf40bad3e20370dba628..c4306da5e4143a6910a87f34c0e89c5fb406334b 100644 (file)
@@ -1762,5 +1762,23 @@ class TermsizeTests(unittest.TestCase):
         self.assertEqual(expected, actual)
 
 
+class PublicAPITests(unittest.TestCase):
+    """Ensures that the correct values are exposed in the public API."""
+
+    def test_module_all_attribute(self):
+        self.assertTrue(hasattr(shutil, '__all__'))
+        target_api = ['copyfileobj', 'copyfile', 'copymode', 'copystat',
+                      'copy', 'copy2', 'copytree', 'move', 'rmtree', 'Error',
+                      'SpecialFileError', 'ExecError', 'make_archive',
+                      'get_archive_formats', 'register_archive_format',
+                      'unregister_archive_format', 'get_unpack_formats',
+                      'register_unpack_format', 'unregister_unpack_format',
+                      'unpack_archive', 'ignore_patterns', 'chown', 'which',
+                      'get_terminal_size', 'SameFileError']
+        if hasattr(os, 'statvfs') or os.name == 'nt':
+            target_api.append('disk_usage')
+        self.assertEqual(set(shutil.__all__), set(target_api))
+
+
 if __name__ == '__main__':
     unittest.main()
index f15ea59a39180c2bed028eadab18083fb072e7c5..9f9155dcf1cff6e69825d80420431224701c19a3 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -33,6 +33,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #22665: Add missing get_terminal_size and SameFileError to
+  shutil.__all__.
+
 - Issue #17381: Fixed handling of case-insensitive ranges in regular
   expressions.