diff options
author | hfinucane <h.finucane+gh@gmail.com> | 2022-05-27 16:04:29 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-05-27 16:04:29 (GMT) |
commit | 47e68d451586541259ffb6ae29e948d4ea67c059 (patch) | |
tree | cc008a3ed0d440920ccc1ee2d884e01c54861ab4 | |
parent | bbcf42449e13c0b62f145cd49d12674ef3d5bf64 (diff) | |
download | cpython-47e68d451586541259ffb6ae29e948d4ea67c059.zip cpython-47e68d451586541259ffb6ae29e948d4ea67c059.tar.gz cpython-47e68d451586541259ffb6ae29e948d4ea67c059.tar.bz2 |
bpo-46951: Order contents of zipapps (GH-31713)
So that builds are more reproducible.
-rw-r--r-- | Lib/test/test_zipapp.py | 16 | ||||
-rw-r--r-- | Lib/zipapp.py | 2 | ||||
-rw-r--r-- | Misc/NEWS.d/next/Library/2022-03-08-04-46-44.bpo-46951.SWAz97.rst | 1 |
3 files changed, 18 insertions, 1 deletions
diff --git a/Lib/test/test_zipapp.py b/Lib/test/test_zipapp.py index 69f2e55..d135c68 100644 --- a/Lib/test/test_zipapp.py +++ b/Lib/test/test_zipapp.py @@ -54,6 +54,22 @@ class ZipAppTest(unittest.TestCase): self.assertIn('foo/', 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): # Test packing a directory and using filter to specify # which files to include. diff --git a/Lib/zipapp.py b/Lib/zipapp.py index ce77632..d8ebfcb 100644 --- a/Lib/zipapp.py +++ b/Lib/zipapp.py @@ -136,7 +136,7 @@ def create_archive(source, target=None, interpreter=None, main=None, compression = (zipfile.ZIP_DEFLATED if compressed else zipfile.ZIP_STORED) 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) if filter is None or filter(arcname): z.write(child, arcname.as_posix()) diff --git a/Misc/NEWS.d/next/Library/2022-03-08-04-46-44.bpo-46951.SWAz97.rst b/Misc/NEWS.d/next/Library/2022-03-08-04-46-44.bpo-46951.SWAz97.rst new file mode 100644 index 0000000..cd7601a --- /dev/null +++ b/Misc/NEWS.d/next/Library/2022-03-08-04-46-44.bpo-46951.SWAz97.rst @@ -0,0 +1 @@ +Order the contents of zipapp archives, to make builds more reproducible. |