diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2015-02-10 06:45:53 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2015-02-10 06:45:53 (GMT) |
commit | 832dd5f0d65d3a0ebd7d7c7a3a4c80ab5170cd08 (patch) | |
tree | 8fa7e8aae8445c058cc8fa1e8408fb9502c1a15e /Lib | |
parent | 22ef9f722e6aa138d047625dd845c9a101c4454d (diff) | |
download | cpython-832dd5f0d65d3a0ebd7d7c7a3a4c80ab5170cd08.zip cpython-832dd5f0d65d3a0ebd7d7c7a3a4c80ab5170cd08.tar.gz cpython-832dd5f0d65d3a0ebd7d7c7a3a4c80ab5170cd08.tar.bz2 |
Issue #23421: Fixed compression in tarfile CLI. Patch by wdv4758h.
Diffstat (limited to 'Lib')
-rwxr-xr-x | Lib/tarfile.py | 16 | ||||
-rw-r--r-- | Lib/test/test_tarfile.py | 15 |
2 files changed, 23 insertions, 8 deletions
diff --git a/Lib/tarfile.py b/Lib/tarfile.py index 9e291c2..37e4dcd 100755 --- a/Lib/tarfile.py +++ b/Lib/tarfile.py @@ -2491,16 +2491,16 @@ def main(): _, ext = os.path.splitext(tar_name) compressions = { # gz - 'gz': 'gz', - 'tgz': 'gz', + '.gz': 'gz', + '.tgz': 'gz', # xz - 'xz': 'xz', - 'txz': 'xz', + '.xz': 'xz', + '.txz': 'xz', # bz2 - 'bz2': 'bz2', - 'tbz': 'bz2', - 'tbz2': 'bz2', - 'tb2': 'bz2', + '.bz2': 'bz2', + '.tbz': 'bz2', + '.tbz2': 'bz2', + '.tb2': 'bz2', } tar_mode = 'w:' + compressions[ext] if ext in compressions else 'w' tar_files = args.create diff --git a/Lib/test/test_tarfile.py b/Lib/test/test_tarfile.py index e527e40..c135304 100644 --- a/Lib/test/test_tarfile.py +++ b/Lib/test/test_tarfile.py @@ -1994,6 +1994,21 @@ class CommandLineTest(unittest.TestCase): finally: support.unlink(tar_name) + def test_create_command_compressed(self): + files = [support.findfile('tokenize_tests.txt'), + support.findfile('tokenize_tests-no-coding-cookie-' + 'and-utf8-bom-sig-only.txt')] + for filetype in (GzipTest, Bz2Test, LzmaTest): + if not filetype.open: + continue + try: + tar_name = tmpname + '.' + filetype.suffix + out = self.tarfilecmd('-c', tar_name, *files) + with filetype.taropen(tar_name) as tar: + tar.getmembers() + finally: + support.unlink(tar_name) + def test_extract_command(self): self.make_simple_tarfile(tmpname) for opt in '-e', '--extract': |