summaryrefslogtreecommitdiffstats
path: root/tests/test_fs.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 16:08:06 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 16:08:06 +0000
commitba6d96469df143b52295f8e79da648bf8a597407 (patch)
tree5ea0c3374f5c53209ad02008dcdddfc8ccae92e5 /tests/test_fs.py
parentInitial commit. (diff)
downloaddh-python-upstream.tar.xz
dh-python-upstream.zip
Adding upstream version 5.20230130+deb12u1.upstream/5.20230130+deb12u1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/test_fs.py')
-rw-r--r--tests/test_fs.py145
1 files changed, 145 insertions, 0 deletions
diff --git a/tests/test_fs.py b/tests/test_fs.py
new file mode 100644
index 0000000..c458fe8
--- /dev/null
+++ b/tests/test_fs.py
@@ -0,0 +1,145 @@
+from tempfile import TemporaryDirectory
+from pathlib import Path
+from unittest import TestCase
+
+from dhpython.interpreter import Interpreter
+from dhpython.fs import (
+ fix_merged_RECORD, merge_RECORD, merge_WHEEL, missing_lines, share_files)
+
+from tests.common import FakeOptions
+
+
+class MergeWheelTestCase(TestCase):
+ files = {}
+ def setUp(self):
+ self.tempdir = TemporaryDirectory()
+ self.addCleanup(self.tempdir.cleanup)
+ temp_path = Path(self.tempdir.name)
+ for fn, contents in self.files.items():
+ path = temp_path / fn
+ setattr(self, path.name, path)
+ path.parent.mkdir(parents=True, exist_ok=True)
+ with path.open('w') as f:
+ f.write('\n'.join(contents))
+ f.write('\n')
+
+ def assertFileContents(self, path, contents):
+ """Assert that the contents of path is contents
+
+ Contents may be specified as a list of strings, one per line, without
+ line-breaks.
+ """
+ if isinstance(contents, (list, tuple)):
+ contents = '\n'.join(contents) + '\n'
+ with path.open('r') as f:
+ self.assertMultiLineEqual(contents, f.read())
+
+
+class SimpleCombinationTest(MergeWheelTestCase):
+ files = {
+ 'a': ('abc', 'def'),
+ 'b': ('abc', 'ghi'),
+ }
+ def test_missing_lines(self):
+ r = missing_lines(self.a, self.b)
+ self.assertEqual(r, ['def\n'])
+
+ def test_merge_record(self):
+ merge_RECORD(self.a, self.b)
+ self.assertFileContents(self.b, ('abc', 'ghi', 'def'))
+
+
+class MergeTagsTest(MergeWheelTestCase):
+ files = {
+ 'a': ('foo', 'Tag: A'),
+ 'b': ('foo', 'Tag: B'),
+ }
+
+ def test_merge_wheel(self):
+ merge_WHEEL(self.a, self.b)
+ self.assertFileContents(self.b, ('foo', 'Tag: B', 'Tag: A'))
+
+
+class UpdateRecordTest(MergeWheelTestCase):
+ files = {
+ 'dist-info/RECORD': ('dist-info/FOO,sha256=b5bb9d8014a0f9b1d61e21e796d7'
+ '8dccdf1352f23cd32812f4850b878ae4944c,4',),
+ 'dist-info/WHEEL': ('foo'),
+ }
+
+ def test_fix_merged_record(self):
+ fix_merged_RECORD(self.RECORD.parent)
+ self.assertFileContents(self.RECORD, (
+ 'dist-info/FOO,sha256=b5bb9d8014a0f9b1d61e21e796d78dccdf1352f23cd32'
+ '812f4850b878ae4944c,4',
+ 'dist-info/WHEEL,sha256=447fb61fa39a067229e1cce8fc0953bfced53eac85d'
+ '1844f5940f51c1fcba725,6',
+ ))
+
+
+class ShareFilesTestCase(MergeWheelTestCase):
+ impl = 'cpython3'
+ options = {}
+
+ def setUp(self):
+ super().setUp()
+ self.destdir = TemporaryDirectory()
+ self.addCleanup(self.destdir.cleanup)
+ share_files(self.tempdir.name, self.destdir.name,
+ Interpreter(self.impl),
+ FakeOptions(**self.options))
+
+ def destPath(self, name):
+ return Path(self.destdir.name) / name
+
+
+class HatchlingLicenseTest(ShareFilesTestCase):
+ files = {
+ 'foo.dist-info/license_files/LICENSE.txt': ('foo'),
+ 'foo.dist-info/licenses/COPYING': ('foo'),
+ 'foo.dist-info/RECORD': (
+ 'foo.dist-info/license_files/LICENSE.txt,sha256=2c26b46b68ffc68ff99'
+ 'b453c1d30413413422d706483bfa0f98a5e886266e7ae,4',
+ 'foo.dist-info/licenses/COPYING,sha256=2c26b46b68ffc68ff99b453c1d30'
+ '413413422d706483bfa0f98a5e886266e7ae,4',
+ 'foo.dist-info/WHEEL,sha256=447fb61fa39a067229e1cce8fc0953bfced53ea'
+ 'c85d1844f5940f51c1fcba725,6'),
+ 'foo.dist-info/WHEEL': ('foo'),
+ }
+
+ def test_removes_license_files(self):
+ self.assertFalse(
+ self.destPath('foo.dist-info/license_files/LICENSE.txt').exists())
+ self.assertFalse(
+ self.destPath('foo.dist-info/licenses/COPYING').exists())
+
+ def test_removes_license_files_from_record(self):
+ print("Checking", self.destPath('foo.dist-info/RECORD'))
+ self.assertFileContents(self.destPath('foo.dist-info/RECORD'),
+ 'foo.dist-info/WHEEL,sha256=447fb61fa39a067229e1cce8fc0953bfced53ea'
+ 'c85d1844f5940f51c1fcba725,6\n')
+
+
+class FlitLicenseTest(ShareFilesTestCase):
+ files = {
+ 'foo.dist-info/COPYING': ('foo'),
+ 'foo.dist-info/COPYING.LESSER': ('foo'),
+ 'foo.dist-info/RECORD': (
+ 'foo.dist-info/COPYING,sha256=2c26b46b68ffc68ff99b453c1d30413413422'
+ 'd706483bfa0f98a5e886266e7ae,4',
+ 'foo.dist-info/COPYING.LESSER,sha256=2c26b46b68ffc68ff99b453c1d3041'
+ '3413422d706483bfa0f98a5e886266e7ae,4',
+ 'foo.dist-info/WHEEL,sha256=447fb61fa39a067229e1cce8fc0953bfced53ea'
+ 'c85d1844f5940f51c1fcba725,6'),
+ 'foo.dist-info/WHEEL': ('foo'),
+ }
+
+ def test_removes_license_files(self):
+ self.assertFalse(self.destPath('foo.dist-info/COPYING.LESSER').exists())
+ self.assertFalse(self.destPath('foo.dist-info/COPYING').exists())
+
+ def test_removes_license_files_from_record(self):
+ print("Checking", self.destPath('foo.dist-info/RECORD'))
+ self.assertFileContents(self.destPath('foo.dist-info/RECORD'),
+ 'foo.dist-info/WHEEL,sha256=447fb61fa39a067229e1cce8fc0953bfced53ea'
+ 'c85d1844f5940f51c1fcba725,6\n')