aboutsummaryrefslogtreecommitdiff
path: root/sysutils
diff options
context:
space:
mode:
authorKubilay Kocak <koobs@FreeBSD.org>2019-12-20 10:40:29 +0000
committerKubilay Kocak <koobs@FreeBSD.org>2019-12-20 10:40:29 +0000
commitcc2444dc67fd19fdb2717bb577e1ada28b5e7d33 (patch)
treee02d7ed78926feda8dc03abefa2a95b00f9fab17 /sysutils
parent657c6df3d174cfde663ff8790e538e8147836a94 (diff)
MFH: r520359 sysutils/py-scandir: Fix unicode issues, level up ports compliance
This change fixes tests and likely runtime in certain locale environments by replace the existing test_scandir.py patch with a backported upstream patch from PR #109 [1][2], coupled with setting an appropriate locale. While I'm here: - Strip shared library and add LICENSE_FILE Tests now all pass on all Python versions (2.7-3.8) [1] https://github.com/benhoyt/scandir/pull/109 [2] https://github.com/benhoyt/scandir/issues/122 Approved by: portmgr (blanket: ports compliance, bugfix) Approved by: ports-secteam (blanket(s): ports compliance, bugfix)
Notes
Notes: svn path=/branches/2019Q4/; revision=520500
Diffstat (limited to 'sysutils')
-rw-r--r--sysutils/py-scandir/Makefile9
-rw-r--r--sysutils/py-scandir/files/patch-scandir.py28
-rw-r--r--sysutils/py-scandir/files/patch-test_test__scandir.py69
3 files changed, 36 insertions, 70 deletions
diff --git a/sysutils/py-scandir/Makefile b/sysutils/py-scandir/Makefile
index f7461ab7fb56..ae8acce6ca41 100644
--- a/sysutils/py-scandir/Makefile
+++ b/sysutils/py-scandir/Makefile
@@ -4,6 +4,7 @@
PORTNAME= scandir
PORTVERSION= 1.10.0
DISTVERSIONPREFIX= v
+PORTREVISION= 1
CATEGORIES= sysutils python
PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX}
@@ -11,6 +12,7 @@ MAINTAINER= rene@FreeBSD.org
COMMENT= Fast and featureful directory iterator
LICENSE= BSD3CLAUSE
+LICENSE_FILE= ${WRKSRC}/LICENSE.txt
USES= python
USE_PYTHON= autoplist distutils
@@ -18,7 +20,12 @@ USE_PYTHON= autoplist distutils
USE_GITHUB= yes
GH_ACCOUNT= benhoyt
+USE_LOCALE= en_US.UTF-8
+
+post-install:
+ ${STRIP_CMD} ${STAGEDIR}${PYTHONPREFIX_SITELIBDIR}/_scandir.so
+
do-test:
- ${PYTHON_CMD} ${WRKSRC}/test/run_tests.py
+ ${SETENV} ${TEST_ENV} ${PYTHON_CMD} ${WRKSRC}/test/run_tests.py
.include <bsd.port.mk>
diff --git a/sysutils/py-scandir/files/patch-scandir.py b/sysutils/py-scandir/files/patch-scandir.py
new file mode 100644
index 000000000000..7843ec201755
--- /dev/null
+++ b/sysutils/py-scandir/files/patch-scandir.py
@@ -0,0 +1,28 @@
+# Based on https://github.com/benhoyt/scandir/pull/109
+# TODO: Upstream
+# See: https://github.com/benhoyt/scandir/issues/122
+
+From cfda49a07865097d3fdadc4e321881635ab2f795 Mon Sep 17 00:00:00 2001
+From: "Elias M. Mariani" <marianielias@gmail.com>
+Date: Mon, 6 Aug 2018 12:06:44 -0300
+Subject: [PATCH] Fix dirent.h struct alignment on OpenBSD
+
+--- scandir.py.orig 2019-03-09 17:51:39 UTC
++++ scandir.py
+@@ -432,6 +432,16 @@ elif sys.platform.startswith(('linux', 'darwin', 'suno
+ ('__d_padding', ctypes.c_uint8 * 4),
+ ('d_name', ctypes.c_char * 256),
+ )
++ elif 'freebsd' in sys.platform:
++ _fields_ = (
++ ('d_ino', ctypes.c_uint64),
++ ('d_off', ctypes.c_uint64),
++ ('d_reclen', ctypes.c_uint16),
++ ('d_type', ctypes.c_uint8),
++ ('d_namlen', ctypes.c_uint8),
++ ('__d_padding', ctypes.c_uint8 * 4),
++ ('d_name', ctypes.c_char * 256),
++ )
+ else:
+ _fields_ = (
+ ('d_ino', ctypes.c_uint32), # must be uint32, not ulong
diff --git a/sysutils/py-scandir/files/patch-test_test__scandir.py b/sysutils/py-scandir/files/patch-test_test__scandir.py
deleted file mode 100644
index c65b270b000d..000000000000
--- a/sysutils/py-scandir/files/patch-test_test__scandir.py
+++ /dev/null
@@ -1,69 +0,0 @@
---- test/test_scandir.py.orig 2017-09-29 12:38:51 UTC
-+++ test/test_scandir.py
-@@ -14,6 +14,9 @@ try:
- except ImportError:
- has_scandir = False
-
-+reload(sys)
-+sys.setdefaultencoding('utf8')
-+
- FILE_ATTRIBUTE_DIRECTORY = 16
-
- TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), 'testdir'))
-@@ -48,24 +51,24 @@ def create_file(path, contents='1234'):
- def setup_main():
- join = os.path.join
-
-- os.mkdir(TEST_PATH)
-- os.mkdir(join(TEST_PATH, 'subdir'))
-+ os.makedirs(TEST_PATH)
-+ os.makedirs(join(TEST_PATH, 'subdir'))
- create_file(join(TEST_PATH, 'file1.txt'))
- create_file(join(TEST_PATH, 'file2.txt'), contents='12345678')
-
-- os.mkdir(join(TEST_PATH, 'subdir', 'unidir\u018F'))
-+ os.makedirs(join(TEST_PATH, 'subdir', u'unidir\u018F'))
- create_file(join(TEST_PATH, 'subdir', 'file1.txt'))
-- create_file(join(TEST_PATH, 'subdir', 'unicod\u018F.txt'))
-+ create_file(join(TEST_PATH, 'subdir', u'unicod\u018F.txt'))
-
-- create_file(join(TEST_PATH, 'subdir', 'unidir\u018F', 'file1.txt'))
-+ create_file(join(TEST_PATH, 'subdir', u'unidir\u018F', 'file1.txt'))
-
-- os.mkdir(join(TEST_PATH, 'linkdir'))
-+ os.makedirs(join(TEST_PATH, 'linkdir'))
-
-
- def setup_symlinks():
- join = os.path.join
-
-- os.mkdir(join(TEST_PATH, 'linkdir', 'linksubdir'))
-+ os.makedirs(join(TEST_PATH, 'linkdir', 'linksubdir'))
- create_file(join(TEST_PATH, 'linkdir', 'file1.txt'))
-
- os.symlink(os.path.abspath(join(TEST_PATH, 'linkdir', 'file1.txt')),
-@@ -217,7 +220,7 @@ class TestMixin(object):
- self.assertTrue(isinstance(entry.path, bytes))
-
- # b'unicod?.txt' on Windows, b'unicod\xc6\x8f.txt' (UTF-8) or similar on POSIX
-- entry_name = 'unicod\u018f.txt'.encode(sys.getfilesystemencoding(), 'replace')
-+ entry_name = u'unicod\u018f.txt'.encode(sys.getfilesystemencoding(), 'replace')
- self.assertEqual(entry.name, entry_name)
- self.assertEqual(entry.path, os.path.join(path, entry_name))
-
-@@ -234,12 +237,12 @@ class TestMixin(object):
- self.assertTrue(isinstance(entry.name, str))
- self.assertTrue(isinstance(entry.path, str))
-
-- entry_name = 'unicod\u018f.txt'
-+ entry_name = u'unicod\u018f.txt'
- self.assertEqual(entry.name, entry_name)
-- self.assertEqual(entry.path, os.path.join(path, 'unicod\u018f.txt'))
-+ self.assertEqual(entry.path, os.path.join(path, u'unicod\u018f.txt'))
-
- # Check that it handles unicode input properly
-- path = os.path.join(TEST_PATH, 'subdir', 'unidir\u018f')
-+ path = os.path.join(TEST_PATH, 'subdir', u'unidir\u018f')
- self.assertTrue(isinstance(path, str))
- entries = list(self.scandir_func(path))
- self.assertEqual(len(entries), 1)