mirror of https://github.com/python/cpython.git
bpo-46951: Order contents of zipapps (GH-31713)
So that builds are more reproducible.
This commit is contained in:
parent
bbcf42449e
commit
47e68d4515
|
@ -54,6 +54,22 @@ def test_create_archive_with_subdirs(self):
|
||||||
self.assertIn('foo/', z.namelist())
|
self.assertIn('foo/', z.namelist())
|
||||||
self.assertIn('bar/', z.namelist())
|
self.assertIn('bar/', z.namelist())
|
||||||
|
|
||||||
|
def test_create_sorted_archive(self):
|
||||||
|
# Test that zipapps order their files by name
|
||||||
|
source = self.tmpdir / 'source'
|
||||||
|
source.mkdir()
|
||||||
|
(source / 'zed.py').touch()
|
||||||
|
(source / 'bin').mkdir()
|
||||||
|
(source / 'bin' / 'qux').touch()
|
||||||
|
(source / 'bin' / 'baz').touch()
|
||||||
|
(source / '__main__.py').touch()
|
||||||
|
target = io.BytesIO()
|
||||||
|
zipapp.create_archive(str(source), target)
|
||||||
|
target.seek(0)
|
||||||
|
with zipfile.ZipFile(target, 'r') as zf:
|
||||||
|
self.assertEqual(zf.namelist(),
|
||||||
|
["__main__.py", "bin/", "bin/baz", "bin/qux", "zed.py"])
|
||||||
|
|
||||||
def test_create_archive_with_filter(self):
|
def test_create_archive_with_filter(self):
|
||||||
# Test packing a directory and using filter to specify
|
# Test packing a directory and using filter to specify
|
||||||
# which files to include.
|
# which files to include.
|
||||||
|
|
|
@ -136,7 +136,7 @@ def create_archive(source, target=None, interpreter=None, main=None,
|
||||||
compression = (zipfile.ZIP_DEFLATED if compressed else
|
compression = (zipfile.ZIP_DEFLATED if compressed else
|
||||||
zipfile.ZIP_STORED)
|
zipfile.ZIP_STORED)
|
||||||
with zipfile.ZipFile(fd, 'w', compression=compression) as z:
|
with zipfile.ZipFile(fd, 'w', compression=compression) as z:
|
||||||
for child in source.rglob('*'):
|
for child in sorted(source.rglob('*')):
|
||||||
arcname = child.relative_to(source)
|
arcname = child.relative_to(source)
|
||||||
if filter is None or filter(arcname):
|
if filter is None or filter(arcname):
|
||||||
z.write(child, arcname.as_posix())
|
z.write(child, arcname.as_posix())
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
Order the contents of zipapp archives, to make builds more reproducible.
|
Loading…
Reference in New Issue