python-meson-python/python-meson-python.spec

128 lines
3.6 KiB
RPMSpec
Raw Normal View History

2023-07-07 03:05:15 +00:00
%bcond tests 1
# The python-pytest-mock dependency is unwanted on RHEL; we can omit it and
# still run most of the tests.
%bcond pytest_mock %{undefined rhel}
# RHEL will not have patchelf (which is used for adjusting RPATH in shared
# libraries bundled in wheels); that is OK because the package is
# buildroot-only there and the packages built with python-meson-python will not
# bundle shared libraries. In Fedora and EPEL, we must depend on patchelf to
# ship a full-featured package.
%bcond patchelf %{expr:%{undefined rhel} || %{defined epel}}
2023-04-30 00:15:23 +00:00
Name: python-meson-python
Summary: Meson Python build backend (PEP 517)
2023-10-26 21:07:43 +00:00
Version: 0.15.0
2023-04-30 00:15:23 +00:00
Release: %autorelease
# SPDX
License: MIT
URL: https://github.com/mesonbuild/meson-python
Source: %{pypi_source meson_python}
# Downstream-only patch to remove the patchelf dependency (and corresponding
# functionality), controlled by the patchelf build conditional
Patch2: meson_python-remove-patchelf.patch
2023-04-30 00:15:23 +00:00
BuildArch: noarch
BuildRequires: python3-devel
%if %{with tests}
BuildRequires: gcc
BuildRequires: git-core
%endif
%global common_description %{expand:
meson-python is a Python build backend built on top of the Meson build system.
It enables to use Meson for the configuration and build steps of Python
packages. Meson is an open source build system meant to be both extremely fast,
and, even more importantly, as user friendly as possible. meson-python is best
suited for building Python packages containing extension modules implemented in
languages such as C, C++, Cython, Fortran, Pythran, or Rust. Consult the
documentation for more details.}
%description %{common_description}
%package -n python3-meson-python
Summary: %{summary}
# When patchelf is not in the PATH, mesonpy.get_requires_for_build_wheel() adds
# https://pypi.org/project/patchelf/ to the dependencies. We always want to use
# the system patchelf.
%if %{with patchelf}
BuildRequires: /usr/bin/patchelf
Requires: /usr/bin/patchelf
%endif
2023-04-30 00:15:23 +00:00
# https://docs.fedoraproject.org/en-US/packaging-guidelines/Python/#_provides_for_importable_modules
%py_provides python3-mesonpy
%description -n python3-meson-python %{common_description}
%prep
%setup -n meson_python-%{version} -q
%patch 0 -p1
%patch 1 -p1
%if %{without patchelf}
%patch 2 -p1
%endif
# build: used only by skipped PEP 518 test
# pytest-cov: https://docs.fedoraproject.org/en-US/packaging-guidelines/Python/#_linters
sed -r -i "s/^ '(build|pytest-cov)/#&/" pyproject.toml
%if %{without pytest_mock}
sed -r -i "s/^ '(pytest-mock)/#&/" pyproject.toml
%endif
2023-04-30 00:15:23 +00:00
%generate_buildrequires
%pyproject_buildrequires -w %{?with_tests:-x test}
%build
%pyproject_wheel
%install
%pyproject_install
%pyproject_save_files mesonpy
%check
%if %{with tests}
# Note: tests are *not* safe for parallel execution with pytest-xdist.
# PEP 518 tests require network access.
ignore="${ignore-} --ignore=tests/test_pep518.py"
%if %{without pytest_mock}
k="${k-}${k+ and }not test_invalid_build_dir"
k="${k-}${k+ and }not test_use_ansi_colors"
%endif
%if %{without patchelf}
k="${k-}${k+ and }not test_contents"
k="${k-}${k+ and }not test_local_lib"
k="${k-}${k+ and }not test_rpath"
k="${k-}${k+ and }not test_get_requires_for_build_wheel"
k="${k-}${k+ and }not test_uneeded_rpath"
%endif
%pytest ${ignore-} -k "${k-}"
2023-04-30 00:15:23 +00:00
%else
%pyproject_check_import
%endif
%files -n python3-meson-python -f %{pyproject_files}
# LICENSE duplicates LICENSES/MIT.txt. Currently, neither is automatically
# installed into the dist-info metadata directory.
%license LICENSES/*
%doc CHANGELOG.rst
%doc README.rst
%changelog
%autochangelog