Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
setuptools
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Jérome Perrin
setuptools
Commits
8488006f
Commit
8488006f
authored
May 28, 2009
by
Tarek Ziadé
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed #6048: Distutils uses the tarfile module instead of the tar command now
parent
a81606b8
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
146 additions
and
25 deletions
+146
-25
archive_util.py
archive_util.py
+35
-23
tests/test_archive_util.py
tests/test_archive_util.py
+111
-2
No files found.
archive_util.py
View file @
8488006f
...
@@ -6,6 +6,9 @@ that sort of thing)."""
...
@@ -6,6 +6,9 @@ that sort of thing)."""
__revision__
=
"$Id$"
__revision__
=
"$Id$"
import
os
import
os
from
warnings
import
warn
import
sys
from
distutils.errors
import
DistutilsExecError
from
distutils.errors
import
DistutilsExecError
from
distutils.spawn
import
spawn
from
distutils.spawn
import
spawn
from
distutils.dir_util
import
mkpath
from
distutils.dir_util
import
mkpath
...
@@ -22,36 +25,45 @@ def make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0):
...
@@ -22,36 +25,45 @@ def make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0):
the appropriate compression extension (".gz", ".bz2" or ".Z").
the appropriate compression extension (".gz", ".bz2" or ".Z").
Returns the output filename.
Returns the output filename.
"""
"""
# XXX GNU tar 1.13 has a nifty option to add a prefix directory.
tar_compression
=
{
'gzip'
:
'gz'
,
'bzip2'
:
'bz2'
,
None
:
''
,
'compress'
:
''
}
# It's pretty new, though, so we certainly can't require it --
compress_ext
=
{
'gzip'
:
'.gz'
,
'bzip2'
:
'.bz2'
,
'compress'
:
'.Z'
}
# but it would be nice to take advantage of it to skip the
# "create a tree of hardlinks" step! (Would also be nice to
# detect GNU tar to use its 'z' option and save a step.)
compress_ext
=
{
'gzip'
:
".gz"
,
'bzip2'
:
'.bz2'
,
'compress'
:
".Z"
}
# flags for compression program, each element of list will be an argument
# flags for compression program, each element of list will be an argument
compress_flags
=
{
'gzip'
:
[
"-f9"
],
'compress'
:
[
"-f"
],
'bzip2'
:
[
'-f9'
]}
if
compress
is
not
None
and
compress
not
in
compress_ext
.
keys
():
if
compress
is
not
None
and
compress
not
in
compress_ext
.
keys
():
raise
ValueError
,
\
raise
ValueError
,
\
"bad value for 'compress': must be None, 'gzip', or 'compress'"
(
"bad value for 'compress': must be None, 'gzip', 'bzip2' "
"or 'compress'"
)
archive_name
=
base_name
+
'.tar'
if
compress
!=
'compress'
:
archive_name
+=
compress_ext
.
get
(
compress
,
''
)
archive_name
=
base_name
+
".tar"
mkpath
(
os
.
path
.
dirname
(
archive_name
),
dry_run
=
dry_run
)
mkpath
(
os
.
path
.
dirname
(
archive_name
),
dry_run
=
dry_run
)
cmd
=
[
"tar"
,
"-cf"
,
archive_name
,
base_dir
]
spawn
(
cmd
,
dry_run
=
dry_run
)
if
compress
:
# creating the tarball
spawn
([
compress
]
+
compress_flags
[
compress
]
+
[
archive_name
],
import
tarfile
# late import so Python build itself doesn't break
dry_run
=
dry_run
)
return
archive_name
+
compress_ext
[
compress
]
log
.
info
(
'Creating tar archive'
)
else
:
if
not
dry_run
:
return
archive_name
tar
=
tarfile
.
open
(
archive_name
,
'w|%s'
%
tar_compression
[
compress
])
try
:
tar
.
add
(
base_dir
)
finally
:
tar
.
close
()
# compression using `compress`
if
compress
==
'compress'
:
warn
(
"'compress' will be deprecated."
,
PendingDeprecationWarning
)
# the option varies depending on the platform
compressed_name
=
archive_name
+
compress_ext
[
compress
]
if
sys
.
platform
==
'win32'
:
cmd
=
[
compress
,
archive_name
,
compressed_name
]
else
:
cmd
=
[
compress
,
'-f'
,
archive_name
]
spawn
(
cmd
,
dry_run
=
dry_run
)
return
compressed_name
return
archive_name
def
make_zipfile
(
base_name
,
base_dir
,
verbose
=
0
,
dry_run
=
0
):
def
make_zipfile
(
base_name
,
base_dir
,
verbose
=
0
,
dry_run
=
0
):
"""Create a zip file from all the files under 'base_dir'.
"""Create a zip file from all the files under 'base_dir'.
...
...
tests/test_archive_util.py
View file @
8488006f
...
@@ -3,12 +3,15 @@ __revision__ = "$Id$"
...
@@ -3,12 +3,15 @@ __revision__ = "$Id$"
import
unittest
import
unittest
import
os
import
os
import
tarfile
from
os.path
import
splitdrive
from
os.path
import
splitdrive
import
warnings
from
distutils.archive_util
import
(
check_archive_formats
,
make_tarball
,
from
distutils.archive_util
import
(
check_archive_formats
,
make_tarball
,
make_zipfile
,
make_archive
)
make_zipfile
,
make_archive
)
from
distutils.spawn
import
find_executable
from
distutils.spawn
import
find_executable
,
spawn
from
distutils.tests
import
support
from
distutils.tests
import
support
from
test.test_support
import
check_warnings
try
:
try
:
import
zipfile
import
zipfile
...
@@ -19,12 +22,13 @@ except ImportError:
...
@@ -19,12 +22,13 @@ except ImportError:
class
ArchiveUtilTestCase
(
support
.
TempdirManager
,
class
ArchiveUtilTestCase
(
support
.
TempdirManager
,
unittest
.
TestCase
):
unittest
.
TestCase
):
@
unittest
.
skipUnless
(
find_executable
(
'tar'
),
'Need the tar command to run'
)
def
test_make_tarball
(
self
):
def
test_make_tarball
(
self
):
# creating something to tar
# creating something to tar
tmpdir
=
self
.
mkdtemp
()
tmpdir
=
self
.
mkdtemp
()
self
.
write_file
([
tmpdir
,
'file1'
],
'xxx'
)
self
.
write_file
([
tmpdir
,
'file1'
],
'xxx'
)
self
.
write_file
([
tmpdir
,
'file2'
],
'xxx'
)
self
.
write_file
([
tmpdir
,
'file2'
],
'xxx'
)
os
.
mkdir
(
os
.
path
.
join
(
tmpdir
,
'sub'
))
self
.
write_file
([
tmpdir
,
'sub'
,
'file3'
],
'xxx'
)
tmpdir2
=
self
.
mkdtemp
()
tmpdir2
=
self
.
mkdtemp
()
unittest
.
skipUnless
(
splitdrive
(
tmpdir
)[
0
]
==
splitdrive
(
tmpdir2
)[
0
],
unittest
.
skipUnless
(
splitdrive
(
tmpdir
)[
0
]
==
splitdrive
(
tmpdir2
)[
0
],
...
@@ -55,6 +59,111 @@ class ArchiveUtilTestCase(support.TempdirManager,
...
@@ -55,6 +59,111 @@ class ArchiveUtilTestCase(support.TempdirManager,
tarball
=
base_name
+
'.tar'
tarball
=
base_name
+
'.tar'
self
.
assert_
(
os
.
path
.
exists
(
tarball
))
self
.
assert_
(
os
.
path
.
exists
(
tarball
))
def
_tarinfo
(
self
,
path
):
tar
=
tarfile
.
open
(
path
)
try
:
names
=
tar
.
getnames
()
names
.
sort
()
return
tuple
(
names
)
finally
:
tar
.
close
()
def
_create_files
(
self
):
# creating something to tar
tmpdir
=
self
.
mkdtemp
()
dist
=
os
.
path
.
join
(
tmpdir
,
'dist'
)
os
.
mkdir
(
dist
)
self
.
write_file
([
dist
,
'file1'
],
'xxx'
)
self
.
write_file
([
dist
,
'file2'
],
'xxx'
)
os
.
mkdir
(
os
.
path
.
join
(
dist
,
'sub'
))
self
.
write_file
([
dist
,
'sub'
,
'file3'
],
'xxx'
)
os
.
mkdir
(
os
.
path
.
join
(
dist
,
'sub2'
))
tmpdir2
=
self
.
mkdtemp
()
base_name
=
os
.
path
.
join
(
tmpdir2
,
'archive'
)
return
tmpdir
,
tmpdir2
,
base_name
@
unittest
.
skipUnless
(
find_executable
(
'tar'
),
'Need the tar command to run'
)
def
test_tarfile_vs_tar
(
self
):
tmpdir
,
tmpdir2
,
base_name
=
self
.
_create_files
()
old_dir
=
os
.
getcwd
()
os
.
chdir
(
tmpdir
)
try
:
make_tarball
(
base_name
,
'dist'
)
finally
:
os
.
chdir
(
old_dir
)
# check if the compressed tarball was created
tarball
=
base_name
+
'.tar.gz'
self
.
assert_
(
os
.
path
.
exists
(
tarball
))
# now create another tarball using `tar`
tarball2
=
os
.
path
.
join
(
tmpdir
,
'archive2.tar.gz'
)
cmd
=
[
'tar'
,
'-czf'
,
'archive2.tar.gz'
,
'dist'
]
old_dir
=
os
.
getcwd
()
os
.
chdir
(
tmpdir
)
try
:
spawn
(
cmd
)
finally
:
os
.
chdir
(
old_dir
)
self
.
assert_
(
os
.
path
.
exists
(
tarball2
))
# let's compare both tarballs
self
.
assertEquals
(
self
.
_tarinfo
(
tarball
),
self
.
_tarinfo
(
tarball2
))
# trying an uncompressed one
base_name
=
os
.
path
.
join
(
tmpdir2
,
'archive'
)
old_dir
=
os
.
getcwd
()
os
.
chdir
(
tmpdir
)
try
:
make_tarball
(
base_name
,
'dist'
,
compress
=
None
)
finally
:
os
.
chdir
(
old_dir
)
tarball
=
base_name
+
'.tar'
self
.
assert_
(
os
.
path
.
exists
(
tarball
))
# now for a dry_run
base_name
=
os
.
path
.
join
(
tmpdir2
,
'archive'
)
old_dir
=
os
.
getcwd
()
os
.
chdir
(
tmpdir
)
try
:
make_tarball
(
base_name
,
'dist'
,
compress
=
None
,
dry_run
=
True
)
finally
:
os
.
chdir
(
old_dir
)
tarball
=
base_name
+
'.tar'
self
.
assert_
(
os
.
path
.
exists
(
tarball
))
@
unittest
.
skipUnless
(
find_executable
(
'compress'
),
'The compress program is required'
)
def
test_compress_deprecated
(
self
):
tmpdir
,
tmpdir2
,
base_name
=
self
.
_create_files
()
# using compress and testing the PendingDeprecationWarning
old_dir
=
os
.
getcwd
()
os
.
chdir
(
tmpdir
)
try
:
with
check_warnings
()
as
w
:
warnings
.
simplefilter
(
"always"
)
make_tarball
(
base_name
,
'dist'
,
compress
=
'compress'
)
finally
:
os
.
chdir
(
old_dir
)
tarball
=
base_name
+
'.tar.Z'
self
.
assert_
(
os
.
path
.
exists
(
tarball
))
self
.
assertEquals
(
len
(
w
.
warnings
),
1
)
# same test with dry_run
os
.
remove
(
tarball
)
old_dir
=
os
.
getcwd
()
os
.
chdir
(
tmpdir
)
try
:
with
check_warnings
()
as
w
:
warnings
.
simplefilter
(
"always"
)
make_tarball
(
base_name
,
'dist'
,
compress
=
'compress'
,
dry_run
=
True
)
finally
:
os
.
chdir
(
old_dir
)
self
.
assert_
(
not
os
.
path
.
exists
(
tarball
))
self
.
assertEquals
(
len
(
w
.
warnings
),
1
)
@
unittest
.
skipUnless
(
ZIP_SUPPORT
,
'Need zip support to run'
)
@
unittest
.
skipUnless
(
ZIP_SUPPORT
,
'Need zip support to run'
)
def
test_make_zipfile
(
self
):
def
test_make_zipfile
(
self
):
# creating something to tar
# creating something to tar
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment