diff options
Diffstat (limited to 'sysutils/py-ansible-core219')
| -rw-r--r-- | sysutils/py-ansible-core219/Makefile | 88 | ||||
| -rw-r--r-- | sysutils/py-ansible-core219/distinfo | 3 | ||||
| -rw-r--r-- | sysutils/py-ansible-core219/files/patch-pyproject.toml | 9 | ||||
| -rw-r--r-- | sysutils/py-ansible-core219/pkg-descr | 5 |
4 files changed, 105 insertions, 0 deletions
diff --git a/sysutils/py-ansible-core219/Makefile b/sysutils/py-ansible-core219/Makefile new file mode 100644 index 000000000000..57f21c3bd51b --- /dev/null +++ b/sysutils/py-ansible-core219/Makefile @@ -0,0 +1,88 @@ +PORTNAME= ansible-core +DISTVERSION= 2.19.1 +CATEGORIES= sysutils python +MASTER_SITES= PYPI +PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX} +PKGNAMESUFFIX= 219 +DISTFILES= ${PORTNAME:R:S/-/_/}-${DISTVERSION}${EXTRACT_SUFX} + +MAINTAINER= cy@FreeBSD.org +COMMENT= Radically simple IT automation +WWW= https://www.ansible.com/ + +WRKSRC= ${WRKDIR}/${PORTNAME:R:S/-/_/}-${DISTVERSION} + +LICENSE= GPLv3+ +LICENSE_FILE= ${WRKSRC}/COPYING + +BUILD_DEPENDS= ${PY_SETUPTOOLS} \ + ${PYTHON_PKGNAMEPREFIX}wheel>=0:devel/py-wheel@${PY_FLAVOR} +RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}Jinja2>=3.0.0:devel/py-Jinja2@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}packaging>=0:devel/py-packaging@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}resolvelib>=0.5.3<1.1.0:devel/py-resolvelib@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}toml>0:textproc/py-toml@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}passlib>0:security/py-passlib@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}pyyaml>=5.1:devel/py-pyyaml@${PY_FLAVOR} +TEST_DEPENDS= ${PYTHON_PKGNAMEPREFIX}bcrypt>=0:security/py-bcrypt@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}boto3>0:www/py-boto3@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}mock>0:devel/py-mock@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}nose>0:devel/py-nose@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}passlib>0:security/py-passlib@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}pycryptodome>=0:security/py-pycryptodome@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}pytest-mock>0:devel/py-pytest-mock@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}pytest-xdist>0:devel/py-pytest-xdist@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}pytest>0:devel/py-pytest@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}requests>0:www/py-requests@${PY_FLAVOR} \ + git:devel/git + +USES= ansible:env cpe python:3.10+ shebangfix +CPE_VENDOR= redhat +CPE_PRODUCT= ansible +USE_PYTHON= autoplist concurrent cryptography pep517 + +SHEBANG_REGEX= [.]/test/.*[.]py + +# Pass MAKE_ENV to TEST_ENV so that binary aliases via an updated PATH. +TEST_ENV= ${MAKE_ENV} + +# The "python" binary alias is needed for the tests. +BINARY_ALIAS= python=${PYTHON_CMD} +NO_ARCH= yes + +post-patch: +# Preserve the original paths in +# test/units/cli/galaxy/test_execute_list_collection.py. +# Replacing /usr/share/ansible breaks tests. + ${FIND} ${WRKSRC} -not -regex '${WRKSRC}/test/units/cli/galaxy/test_execute_list_collection.py' -type f -print0 | \ + ${XARGS} -0 ${REINPLACE_CMD} \ + -e 's|/etc/ansible|${ETCDIR}|g' \ + -e 's|/usr/share/ansible|${DATADIR}|g' + ${FIND} ${WRKSRC} -type f -name "*.bak" -delete + +post-stage: + ${FIND} ${STAGEDIR}${PREFIX}/bin -type l -name ansible-\* -lname ansible \ + -execdir ${RLN} ansible-${PYTHON_VER} {} \; +# USE_PYTHON=autoplist doesn't add this file to pkg-plist. + ${RM} ${STAGEDIR}${PYTHONPREFIX_SITELIBDIR}/ansible_test/_data/injector/ansible-inventory + +pre-test: +# This one file does not get its paths replaced correctly in post-patch. + ${REINPLACE_CMD} 's|"/etc"|"${ETCDIR:H}"|g' \ + ${WRKSRC}/test/units/playbook/test_helpers.py +# This test constructs a Python script inline and uses an invalid path to it. + ${REINPLACE_CMD} 's|/usr/bin/python|${PYTHON_CMD}|' \ + ${WRKSRC}/test/units/modules/test_async_wrapper.py +# Skip the SELinux tests, it's not present on FreeBSD. + ${RM} ${WRKSRC}/test/units/module_utils/basic/test_selinux.py +# Disable some failing tests. They fail to detect that emoji are of width 2 istead of 1. + ${RM} ${WRKSRC}/test/units/utils/test_display.py + +do-test: + @cd ${TEST_WRKSRC} && ${SETENV} ${TEST_ENV} ./bin/ansible-test units -v --python ${PYTHON_VER} + +.include <bsd.port.mk> + +# Make sure that we override the unique DATADIR and ETCDIR set +# by the implicit USES=uniquefiles. +DATADIR= ${ANSIBLE_DATADIR} +ETCDIR= ${ANSIBLE_ETCDIR} diff --git a/sysutils/py-ansible-core219/distinfo b/sysutils/py-ansible-core219/distinfo new file mode 100644 index 000000000000..9740b0cb27d0 --- /dev/null +++ b/sysutils/py-ansible-core219/distinfo @@ -0,0 +1,3 @@ +TIMESTAMP = 1758599602 +SHA256 (ansible_core-2.19.1.tar.gz) = affd33b38d32b57cfc2cd6daf3aafcb384297039e4c5600196a2ee9aa027b75d +SIZE (ansible_core-2.19.1.tar.gz) = 3401547 diff --git a/sysutils/py-ansible-core219/files/patch-pyproject.toml b/sysutils/py-ansible-core219/files/patch-pyproject.toml new file mode 100644 index 000000000000..4db56a4c7bc9 --- /dev/null +++ b/sysutils/py-ansible-core219/files/patch-pyproject.toml @@ -0,0 +1,9 @@ +--- pyproject.toml.orig 2025-07-15 10:46:32.000000000 -0700 ++++ pyproject.toml 2025-07-20 05:54:59.527173000 -0700 +@@ -1,5 +1,5 @@ + [build-system] +-requires = ["setuptools >= 66.1.0, <= 80.9.0", "wheel == 0.45.1"] # lower bound to support controller Python versions, upper bound for latest version tested at release ++requires = ["setuptools >= 63.1.0, <= 80.9.0", "wheel == 0.45.1"] # lower bound to support controller Python versions, upper bound for latest version tested at release + build-backend = "setuptools.build_meta" + + [project] diff --git a/sysutils/py-ansible-core219/pkg-descr b/sysutils/py-ansible-core219/pkg-descr new file mode 100644 index 000000000000..12dcf10983b9 --- /dev/null +++ b/sysutils/py-ansible-core219/pkg-descr @@ -0,0 +1,5 @@ +Ansible is a radically simple configuration-management, deployment, +task-execution, and multinode orchestration framework. + +ansible-core contains the core engine, modules and plugins. It does not contain +community and partner supported Ansible Collections of modules and plugins. |
