Merge fedora/rawhide into c10s

This commit is contained in:
Miro Hrončok 2025-11-28 18:28:40 +01:00
commit 755e2f77d3
39 changed files with 498 additions and 280 deletions

1
.fmf/version Normal file
View File

@ -0,0 +1 @@
1

View File

@ -80,7 +80,7 @@ using the `-R` flag:
%pyproject_buildrequires -R %pyproject_buildrequires -R
Alternatively, if the project specifies its dependencies in the pyproject.toml Alternatively, if the project specifies its dependencies in the pyproject.toml
`[project]` table (as defined in [PEP 621](https://www.python.org/dev/peps/pep-0621/)), `[project]` table (as defined in [PEP 621]),
the runtime dependencies can be obtained by reading that metadata. the runtime dependencies can be obtained by reading that metadata.
This can be enabled by using the `-p` flag. This can be enabled by using the `-p` flag.
@ -92,28 +92,6 @@ Please note that not all build backends which use pyproject.toml support the
For example, poetry-core (at least in 1.9.0) defines package metadata in the For example, poetry-core (at least in 1.9.0) defines package metadata in the
custom `[tool.poetry]` table which is not supported by the `%pyproject_buildrequires` macro. custom `[tool.poetry]` table which is not supported by the `%pyproject_buildrequires` macro.
Finally, the runtime dependencies can be obtained by building the wheel and reading the metadata from the built wheel.
This can be enabled with the `-w` flag and cannot be combined with `-p`.
Support for building wheels with `%pyproject_buildrequires -w` is **provisional** and the behavior might change.
Please subscribe to Fedora's [python-devel list] if you use the option.
%generate_buildrequires
%pyproject_buildrequires -w
When this is used, the wheel is going to be built at least twice,
becasue the `%generate_buildrequires` section runs repeatedly.
To avoid accidentally reusing a wheel leaking from a previous (different) build,
it cannot be reused between `%generate_buildrequires` rounds.
Contrarily to that, rebuilding the wheel again in the `%build` section is redundant
and the packager can omit the `%build` section entirely
to reuse the wheel built from the last round of `%generate_buildrequires`.
Be extra careful when attempting to modify the sources after `%pyproject_buildrequires`,
e.g. when running extra commands in the `%build` section:
%build
cython src/wrong.pyx # this is too late with %%pyproject_buildrequires -w
%pyproject_wheel
For projects that specify test requirements using an [`extra` For projects that specify test requirements using an [`extra`
provide](https://packaging.python.org/specifications/core-metadata/#provides-extra-multiple-use), provide](https://packaging.python.org/specifications/core-metadata/#provides-extra-multiple-use),
these can be added using the `-x` flag. these can be added using the `-x` flag.
@ -167,7 +145,7 @@ in worst case, patch/sed the requirement out from the tox configuration.
Note that neither `-x` or `-t` can be used with `-R` or `-N`, Note that neither `-x` or `-t` can be used with `-R` or `-N`,
because runtime dependencies are always required for testing. because runtime dependencies are always required for testing.
You can only use those options if the build backend supports the [prepare-metadata-for-build-wheel hook], You can only use those options if the build backend supports the [prepare-metadata-for-build-wheel hook],
or together with `-p` or `-w`. or together with `-p`.
However, using `-g` with `-R` or `-N` is supported because dependency groups don't need to be used for testing However, using `-g` with `-R` or `-N` is supported because dependency groups don't need to be used for testing
and can be obtained by reading `pyproject.toml` only. and can be obtained by reading `pyproject.toml` only.
@ -184,7 +162,7 @@ Dependencies will be loaded from them:
For packages not using build system you can use `-N` to entirely skip automatical For packages not using build system you can use `-N` to entirely skip automatical
generation of requirements and install requirements only from manually specified files. generation of requirements and install requirements only from manually specified files.
`-N` option implies `-R` and cannot be used in combination with other options mentioned above `-N` option implies `-R` and cannot be used in combination with other options mentioned above
(`-w`, `-e`, `-t`, `-x`, `-p`). (`-e`, `-t`, `-x`, `-p`).
The `%pyproject_buildrequires` macro also accepts the `-r` flag for backward compatibility; The `%pyproject_buildrequires` macro also accepts the `-r` flag for backward compatibility;
it means "include runtime dependencies" which has been the default since version 0-53. it means "include runtime dependencies" which has been the default since version 0-53.
@ -243,7 +221,7 @@ The macro:
- Always prepends `$PATH` with `%{buildroot}%{_bindir}` - Always prepends `$PATH` with `%{buildroot}%{_bindir}`
- If not defined, sets `$PYTHONPATH` to `%{buildroot}%{python3_sitearch}:%{buildroot}%{python3_sitelib}` - If not defined, sets `$PYTHONPATH` to `%{buildroot}%{python3_sitearch}:%{buildroot}%{python3_sitelib}`
- If not defined, sets `$TOX_TESTENV_PASSENV` to `*` - If not defined, sets `$TOX_TESTENV_PASSENV` to `*`
- Runs `tox` with `-q` (quiet), `--recreate` and `--current-env` (from [tox-current-env]) flags - Runs `tox` with `-q` (quiet), `--recreate`, `--current-env` (from [tox-current-env]) and `--assert-config` (from [tox-current-env]) flags
- Implicitly uses the tox environment name stored in `%{toxenv}` - as overridden by `%pyproject_buildrequires -e` - Implicitly uses the tox environment name stored in `%{toxenv}` - as overridden by `%pyproject_buildrequires -e`
By using the `-e` flag, you can use a different tox environment(s): By using the `-e` flag, you can use a different tox environment(s):
@ -311,10 +289,17 @@ However, in Fedora packages, always list executables explicitly to avoid uninten
%doc README.rst %doc README.rst
%{_bindir}/downloader %{_bindir}/downloader
If the package has no Python modules in it, you can explicitly use `-M` to denote that.
%install
%pyproject_install
%pyproject_save_files -M
Otherwise, at least one module-glob argument is required.
`%pyproject_save_files` can automatically mark license files with `%license` macro `%pyproject_save_files` can automatically mark license files with `%license` macro
and language (`*.mo`) files with `%lang` macro and appropriate language code. and language (`*.mo`) files with `%lang` macro and appropriate language code.
Only license files declared via [PEP 639] `License-File` field are detected. Only license files declared via [PEP 639] `License-File` field are detected.
[PEP 639] is still provisional and can be changed in the future.
It is possible to use the `-l` flag to declare that a missing license should It is possible to use the `-l` flag to declare that a missing license should
terminate the build or `-L` (the default) to explicitly disable this check. terminate the build or `-L` (the default) to explicitly disable this check.
Packagers are encouraged to use the `-l` flag when the `%license` file is not manually listed in `%files` Packagers are encouraged to use the `-l` flag when the `%license` file is not manually listed in `%files`
@ -417,7 +402,7 @@ Provisional: Declarative Buildsystem (RPM 4.20+)
It is possible to reduce some of the spec boilerplate by using the provided It is possible to reduce some of the spec boilerplate by using the provided
pyproject [declarative buildsystem]. pyproject [declarative buildsystem].
This option is only available with RPM 4.20+ (e.g. in Fedora 41+). This option is only available with RPM 4.20+ (e.g. in Fedora 41+, ELN/CentOS Stream 11+).
The declarative buildsystem is **provisional** and the behavior might change. The declarative buildsystem is **provisional** and the behavior might change.
Please subscribe to Fedora's [python-devel list] if you use the feature. Please subscribe to Fedora's [python-devel list] if you use the feature.
@ -532,6 +517,7 @@ so be prepared for problems.
[PEP 508]: https://www.python.org/dev/peps/pep-0508/ [PEP 508]: https://www.python.org/dev/peps/pep-0508/
[PEP 517]: https://www.python.org/dev/peps/pep-0517/ [PEP 517]: https://www.python.org/dev/peps/pep-0517/
[PEP 518]: https://www.python.org/dev/peps/pep-0518/ [PEP 518]: https://www.python.org/dev/peps/pep-0518/
[PEP 621]: https://www.python.org/dev/peps/pep-0621/
[PEP 639]: https://www.python.org/dev/peps/pep-0639/ [PEP 639]: https://www.python.org/dev/peps/pep-0639/
[PEP 735]: https://www.python.org/dev/peps/pep-0735/ [PEP 735]: https://www.python.org/dev/peps/pep-0735/
[pip's documentation]: https://pip.pypa.io/en/stable/cli/pip_install/#vcs-support [pip's documentation]: https://pip.pypa.io/en/stable/cli/pip_install/#vcs-support
@ -542,6 +528,11 @@ Deprecated
The `%{pyproject_build_lib}` macro is deprecated, don't use it. The `%{pyproject_build_lib}` macro is deprecated, don't use it.
The `%pyproject_buildrequires` `-w` option is deprecated, don't use it.
If the build backend does not support the [prepare-metadata-for-build-wheel hook],
consider using the `-p` flag to read the metadata from the pyproject.toml
`[project]` table (as defined in [PEP 621]) instead.
Testing the macros Testing the macros
------------------ ------------------
@ -565,11 +556,11 @@ For each `$PKG.spec` in `tests/`:
- download the sources: - download the sources:
spectool -g -R $PKG.spec spectool -g $PKG.spec
- build a SRPM: - build a SRPM:
rpmbuild -bs $PKG.spec rpmbuild -bs --define '_sourcedir .' $PKG.spec
- build in mock, using the path from the command above as `$SRPM`: - build in mock, using the path from the command above as `$SRPM`:

View File

@ -3,8 +3,8 @@
# When this file is installed but macros.pyproject is not # When this file is installed but macros.pyproject is not
# this macro will cause the package with the real macro to be installed. # this macro will cause the package with the real macro to be installed.
# When macros.pyproject is installed, it overrides this macro. # When macros.pyproject is installed, it overrides this macro.
# Note: This needs to maintain the same set of options as the real macro. # Note: This takes arbitrary options, to ease addition of new options to the real macro.
%pyproject_buildrequires(rRxtNwpe:g:C:) echo 'pyproject-rpm-macros' && exit 0 %pyproject_buildrequires(-) echo 'pyproject-rpm-macros'
# Declarative buildsystem, requires RPM 4.20+ to work # Declarative buildsystem, requires RPM 4.20+ to work

View File

@ -2,8 +2,14 @@
# For the main Python it's empty, for all others it's "-3.X" # For the main Python it's empty, for all others it's "-3.X"
%_pyproject_files_pkgversion %{expr:"%{python3_pkgversion}" != "3" ? "-%{python3_pkgversion}" : ""} %_pyproject_files_pkgversion %{expr:"%{python3_pkgversion}" != "3" ? "-%{python3_pkgversion}" : ""}
# In RPM < 4.20 (4.19.9x is 4.20 alpha), there is no guaranteed, RPM-controlled per-build directory (%%mkbuilddir step).
# Hence we use %%{buildsubdir} if available.
# On newer RPM 4.20+ this is no longer necessary and breaks the declarative buildsystem:
# https://github.com/rpm-software-management/rpm/issues/3890
%_pyproject_buildsubdir_compat %[ v"0%{?rpmversion}" < v"4.19.90" ? "%{?buildsubdir:/%{buildsubdir}}" : ""]
# This is a directory where wheels are stored and installed from, absolute # This is a directory where wheels are stored and installed from, absolute
%_pyproject_wheeldir %{_builddir}%{?buildsubdir:/%{buildsubdir}}/pyproject-wheeldir%{_pyproject_files_pkgversion} %_pyproject_wheeldir %{_builddir}%{_pyproject_buildsubdir_compat}/pyproject-wheeldir%{_pyproject_files_pkgversion}
# This is a directory used as TMPDIR, where pip copies sources to and builds from, relative to PWD # This is a directory used as TMPDIR, where pip copies sources to and builds from, relative to PWD
# For proper debugsource packages, we create TMPDIR within PWD # For proper debugsource packages, we create TMPDIR within PWD
@ -12,7 +18,7 @@
# This will be used in debugsource package paths (applies to extension modules only) # This will be used in debugsource package paths (applies to extension modules only)
# NB: pytest collects tests from here if not hidden # NB: pytest collects tests from here if not hidden
# https://docs.pytest.org/en/latest/reference.html#confval-norecursedirs # https://docs.pytest.org/en/latest/reference.html#confval-norecursedirs
%_pyproject_builddir %{_builddir}%{?buildsubdir:/%{buildsubdir}}/.pyproject-builddir%{_pyproject_files_pkgversion} %_pyproject_builddir %{_builddir}%{_pyproject_buildsubdir_compat}/.pyproject-builddir%{_pyproject_files_pkgversion}
# We prefix all created files with this value to make them unique # We prefix all created files with this value to make them unique
# Ideally, we would put them into %%{buildsubdir}, but that value changes during the spec # Ideally, we would put them into %%{buildsubdir}, but that value changes during the spec
@ -75,7 +81,7 @@ echo $(IFS=:; echo "${pyproject_build_lib[*]}")
%pyproject_install() %{expand:\\\ %pyproject_install() %{expand:\\\
specifier=$(ls %{_pyproject_wheeldir}/*.whl | xargs basename --multiple | sed -E 's/([^-]+)-([^-]+)-.+\\\.whl/\\\1==\\\2/') specifier=$(ls %{_pyproject_wheeldir}/*.whl | xargs basename --multiple | sed -E 's/([^-]+)-([^-]+)-.+\\\.whl/\\\1==\\\2/')
if [ -z $specifier ]; then if [ -z "$specifier" ]; then
echo 'ERROR: %%%%pyproject_install found no wheel in %%%%{_pyproject_wheeldir} %{_pyproject_wheeldir}' >&2 echo 'ERROR: %%%%pyproject_install found no wheel in %%%%{_pyproject_wheeldir} %{_pyproject_wheeldir}' >&2
exit 1 exit 1
fi fi
@ -97,7 +103,7 @@ fi
# Process all *.dist-info dirs in sitelib/sitearch # Process all *.dist-info dirs in sitelib/sitearch
for site_dir in ${site_dirs[@]}; do for site_dir in ${site_dirs[@]}; do
for distinfo in %{buildroot}$site_dir/*.dist-info; do for distinfo in %{buildroot}$site_dir/*.dist-info; do
echo "%ghost ${distinfo#%{buildroot}}" >> %{_pyproject_ghost_distinfo} echo "%ghost %dir ${distinfo#%{buildroot}}" >> %{_pyproject_ghost_distinfo}
sed -i 's/pip/rpm/' ${distinfo}/INSTALLER sed -i 's/pip/rpm/' ${distinfo}/INSTALLER
PYTHONPATH=%{_rpmconfigdir}/redhat \\ PYTHONPATH=%{_rpmconfigdir}/redhat \\
%{__python3} -B %{_rpmconfigdir}/redhat/pyproject_preprocess_record.py \\ %{__python3} -B %{_rpmconfigdir}/redhat/pyproject_preprocess_record.py \\
@ -122,7 +128,7 @@ fi
# https://github.com/rpm-software-management/rpm/issues/1749#issuecomment-1020420616 # https://github.com/rpm-software-management/rpm/issues/1749#issuecomment-1020420616
# Since we support both ways, we pass either 4.19 or 4.18 to the script, so it knows which one to use # Since we support both ways, we pass either 4.19 or 4.18 to the script, so it knows which one to use
# Rather than passing the actual version, we let RPM compare the versions, as it is easier done here than in Python # Rather than passing the actual version, we let RPM compare the versions, as it is easier done here than in Python
%pyproject_save_files(lL) %{expand:\\\ %pyproject_save_files(lLM) %{expand:\\\
%{expr:v"0%{?rpmversion}" >= v"4.18.90" ? "RPM_FILES_ESCAPE=4.19" : "RPM_FILES_ESCAPE=4.18" } \\ %{expr:v"0%{?rpmversion}" >= v"4.18.90" ? "RPM_FILES_ESCAPE=4.19" : "RPM_FILES_ESCAPE=4.18" } \\
%{__python3} %{_rpmconfigdir}/redhat/pyproject_save_files.py \\ %{__python3} %{_rpmconfigdir}/redhat/pyproject_save_files.py \\
--output-files "%{pyproject_files}" \\ --output-files "%{pyproject_files}" \\
@ -166,7 +172,6 @@ fi
]"\ ]"\
] ]
# Note: Keep the options in sync with this macro from macros.aaa-pyproject-srpm
%pyproject_buildrequires(rRxtNwpe:g:C:) %{expand:\\\ %pyproject_buildrequires(rRxtNwpe:g:C:) %{expand:\\\
%_set_pytest_addopts %_set_pytest_addopts
# The default flags expect the package note file to exist # The default flags expect the package note file to exist
@ -193,6 +198,10 @@ fi
fi} fi}
} }
%{-w: %{-w:
%{!?__pyproject_buildrequires_w_warned:%{warn:The %%pyproject_buildrequires -w option is deprecated.
It's not efficient to build the wheel several times during the build.
The option is not scheduled for removal, but packagers should use the -p option instead.
}%global __pyproject_buildrequires_w_warned 1}
%{-p:%{error:The -w and -p options are mutually exclusive}} %{-p:%{error:The -w and -p options are mutually exclusive}}
} }
%{-e:%{expand:%global toxenv %(%{__python3} -s %{_rpmconfigdir}/redhat/pyproject_construct_toxenv.py %{?**})}} %{-e:%{expand:%global toxenv %(%{__python3} -s %{_rpmconfigdir}/redhat/pyproject_construct_toxenv.py %{?**})}}
@ -216,7 +225,7 @@ if [ -f %{__python3} ]; then
echo -n > %{_pyproject_buildrequires} echo -n > %{_pyproject_buildrequires}
%{_pyproject_build_flags} \\\ %{_pyproject_build_flags} \\\
TMPDIR="%{_pyproject_builddir}" \\\ TMPDIR="%{_pyproject_builddir}" \\\
RPM_TOXENV="%{toxenv}" HOSTNAME="rpmbuild" %{__python3} -Bs %{_rpmconfigdir}/redhat/pyproject_buildrequires.py %{?!_python_no_extras_requires:--generate-extras} --python3_pkgversion %{python3_pkgversion} --wheeldir %{_pyproject_wheeldir} --output %{_pyproject_buildrequires} %{?**} >&2 RPM_TOXENV="%{toxenv}" FEDORA=%{?fedora} HOSTNAME="rpmbuild" %{__python3} -Bs %{_rpmconfigdir}/redhat/pyproject_buildrequires.py %{?!_python_no_extras_requires:--generate-extras} --python3_pkgversion %{python3_pkgversion} --wheeldir %{_pyproject_wheeldir} --output %{_pyproject_buildrequires} %{?**} >&2
cat %{_pyproject_buildrequires} cat %{_pyproject_buildrequires}
fi fi
# Incomplete .dist-info dir might confuse importlib.metadata # Incomplete .dist-info dir might confuse importlib.metadata
@ -231,7 +240,7 @@ PATH="%{buildroot}%{_bindir}:$PATH" \\
PYTHONPATH="${PYTHONPATH:-%{buildroot}%{python3_sitearch}:%{buildroot}%{python3_sitelib}}" \\ PYTHONPATH="${PYTHONPATH:-%{buildroot}%{python3_sitearch}:%{buildroot}%{python3_sitelib}}" \\
%{?__pytest_addopts:PYTEST_ADDOPTS="${PYTEST_ADDOPTS:-} %{__pytest_addopts}"}} \\ %{?__pytest_addopts:PYTEST_ADDOPTS="${PYTEST_ADDOPTS:-} %{__pytest_addopts}"}} \\
HOSTNAME="rpmbuild" \\ HOSTNAME="rpmbuild" \\
%{__python3} -m tox --current-env -q --recreate -e "%{-e:%{-e*}}%{!-e:%{toxenv}}" %{?*} %{__python3} -m tox --current-env --assert-config -q --recreate -e "%{-e:%{-e*}}%{!-e:%{toxenv}}" %{?*}
} }

136
plan.fmf Normal file
View File

@ -0,0 +1,136 @@
execute:
how: tmt
discover:
- name: same_repo
how: shell
tests:
- name: pytest
path: /tests
test: ./mocktest.sh python-pytest
- name: entrypoints
path: /tests
test: ./mocktest.sh python-entrypoints
- name: pluggy
path: /tests
test: ./mocktest.sh python-pluggy
- name: clikit
path: /tests
test: ./mocktest.sh python-clikit
- name: distroinfo
path: /tests
test: ./mocktest.sh python-distroinfo
# No matching package to install: 'python3dist(termcolor)'
#- name: tldr
# path: /tests
# test: ./mocktest.sh tldr
# No matching package to install: 'python3dist(freezegun)'
#- name: openqa_client
# path: /tests
# test: ./mocktest.sh python-openqa_client
- name: httpbin
path: /tests
test: ./mocktest.sh python-httpbin
# No matching package to install: 'openldap-servers'
#- name: ldap
# path: /tests
# test: ./mocktest.sh python-ldap
- name: isort
path: /tests
test: ./mocktest.sh python-isort
- name: mistune
path: /tests
test: ./mocktest.sh python-mistune
- name: setuptools_scm
path: /tests
test: ./mocktest.sh python-setuptools_scm
- name: ipykernel
path: /tests
test: ./mocktest.sh python-ipykernel
- name: zope
path: /tests
test: ./mocktest.sh python-zope-event
- name: django
path: /tests
test: ./mocktest.sh python-django
- name: printrun
path: /tests
test: ./mocktest.sh printrun
# No matching package to install: 'python3dist(vcrpy) > 1.0'
#- name: dns_lexicon
# path: /tests
# test: ./mocktest.sh python-dns-lexicon
- name: flit_core
path: /tests
test: ./mocktest.sh python-flit-core
- name: poetry_core
path: /tests
test: ./mocktest.sh python-poetry-core
- name: setuptools
path: /tests
test: ./mocktest.sh python-setuptools
# No matching package to install: 'python3dist(mypy)'
# No matching package to install: 'python3dist(pallets-sphinx-themes)'
# No matching package to install: 'python3dist(pre-commit)'
# No matching package to install: 'python3dist(sphinx-issues)'
# No matching package to install: 'python3dist(sphinxcontrib-log-cabinet)'
#- name: markupsafe
# path: /tests
# test: ./mocktest.sh python-markupsafe
- name: getmac
path: /tests
test: ./mocktest.sh python-getmac
- name: userpath
path: /tests
test: ./mocktest.sh python-userpath
# No matching package to install: 'python3dist(pytest-cov)' [testing]
# No matching package to install: 'python3dist(pytest-regressions)' [testing]
# No matching package to install: 'python3dist(linkify-it-py)' [linkify]
# No matching package to install: 'python3dist(mdurl)'
#- name: markdown_it_py
# path: /tests
# test: ./mocktest.sh python-markdown-it-py
- name: double_install
path: /tests
test: ./mocktest.sh double-install
- name: fake_requirements
path: /tests
test: ./mocktest.sh fake-requirements
- name: virtualenv
path: /tests
test: ./mocktest.sh python-virtualenv
- name: coverage_pth
path: /tests
test: ./mocktest.sh python-coverage-pth
- name: pello
path: /tests
test: ./mocktest.sh python-pello
- name: pello_with_options
path: /tests
test: ./mocktest.sh python-pello --with options
- name: pello_with_override_install
path: /tests
test: ./mocktest.sh python-pello --with override_install
- name: escape_paths
path: /tests
test: ./mocktest.sh escape_paths
- name: config-settings-test
path: /tests
test: ./mocktest.sh config-settings-test
- name: isort_c9s
path: /tests
test: NAME="CentOS Stream" VERSION_ID=9 ./mocktest.sh python-isort
- name: isort_c10s
path: /tests
test: NAME="CentOS Stream" VERSION_ID=10 ./mocktest.sh python-isort
prepare:
- name: Install dependencies
how: install
package:
- 'https://dl.fedoraproject.org/pub/epel/epel-release-latest-10.noarch.rpm'
- mock
- rpmdevtools
- rpm-build
- dnf
- name: Update packages
how: shell
script: dnf upgrade -y

View File

@ -14,7 +14,7 @@ License: MIT
# Increment Y and reset Z when new macros or features are added # Increment Y and reset Z when new macros or features are added
# Increment Z when this is a bugfix or a cosmetic change # Increment Z when this is a bugfix or a cosmetic change
# Dropping support for EOL Fedoras is *not* considered a breaking change # Dropping support for EOL Fedoras is *not* considered a breaking change
Version: 1.16.2 Version: 1.18.5
Release: 1%{?dist} Release: 1%{?dist}
# Macro files # Macro files
@ -59,9 +59,9 @@ BuildRequires: python3dist(packaging)
BuildRequires: python3dist(pip) BuildRequires: python3dist(pip)
BuildRequires: python3dist(setuptools) BuildRequires: python3dist(setuptools)
%if %{with tox_tests} %if %{with tox_tests}
BuildRequires: python3dist(tox-current-env) >= 0.0.6 BuildRequires: python3dist(tox-current-env) >= 0.0.16
%endif %endif
BuildRequires: python3dist(wheel) BuildRequires: (python3dist(wheel) if python3dist(setuptools) < 71)
BuildRequires: (python3dist(tomli) if python3 < 3.11) BuildRequires: (python3dist(tomli) if python3 < 3.11)
%endif %endif
@ -137,15 +137,9 @@ install -pm 644 pyproject_construct_toxenv.py %{buildroot}%{_rpmconfigdir}/redha
install -pm 644 pyproject_requirements_txt.py %{buildroot}%{_rpmconfigdir}/redhat/ install -pm 644 pyproject_requirements_txt.py %{buildroot}%{_rpmconfigdir}/redhat/
install -pm 644 pyproject_wheel.py %{buildroot}%{_rpmconfigdir}/redhat/ install -pm 644 pyproject_wheel.py %{buildroot}%{_rpmconfigdir}/redhat/
%check
# assert the two signatures of %%pyproject_buildrequires match exactly
signature1="$(grep '^%%pyproject_buildrequires' macros.pyproject | cut -d' ' -f1)"
signature2="$(grep '^%%pyproject_buildrequires' macros.aaa-pyproject-srpm | cut -d' ' -f1)"
test "$signature1" == "$signature2"
# but also assert we are not comparing empty strings
test "$signature1" != ""
%if %{with tests} %if %{with tests}
%check
export HOSTNAME="rpmbuild" # to speedup tox in network-less mock, see rhbz#1856356 export HOSTNAME="rpmbuild" # to speedup tox in network-less mock, see rhbz#1856356
%pytest -vv --doctest-modules %{?with_pytest_xdist:-n auto} %{!?with_tox_tests:-k "not tox"} %pytest -vv --doctest-modules %{?with_pytest_xdist:-n auto} %{!?with_tox_tests:-k "not tox"}
@ -173,6 +167,51 @@ export HOSTNAME="rpmbuild" # to speedup tox in network-less mock, see rhbz#1856
%changelog %changelog
* Thu Oct 16 2025 Miro Hrončok <mhroncok@redhat.com> - 1.18.5-1
- %%pyproject_extras_subpkg: Only %%ghost the dist-info directory, not the content
- That way, accidentally unpackaged files within are reported as errors
- %%pyproject_save_files: Also save top level typing stub files (.pyi)
* Mon Sep 01 2025 Miro Hrončok <mhroncok@redhat.com> - 1.18.4-1
- Don't exit from pyproject-srpm-macros implementation of %%pyproject_buildrequires
- Fixes: rhbz#2391290
- On RPM 4.20+ don't put pyproject-macros-specific files in %%buildsubdir
- Works around https://github.com/rpm-software-management/rpm/issues/3890
- Speed %%pyproject_save_files up significantly
* Fri Jul 25 2025 Fedora Release Engineering <releng@fedoraproject.org> - 1.18.3-2
- Rebuilt for https://fedoraproject.org/wiki/Fedora_43_Mass_Rebuild
* Fri Jul 11 2025 Miro Hrončok <mhroncok@redhat.com> - 1.18.3-1
- %%pyproject_buildrequires: Do not generate BuildRequires from Requires core metadata fields
- That field is deprecated and should include importable module names, not distribution packages
- Related: rhbz#2378463
* Mon May 19 2025 Maxwell G <maxwell@gtmx.me> - 1.18.2-1
- Fix handling of config_settings in %%pyproject_buildrequires
* Fri Mar 21 2025 Miro Hrončok <mhroncok@redhat.com> - 1.18.1-1
- Fix reverted conditional in %%pyproject_buildrequires -t/-e Fedora version comparison
* Tue Mar 11 2025 Miro Hrončok <mhroncok@redhat.com> - 1.18.0-1
- Make %%pyproject_buildrequires -t/-e and %%tox fail when no suitable tox configuration exists
- The %%pyproject_buildrequires -t/-e case is temporarily allowed on Fedora 40-42
- Requires tox-current-env >= 0.0.16
* Thu Jan 30 2025 Miro Hrončok <miro@hroncok.cz> - 1.17.0-1
- Add the -M flag to %%pyproject_save_files
- The flag can be used to indicate no Python modules should be saved
* Sat Jan 18 2025 Fedora Release Engineering <releng@fedoraproject.org> - 1.16.4-2
- Rebuilt for https://fedoraproject.org/wiki/Fedora_42_Mass_Rebuild
* Tue Dec 03 2024 Miro Hrončok <mhroncok@redhat.com> - 1.16.4-1
- Deprecate the provisional -w flag for %%pyproject_buildrequires
* Tue Dec 03 2024 Miro Hrončok <mhroncok@redhat.com> - 1.16.3-1
- Accept arbitrary options from %%pyproject_buildrequires in pyproject-srpm-macros
- This will make future additions smoother
* Wed Nov 13 2024 Miro Hrončok <mhroncok@redhat.com> - 1.16.2-1 * Wed Nov 13 2024 Miro Hrončok <mhroncok@redhat.com> - 1.16.2-1
- Fix one remaining test for setuptools 70+ - Fix one remaining test for setuptools 70+

View File

@ -22,6 +22,15 @@ from pyproject_wheel import parse_config_settings_args
# Allow only the forms we know we can handle. # Allow only the forms we know we can handle.
VERSION_RE = re.compile(r'[a-zA-Z0-9.-]+(\.\*)?') VERSION_RE = re.compile(r'[a-zA-Z0-9.-]+(\.\*)?')
# To avoid breakage on Fedora 40-42,
# we don't assert tox configuration there.
# This can be removed when Fedora 42 goes EOL.
# Note that %tox still uses --assert-config
# because %tox without config is dangerous (false sense of tests).
# Running %pyproject_buildrequires -t/-e without tox config is wrong, but not dangerous.
FEDORA = int(os.getenv('FEDORA') or 0)
TOX_ASSERT_CONFIG_OPTS = () if 40 <= FEDORA < 43 else ('--assert-config',)
class EndPass(Exception): class EndPass(Exception):
"""End current pass of generating requirements""" """End current pass of generating requirements"""
@ -290,7 +299,7 @@ def get_backend(requirements):
def generate_build_requirements(backend, requirements): def generate_build_requirements(backend, requirements):
get_requires = getattr(backend, 'get_requires_for_build_wheel', None) get_requires = getattr(backend, 'get_requires_for_build_wheel', None)
if get_requires: if get_requires:
new_reqs = get_requires(config_settings=requirements.config_settings) new_reqs = get_requires(requirements.config_settings)
requirements.extend(new_reqs, source='get_requires_for_build_wheel') requirements.extend(new_reqs, source='get_requires_for_build_wheel')
requirements.check(source='get_requires_for_build_wheel') requirements.check(source='get_requires_for_build_wheel')
@ -300,7 +309,7 @@ def parse_metadata_file(metadata_file):
def requires_from_parsed_metadata_file(message): def requires_from_parsed_metadata_file(message):
return {k: message.get_all(k, ()) for k in ('Requires', 'Requires-Dist')} return {k: message.get_all(k, ()) for k in ('Requires-Dist',)}
def package_name_from_parsed_metadata_file(message): def package_name_from_parsed_metadata_file(message):
@ -322,11 +331,10 @@ def generate_run_requirements_hook(backend, requirements):
'The build backend cannot provide build metadata ' 'The build backend cannot provide build metadata '
'(incl. runtime requirements) before build. ' '(incl. runtime requirements) before build. '
'If the dependencies are specified in the pyproject.toml [project] ' 'If the dependencies are specified in the pyproject.toml [project] '
'table, you can use the -p flag to read them.' 'table, you can use the -p flag to read them. '
'Alternatively, use the provisional -w flag to build the wheel and parse the metadata from it, ' 'Alternatively, use the -R flag not to generate runtime dependencies.'
'or use the -R flag not to generate runtime dependencies.'
) )
dir_basename = prepare_metadata('.', config_settings=requirements.config_settings) dir_basename = prepare_metadata('.', requirements.config_settings)
with open(dir_basename + '/METADATA') as metadata_file: with open(dir_basename + '/METADATA') as metadata_file:
name, requires = package_name_and_requires_from_metadata_file(metadata_file) name, requires = package_name_and_requires_from_metadata_file(metadata_file)
for key, req in requires.items(): for key, req in requires.items():
@ -417,7 +425,7 @@ def generate_run_requirements(backend, requirements, *, build_wheel, read_pyproj
def generate_tox_requirements(toxenv, requirements): def generate_tox_requirements(toxenv, requirements):
toxenv = ','.join(toxenv) toxenv = ','.join(toxenv)
requirements.add('tox-current-env >= 0.0.6', source='tox itself') requirements.add('tox-current-env >= 0.0.16', source='tox itself')
requirements.check(source='tox itself') requirements.check(source='tox itself')
with tempfile.NamedTemporaryFile('r') as deps, \ with tempfile.NamedTemporaryFile('r') as deps, \
tempfile.NamedTemporaryFile('r') as extras, \ tempfile.NamedTemporaryFile('r') as extras, \
@ -427,6 +435,7 @@ def generate_tox_requirements(toxenv, requirements):
'--print-deps-to', deps.name, '--print-deps-to', deps.name,
'--print-extras-to', extras.name, '--print-extras-to', extras.name,
'--no-provision', provision.name, '--no-provision', provision.name,
*TOX_ASSERT_CONFIG_OPTS,
'-q', '-r', '-e', toxenv], '-q', '-r', '-e', toxenv],
check=False, check=False,
encoding='utf-8', encoding='utf-8',
@ -669,7 +678,7 @@ def main(argv):
parser.add_argument( parser.add_argument(
'-w', '--wheel', action='store_true', default=False, '-w', '--wheel', action='store_true', default=False,
help=('Generate run-time requirements by building the wheel ' help=('Generate run-time requirements by building the wheel '
'(useful for build backends without the prepare_metadata_for_build_wheel hook)'), '(useful for build backends without the prepare_metadata_for_build_wheel hook, deprecated)'),
) )
parser.add_argument( parser.add_argument(
'-p', '--read-pyproject-dependencies', action='store_true', default=False, '-p', '--read-pyproject-dependencies', action='store_true', default=False,

View File

@ -456,7 +456,7 @@ tox dependencies:
setuptools: 50 setuptools: 50
wheel: 1 wheel: 1
tox: 3.5.3 tox: 3.5.3
tox-current-env: 0.0.6 tox-current-env: 0.0.16
toxenv: toxenv:
- py3 - py3
setup.py: | setup.py: |
@ -479,13 +479,13 @@ tox dependencies:
- | # tox 3 with setuptools < 70 - | # tox 3 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(toxdep1) python3dist(toxdep1)
python3dist(toxdep2) python3dist(toxdep2)
python3dist(inst) python3dist(inst)
- | # tox 4 with setuptools 70+ - | # tox 4 with setuptools 70+
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) python3dist(tox)
python3dist(toxdep1) python3dist(toxdep1)
python3dist(toxdep2) python3dist(toxdep2)
@ -493,7 +493,7 @@ tox dependencies:
- | # tox 4 with setuptools < 70 - | # tox 4 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) python3dist(tox)
python3dist(toxdep1) python3dist(toxdep1)
python3dist(toxdep2) python3dist(toxdep2)
@ -505,7 +505,7 @@ tox extras:
setuptools: 50 setuptools: 50
wheel: 1 wheel: 1
tox: 3.5.3 tox: 3.5.3
tox-current-env: 0.0.6 tox-current-env: 0.0.16
generate_extras: true generate_extras: true
toxenv: toxenv:
- py3 - py3
@ -536,7 +536,7 @@ tox extras:
- | # tox 3 with setuptools < 70 - | # tox 3 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(toxdep) python3dist(toxdep)
python3dist(inst) python3dist(inst)
python3dist(dep11) > 11.0 python3dist(dep11) > 11.0
@ -548,7 +548,7 @@ tox extras:
python3dist(extra-dep[extra_dep]) python3dist(extra-dep[extra_dep])
- | # tox 4 with setuptools 70+ - | # tox 4 with setuptools 70+
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) python3dist(tox)
python3dist(toxdep) python3dist(toxdep)
python3dist(inst) python3dist(inst)
@ -562,7 +562,7 @@ tox extras:
- | # tox 4 with setuptools < 70 - | # tox 4 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) python3dist(tox)
python3dist(toxdep) python3dist(toxdep)
python3dist(inst) python3dist(inst)
@ -580,7 +580,7 @@ tox provision unsatisfied:
setuptools: 50 setuptools: 50
wheel: 1 wheel: 1
tox: 3.5.3 tox: 3.5.3
tox-current-env: 0.0.6 tox-current-env: 0.0.16
toxenv: toxenv:
- py3 - py3
setup.py: | setup.py: |
@ -604,13 +604,13 @@ tox provision unsatisfied:
- | # tox 3 with setuptools < 70 - | # tox 3 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) >= 3.999 python3dist(tox) >= 3.999
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(wheel) > 2.0 python3dist(wheel) > 2.0
- | # tox 4 with setuptools 70+ - | # tox 4 with setuptools 70+
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) >= 3.999 python3dist(tox) >= 3.999
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(wheel) > 2.0 python3dist(wheel) > 2.0
@ -618,7 +618,7 @@ tox provision unsatisfied:
- | # tox 4 with setuptools < 70 - | # tox 4 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) >= 3.999 python3dist(tox) >= 3.999
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(wheel) > 2.0 python3dist(wheel) > 2.0
@ -630,7 +630,7 @@ tox provision satisfied:
setuptools: 50 setuptools: 50
wheel: 1 wheel: 1
tox: 3.5.3 tox: 3.5.3
tox-current-env: 0.0.6 tox-current-env: 0.0.16
toxenv: toxenv:
- py3 - py3
setup.py: | setup.py: |
@ -653,7 +653,7 @@ tox provision satisfied:
- | # tox 3 with setuptools < 70 - | # tox 3 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) >= 3.5 python3dist(tox) >= 3.5
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(toxdep1) python3dist(toxdep1)
@ -661,7 +661,7 @@ tox provision satisfied:
python3dist(inst) python3dist(inst)
- | # tox 4 with setuptools 70+ - | # tox 4 with setuptools 70+
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(tox) >= 3.5 python3dist(tox) >= 3.5
python3dist(toxdep1) python3dist(toxdep1)
@ -670,7 +670,7 @@ tox provision satisfied:
- | # tox 4 with setuptools < 70 - | # tox 4 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(tox) >= 3.5 python3dist(tox) >= 3.5
python3dist(toxdep1) python3dist(toxdep1)
@ -683,7 +683,7 @@ tox provision no minversion:
setuptools: 50 setuptools: 50
wheel: 1 wheel: 1
tox: 3.5.3 tox: 3.5.3
tox-current-env: 0.0.6 tox-current-env: 0.0.16
toxenv: toxenv:
- py3 - py3
setup.py: | setup.py: |
@ -701,19 +701,19 @@ tox provision no minversion:
- | # tox 3 with setuptools < 70 - | # tox 3 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(wheel) > 2.0 python3dist(wheel) > 2.0
- | # tox 4 with setuptools 70+ - | # tox 4 with setuptools 70+
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(wheel) > 2.0 python3dist(wheel) > 2.0
python3dist(tox) python3dist(tox)
- | # tox 4 with setuptools < 70 - | # tox 4 with setuptools < 70
python3dist(setuptools) >= 40.8 python3dist(setuptools) >= 40.8
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(setuptools) > 40.0 python3dist(setuptools) > 40.0
python3dist(wheel) > 2.0 python3dist(wheel) > 2.0
python3dist(tox) python3dist(tox)
@ -1573,7 +1573,7 @@ tox with dependency_groups:
setuptools: 50 setuptools: 50
wheel: 1 wheel: 1
tox: 4.22 tox: 4.22
tox-current-env: 0.0.14 tox-current-env: 0.0.16
toxenv: toxenv:
- py3 - py3
pyproject.toml: | pyproject.toml: |
@ -1594,7 +1594,7 @@ tox with dependency_groups:
expected: expected:
- | # setuptools 70+ - | # setuptools 70+
python3dist(setuptools) python3dist(setuptools)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) >= 4.22 python3dist(tox) >= 4.22
python3dist(tox) python3dist(tox)
python3dist(pytest) >= 5 python3dist(pytest) >= 5
@ -1602,9 +1602,29 @@ tox with dependency_groups:
- | # setuptools < 70 - | # setuptools < 70
python3dist(setuptools) python3dist(setuptools)
python3dist(wheel) python3dist(wheel)
python3dist(tox-current-env) >= 0.0.6 python3dist(tox-current-env) >= 0.0.16
python3dist(tox) >= 4.22 python3dist(tox) >= 4.22
python3dist(tox) python3dist(tox)
python3dist(pytest) >= 5 python3dist(pytest) >= 5
python3dist(pytest-mock) python3dist(pytest-mock)
result: 0 result: 0
Plain Requires fields in core metadata is ignored:
installed:
setuptools: 50
wheel: 1
include_runtime: true
setup.py: |
from setuptools import setup
setup(
name='test',
version='0.1',
requires=['ignore_me'],
)
expected:
- | # setuptools 70+
python3dist(setuptools) >= 40.8
- | # setuptools < 70
python3dist(setuptools) >= 40.8
python3dist(wheel)
result: 0

View File

@ -137,12 +137,11 @@ def add_file_to_module(paths, module_name, module_type, files_dirs, *files):
""" """
for module in paths["modules"][module_name]: for module in paths["modules"][module_name]:
if module["type"] == module_type: if module["type"] == module_type:
if files[0] not in module[files_dirs]: module[files_dirs].update(files)
module[files_dirs].extend(files)
break break
else: else:
paths["modules"][module_name].append( paths["modules"][module_name].append(
{"type": module_type, "files": [], "dirs": [], files_dirs: list(files)} {"type": module_type, "files": set(), "dirs": set(), files_dirs: set(files)}
) )
@ -348,7 +347,7 @@ def classify_paths(
"docs": [], # to be used once there is upstream way to recognize READMEs "docs": [], # to be used once there is upstream way to recognize READMEs
"licenses": [], # %license entries parsed from dist-info METADATA file "licenses": [], # %license entries parsed from dist-info METADATA file
}, },
"lang": {}, # %lang entries: [module_name or None][language_code] lists of .mo files "lang": {}, # %lang entries: [module_name or None][language_code] lists of .mo and .qm files
"modules": defaultdict(list), # each importable module (directory, .py, .so) "modules": defaultdict(list), # each importable module (directory, .py, .so)
"module_names": set(), # qualified names of each importable module ("foo.bar.baz") "module_names": set(), # qualified names of each importable module ("foo.bar.baz")
"other": {"files": []}, # regular %file entries we could not parse :( "other": {"files": []}, # regular %file entries we could not parse :(
@ -357,7 +356,7 @@ def classify_paths(
license_files = metadata.get_all('License-File') license_files = metadata.get_all('License-File')
license_directory = distinfo / 'licenses' # See PEP 639 "Root License Directory" license_directory = distinfo / 'licenses' # See PEP 639 "Root License Directory"
# setuptools was the first known build backend to implement License-File. # setuptools was the first known build backend to implement License-File.
# Unfortunately they don't put licenses to the license directory (yet): # Unfortunately they didn't put licenses to the license directory in setuptools<78:
# https://github.com/pypa/setuptools/issues/3596 # https://github.com/pypa/setuptools/issues/3596
# Hence, we check licenses in both licenses and dist-info # Hence, we check licenses in both licenses and dist-info
license_directories = (license_directory, distinfo) license_directories = (license_directory, distinfo)
@ -396,6 +395,9 @@ def classify_paths(
# extension modules can have 2 suffixes # extension modules can have 2 suffixes
name = BuildrootPath(path.stem).stem name = BuildrootPath(path.stem).stem
add_file_to_module(paths, name, "extension", "files", path) add_file_to_module(paths, name, "extension", "files", path)
elif path.suffix == ".pyi":
name = path.stem
add_file_to_module(paths, name, "stub", "files", path)
elif path.suffix == ".py": elif path.suffix == ".py":
name = path.stem name = path.stem
# we add the .pyc files, but not top-level __pycache__ # we add the .pyc files, but not top-level __pycache__
@ -412,7 +414,7 @@ def classify_paths(
for parent in list(path.parents)[:index]: # no direct slice until Python 3.10 for parent in list(path.parents)[:index]: # no direct slice until Python 3.10
add_file_to_module(paths, module_dir.name, "package", "dirs", parent) add_file_to_module(paths, module_dir.name, "package", "dirs", parent)
is_lang = False is_lang = False
if path.suffix == ".mo": if path.suffix == ".mo" or path.suffix == ".qm":
is_lang = add_lang_to_module(paths, module_dir.name, path) is_lang = add_lang_to_module(paths, module_dir.name, path)
if not is_lang: if not is_lang:
if path.suffix == ".py": if path.suffix == ".py":
@ -425,7 +427,7 @@ def classify_paths(
add_file_to_module(paths, module_dir.name, "package", "files", path) add_file_to_module(paths, module_dir.name, "package", "files", path)
break break
else: else:
if path.suffix == ".mo": if path.suffix == ".mo" or path.suffix == ".qm":
add_lang_to_module(paths, None, path) or paths["other"]["files"].append(path) add_lang_to_module(paths, None, path) or paths["other"]["files"].append(path)
else: else:
path = normalize_manpage_filename(prefix, path) path = normalize_manpage_filename(prefix, path)
@ -614,7 +616,9 @@ def generate_file_list(paths_dict, module_globs, include_others=False):
# Users using '*' don't care about the files in the package, so it's ok # Users using '*' don't care about the files in the package, so it's ok
# not to fail the build when no modules are detected # not to fail the build when no modules are detected
# There can be legitimate reasons to create a package without Python modules # There can be legitimate reasons to create a package without Python modules
if not modules and fnmatch.fnmatchcase("", glob): if not modules:
for glob in module_globs:
if fnmatch.fnmatchcase("", glob):
done_globs.add(glob) done_globs.add(glob)
missed = module_globs - done_globs missed = module_globs - done_globs
@ -782,7 +786,7 @@ def dist_metadata(buildroot, record_path):
return dist.metadata return dist.metadata
def pyproject_save_files_and_modules(buildroot, sitelib, sitearch, python_version, pyproject_record, prefix, assert_license, varargs): def pyproject_save_files_and_modules(buildroot, sitelib, sitearch, python_version, pyproject_record, prefix, assert_license, allow_no_modules, varargs):
""" """
Takes arguments from the %{pyproject_save_files} macro Takes arguments from the %{pyproject_save_files} macro
@ -797,6 +801,15 @@ def pyproject_save_files_and_modules(buildroot, sitelib, sitearch, python_versio
sitedirs = sorted({sitelib, sitearch}) sitedirs = sorted({sitelib, sitearch})
globs, include_auto = parse_varargs(varargs) globs, include_auto = parse_varargs(varargs)
if not globs and not allow_no_modules:
raise ValueError(
"At least one module glob needs to be provided to %pyproject_save_files. "
"Alternatively, use -M to indicate no Python modules should be saved."
)
if globs and allow_no_modules:
raise ValueError(
"%pyproject_save_files -M cannot be used together with module globs."
)
parsed_records = load_parsed_record(pyproject_record) parsed_records = load_parsed_record(pyproject_record)
final_file_list = [] final_file_list = []
@ -840,6 +853,7 @@ def main(cli_args):
cli_args.pyproject_record, cli_args.pyproject_record,
cli_args.prefix, cli_args.prefix,
cli_args.assert_license, cli_args.assert_license,
cli_args.allow_no_modules,
cli_args.varargs, cli_args.varargs,
) )
@ -853,7 +867,7 @@ def argparser():
prog="%pyproject_save_files", prog="%pyproject_save_files",
add_help=False, add_help=False,
# custom usage to add +auto # custom usage to add +auto
usage="%(prog)s [-l|-L] MODULE_GLOB [MODULE_GLOB ...] [+auto]", usage="%(prog)s [-l|-L] MODULE_GLOB|-M [MODULE_GLOB ...] [+auto]",
) )
parser.add_argument( parser.add_argument(
'--help', action='help', '--help', action='help',
@ -878,7 +892,11 @@ def argparser():
help="Don't fail when no License-File (PEP 639) is found (the default).", help="Don't fail when no License-File (PEP 639) is found (the default).",
) )
parser.add_argument( parser.add_argument(
"varargs", nargs="+", metavar="MODULE_GLOB", "-M", "--allow-no-modules", action="store_true", default=False,
help="Don't fail when no globs are provided, only include non-modules data in the generated filelist.",
)
parser.add_argument(
"varargs", nargs="*", metavar="MODULE_GLOB",
help="Shell-like glob matching top-level module names to save into %%{pyproject_files}", help="Shell-like glob matching top-level module names to save into %%{pyproject_files}",
) )
return parser return parser

View File

@ -213,6 +213,10 @@ classified:
- /usr/lib/python3.7/site-packages/__pycache__/tldr.cpython-37{,.opt-?}.pyc - /usr/lib/python3.7/site-packages/__pycache__/tldr.cpython-37{,.opt-?}.pyc
dirs: [] dirs: []
type: script type: script
- files:
- /usr/lib/python3.7/site-packages/tldr.pyi
dirs: []
type: stub
other: other:
files: files:
- /usr/bin/tldr - /usr/bin/tldr
@ -7572,6 +7576,7 @@ dumped:
- /usr/lib/python3.7/site-packages/tldr-0.5.dist-info/WHEEL - /usr/lib/python3.7/site-packages/tldr-0.5.dist-info/WHEEL
- /usr/lib/python3.7/site-packages/tldr-0.5.dist-info/top_level.txt - /usr/lib/python3.7/site-packages/tldr-0.5.dist-info/top_level.txt
- /usr/lib/python3.7/site-packages/tldr.py - /usr/lib/python3.7/site-packages/tldr.py
- /usr/lib/python3.7/site-packages/tldr.pyi
- /usr/share/man/man1/tldr* - /usr/share/man/man1/tldr*
- - tldr - - tldr
- - mistune - - mistune
@ -15665,6 +15670,7 @@ records:
tldr-0.5.dist-info/WHEEL,sha256=S8S5VL-stOTSZDYxHyf0KP7eds0J72qrK0Evu3TfyAY,92 tldr-0.5.dist-info/WHEEL,sha256=S8S5VL-stOTSZDYxHyf0KP7eds0J72qrK0Evu3TfyAY,92
tldr-0.5.dist-info/top_level.txt,sha256=xHSI9WD6Y-_hONbi2b_9RIn9oiO7RBGHU3A8geJq3mI,5 tldr-0.5.dist-info/top_level.txt,sha256=xHSI9WD6Y-_hONbi2b_9RIn9oiO7RBGHU3A8geJq3mI,5
tldr.py,sha256=aJlA3tIz4QYYy8e7DZUhPyLCqTwnfFjA7Nubwm9bPe0,12779 tldr.py,sha256=aJlA3tIz4QYYy8e7DZUhPyLCqTwnfFjA7Nubwm9bPe0,12779
tldr.pyi,sha256=GxQ4ZGLPQObN92QW_Hb8IJPEuYINNn186FjrRovM09g,13
mistune: mistune:
path: /usr/lib64/python3.7/site-packages/mistune-0.8.3.dist-info/RECORD path: /usr/lib64/python3.7/site-packages/mistune-0.8.3.dist-info/RECORD

View File

@ -9,3 +9,4 @@ tldr-0.5.dist-info/RECORD,,
tldr-0.5.dist-info/WHEEL,sha256=S8S5VL-stOTSZDYxHyf0KP7eds0J72qrK0Evu3TfyAY,92 tldr-0.5.dist-info/WHEEL,sha256=S8S5VL-stOTSZDYxHyf0KP7eds0J72qrK0Evu3TfyAY,92
tldr-0.5.dist-info/top_level.txt,sha256=xHSI9WD6Y-_hONbi2b_9RIn9oiO7RBGHU3A8geJq3mI,5 tldr-0.5.dist-info/top_level.txt,sha256=xHSI9WD6Y-_hONbi2b_9RIn9oiO7RBGHU3A8geJq3mI,5
tldr.py,sha256=aJlA3tIz4QYYy8e7DZUhPyLCqTwnfFjA7Nubwm9bPe0,12779 tldr.py,sha256=aJlA3tIz4QYYy8e7DZUhPyLCqTwnfFjA7Nubwm9bPe0,12779
tldr.pyi,sha256=GxQ4ZGLPQObN92QW_Hb8IJPEuYINNn186FjrRovM09g,13

View File

@ -102,15 +102,15 @@ def test_data(case_name, capfd, tmp_path, monkeypatch):
assert 'expected' in case or 'stderr_contains' in case assert 'expected' in case or 'stderr_contains' in case
out, err = capfd.readouterr() out, err = capfd.readouterr()
dependencies = output.read_text() dependencies = sorted(output.read_text().splitlines())
if 'expected' in case: if 'expected' in case:
expected = case['expected'] expected = case['expected']
if isinstance(expected, list): if isinstance(expected, list):
# at least one of them needs to match # at least one of them needs to match
assert dependencies in expected assert dependencies in [sorted(e.splitlines()) for e in expected]
else: else:
assert dependencies == expected assert dependencies == sorted(expected.splitlines())
# stderr_contains may be a string or list of strings # stderr_contains may be a string or list of strings
stderr_contains = case.get('stderr_contains') stderr_contains = case.get('stderr_contains')

View File

@ -103,6 +103,7 @@ def test_parse_record_tldr():
str(SITELIB / "tldr-0.5.dist-info/WHEEL"), str(SITELIB / "tldr-0.5.dist-info/WHEEL"),
str(SITELIB / "tldr-0.5.dist-info/top_level.txt"), str(SITELIB / "tldr-0.5.dist-info/top_level.txt"),
str(SITELIB / "tldr.py"), str(SITELIB / "tldr.py"),
str(SITELIB / "tldr.pyi"),
] ]
assert output == expected assert output == expected

View File

@ -2,7 +2,7 @@ Name: double-install
Version: 0 Version: 0
Release: 0%{?dist} Release: 0%{?dist}
Summary: Install 2 wheels Summary: Install 2 wheels
License: BSD and MIT License: BSD-3-Clause AND MIT
%global markupsafe_version 2.0.1 %global markupsafe_version 2.0.1
%global tldr_version 0.4.4 %global tldr_version 0.4.4
Source1: https://github.com/pallets/markupsafe/archive/%{markupsafe_version}/MarkupSafe-%{markupsafe_version}.tar.gz Source1: https://github.com/pallets/markupsafe/archive/%{markupsafe_version}/MarkupSafe-%{markupsafe_version}.tar.gz
@ -39,20 +39,17 @@ cd ..
%install %install
(
# This should install both the wheels: # This should install both the wheels:
%pyproject_install %pyproject_install
) 2>&1 | tee install.log
#pyproject_save_files is not possible with 2 dist-infos #pyproject_save_files is not possible with 2 dist-infos
%check %check
# Internal check for the value of %%{pyproject_build_lib} # Internal check for the value of %%{pyproject_build_lib}
%if 0%{?rhel} == 9
for dir in . markupsafe-%{markupsafe_version} tldr-%{tldr_version}; do
(cd $dir && test "%{pyproject_build_lib}" == "$(echo %{_pyproject_builddir}/pip-req-build-*/build/lib.%{python3_platform}-%{python3_version}):$(echo %{_pyproject_builddir}/pip-req-build-*/build/lib)")
done
%else
cd markupsafe-%{markupsafe_version} cd markupsafe-%{markupsafe_version}
%if 0%{?fedora} == 36 %if 0%{?rhel} == 9
test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/markupsafe-%{markupsafe_version}/build/lib.%{python3_platform}-%{python3_version}" test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/markupsafe-%{markupsafe_version}/build/lib.%{python3_platform}-%{python3_version}"
%else %else
test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/markupsafe-%{markupsafe_version}/build/lib.%{python3_platform}-cpython-%{python3_version_nodots}" test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/markupsafe-%{markupsafe_version}/build/lib.%{python3_platform}-cpython-%{python3_version_nodots}"
@ -60,12 +57,14 @@ test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/markupsafe-%{marku
cd ../tldr-%{tldr_version} cd ../tldr-%{tldr_version}
test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/tldr-%{tldr_version}/build/lib" test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/tldr-%{tldr_version}/build/lib"
cd .. cd ..
%endif # Internal regression check for %%pyproject_install with multiple wheels
grep 'binary operator expected' install.log && exit 1 || true
grep 'too many arguments' install.log && exit 1 || true
%files %files
%{_bindir}/tldr* %{_bindir}/tldr*
%pycached %{python3_sitelib}/tldr.py %pycached %{python3_sitelib}/tldr.py
%{python3_sitelib}/tldr-%{tldr_version}.dist-info/ %{python3_sitelib}/tldr-%{tldr_version}.dist-info/
%{python3_sitearch}/MarkupSafe-%{markupsafe_version}.dist-info/ %{python3_sitearch}/[Mm]arkup[Ss]afe-%{markupsafe_version}.dist-info/
%{python3_sitearch}/markupsafe/ %{python3_sitearch}/markupsafe/

View File

@ -72,7 +72,7 @@ mock --verbose --isolation=simple -r $config --enablerepo="$repos" init
mock --verbose --isolation=simple -r $config --enablerepo="$repos" "$@" ~/rpmbuild/SRPMS/${pkgname}-*.src.rpm || res=$? mock --verbose --isolation=simple -r $config --enablerepo="$repos" "$@" ~/rpmbuild/SRPMS/${pkgname}-*.src.rpm || res=$?
# move the results to the artifacts directory, so we can examine them # move the results to the artifacts directory, so we can examine them
artifacts=${TEST_ARTIFACTS:-/tmp/artifacts} artifacts=${TEST_ARTIFACTS:-${TMT_TEST_DATA:-/tmp/artifacts}}
# on Fedora Rawhide, the directory contains "rawhide" instead of the actual version # on Fedora Rawhide, the directory contains "rawhide" instead of the actual version
pushd /var/lib/mock/${mock}/result || pushd /var/lib/mock/${mock/${version}/rawhide}/result pushd /var/lib/mock/${mock}/result || pushd /var/lib/mock/${mock/${version}/rawhide}/result

View File

@ -3,7 +3,7 @@ Version: 2.0.0~rc6
%global upstream_version 2.0.0rc6 %global upstream_version 2.0.0rc6
Release: 0%{?dist} Release: 0%{?dist}
Summary: RepRap printer interface and tools Summary: RepRap printer interface and tools
License: GPLv3+ and FSFAP License: GPL-3.0-or-later AND FSFAP
URL: https://github.com/kliment/Printrun URL: https://github.com/kliment/Printrun
Source0: https://github.com/kliment/Printrun/archive/%{name}-%{upstream_version}.tar.gz Source0: https://github.com/kliment/Printrun/archive/%{name}-%{upstream_version}.tar.gz

View File

@ -0,0 +1,50 @@
Name: python-coverage-pth
Version: 0.0.2
Release: 0%{?dist}
Summary: Coverage PTH file to enable coverage at the virtualenv level
License: BSD-2-Clause
URL: https://github.com/dougn/coverage_pth
Source: %{pypi_source coverage_pth}
BuildArch: noarch
BuildRequires: python3-devel
%description
This package exists to test %%pyproject_save_files -M.
It contains no Python modules, just a single .pth file.
%package -n python3-coverage-pth
Summary: %{summary}
%description -n python3-coverage-pth
...
%prep
%autosetup -p1 -n coverage_pth-%{version}
# support multi-digit Python versions in setup.py regexes
sed -i 's/d)/d+)/' setup.py
%generate_buildrequires
%pyproject_buildrequires
%build
%pyproject_wheel
%install
%pyproject_install
# internal check for our macros:
# this should not work without -M
%pyproject_save_files -L && exit 1 || true
# but this should:
%pyproject_save_files -LM
%files -n python3-coverage-pth -f %{pyproject_files}
%{python3_sitelib}/coverage_pth.pth

View File

@ -2,7 +2,7 @@ Name: python-distroinfo
Version: 0.3.2 Version: 0.3.2
Release: 0%{?dist} Release: 0%{?dist}
Summary: Parsing and querying distribution metadata stored in text/YAML files Summary: Parsing and querying distribution metadata stored in text/YAML files
License: ASL 2.0 License: Apache-2.0
URL: https://github.com/softwarefactory-project/distroinfo URL: https://github.com/softwarefactory-project/distroinfo
Source0: %{pypi_source distroinfo} Source0: %{pypi_source distroinfo}
BuildArch: noarch BuildArch: noarch

View File

@ -2,7 +2,7 @@ Name: python-django
Version: 3.0.7 Version: 3.0.7
Release: 0%{?dist} Release: 0%{?dist}
Summary: A high-level Python Web framework Summary: A high-level Python Web framework
License: BSD License: BSD-3-Clause
URL: https://www.djangoproject.com/ URL: https://www.djangoproject.com/
Source0: %{pypi_source Django} Source0: %{pypi_source Django}
BuildArch: noarch BuildArch: noarch

View File

@ -3,7 +3,7 @@ Version: 3.0.0
Release: 0%{?dist} Release: 0%{?dist}
Summary: Distribution-building parts of Flit Summary: Distribution-building parts of Flit
License: BSD License: BSD-3-Clause AND BSD-2-Clause
URL: https://pypi.org/project/flit-core/ URL: https://pypi.org/project/flit-core/
Source0: https://github.com/takluyver/flit/archive/%{version}/flit-%{version}.tar.gz Source0: https://github.com/takluyver/flit/archive/%{version}/flit-%{version}.tar.gz

View File

@ -10,9 +10,9 @@ BuildArch: noarch
BuildRequires: python3-devel BuildRequires: python3-devel
BuildRequires: pyproject-rpm-macros BuildRequires: pyproject-rpm-macros
%if 0%{?fedora} >= 37 || 0%{?rhel} >= 10 %if 0%{?rhel} != 9
# Wekrzeug in Fedora 37 isn't compatible with our httpbin # Wekrzeug in Fedora and EL10+ isn't compatible with our httpbin
Patch: 0001-Fix-disabling-of-location-header-autocorrect-for-wer.patch Patch: python-httpbin-werkzeug-2.1.patch
%endif %endif
# no flask, itsdangerous, raven, werkzeug packaged for EPEL 9 yet # no flask, itsdangerous, raven, werkzeug packaged for EPEL 9 yet
@ -61,7 +61,7 @@ sed -Ei 's/\bdef (test_(relative_)?redirect_(to_post|n_(equals_to|higher_than)_1
%if %{with tests} %if %{with tests}
%check %check
%if 0%{?fedora} < 40 && 0%{?rhel} < 10 %if 0%{?rhel} == 9
# this version of httpbin is not compatible with werkzeug 3+ # this version of httpbin is not compatible with werkzeug 3+
%tox %tox
%endif %endif

View File

@ -2,7 +2,7 @@ Name: python-ipykernel
Version: 6.11.0 Version: 6.11.0
Release: 0%{?dist} Release: 0%{?dist}
Summary: IPython Kernel for Jupyter Summary: IPython Kernel for Jupyter
License: BSD License: BSD-3-Clause
URL: https://github.com/ipython/ipykernel URL: https://github.com/ipython/ipykernel
Source0: https://github.com/ipython/ipykernel/archive/v%{version}/ipykernel-%{version}.tar.gz Source0: https://github.com/ipython/ipykernel/archive/v%{version}/ipykernel-%{version}.tar.gz

View File

@ -37,6 +37,15 @@ Summary: %{summary}
%package -n python%{python3_pkgversion}-%{modname} %package -n python%{python3_pkgversion}-%{modname}
Summary: %{summary} Summary: %{summary}
%description -n python%{python3_pkgversion}-%{modname}
%{summary}.
%endif
%if 0%{?rhel} == 9 || 0%{?rhel} == 10
%global python3_pkgversion 3.13
%package -n python%{python3_pkgversion}-%{modname}
Summary: %{summary}
%description -n python%{python3_pkgversion}-%{modname} %description -n python%{python3_pkgversion}-%{modname}
%{summary}. %{summary}.
@ -55,6 +64,10 @@ Summary: %{summary}
%pyproject_buildrequires %pyproject_buildrequires
%global python3_pkgversion 3.12 %global python3_pkgversion 3.12
%pyproject_buildrequires %pyproject_buildrequires
%endif
%if 0%{?rhel} == 9 || 0%{?rhel} == 10
%global python3_pkgversion 3.13
%pyproject_buildrequires
%global python3_pkgversion 3 %global python3_pkgversion 3
%endif %endif
@ -67,6 +80,10 @@ Summary: %{summary}
%pyproject_wheel %pyproject_wheel
%global python3_pkgversion 3.12 %global python3_pkgversion 3.12
%pyproject_wheel %pyproject_wheel
%endif
%if 0%{?rhel} == 9 || 0%{?rhel} == 10
%global python3_pkgversion 3.13
%pyproject_wheel
%global python3_pkgversion 3 %global python3_pkgversion 3
%endif %endif
@ -79,6 +96,11 @@ Summary: %{summary}
%global python3_pkgversion 3.12 %global python3_pkgversion 3.12
%pyproject_install %pyproject_install
%pyproject_save_files -l isort %pyproject_save_files -l isort
%endif
%if 0%{?rhel} == 9 || 0%{?rhel} == 10
%global python3_pkgversion 3.13
%pyproject_install
%pyproject_save_files -l isort
%global python3_pkgversion 3 %global python3_pkgversion 3
%endif %endif
# we keep this one last so /usr/bin/isort is installed with python3 shebang # we keep this one last so /usr/bin/isort is installed with python3 shebang
@ -107,6 +129,13 @@ diff %{pyproject_files} <(grep -F python3.11/site-packages %{pyproject_files})
test -d %{buildroot}%{_usr}/lib/python3.12/site-packages/%{modname}/ test -d %{buildroot}%{_usr}/lib/python3.12/site-packages/%{modname}/
test -d %{buildroot}%{_usr}/lib/python3.12/site-packages/%{modname}-%{version}.dist-info/ test -d %{buildroot}%{_usr}/lib/python3.12/site-packages/%{modname}-%{version}.dist-info/
diff %{pyproject_files} <(grep -F python3.12/site-packages %{pyproject_files}) diff %{pyproject_files} <(grep -F python3.12/site-packages %{pyproject_files})
%endif
%if 0%{?rhel} == 9 || 0%{?rhel} == 10
%global python3_pkgversion 3.13
test -d %{buildroot}%{_usr}/lib/python3.13/site-packages/%{modname}/
test -d %{buildroot}%{_usr}/lib/python3.13/site-packages/%{modname}-%{version}.dist-info/
diff %{pyproject_files} <(grep -F python3.13/site-packages %{pyproject_files})
%global python3_pkgversion 3 %global python3_pkgversion 3
%endif %endif
@ -121,5 +150,10 @@ diff %{pyproject_files} <(grep -F python3.12/site-packages %{pyproject_files})
%global python3_pkgversion 3.12 %global python3_pkgversion 3.12
%files -n python%{python3_pkgversion}-%{modname} -f %{pyproject_files} %files -n python%{python3_pkgversion}-%{modname} -f %{pyproject_files}
%doc README.rst *.md %doc README.rst *.md
%endif
%if 0%{?rhel} == 9 || 0%{?rhel} == 10
%global python3_pkgversion 3.13
%files -n python%{python3_pkgversion}-%{modname} -f %{pyproject_files}
%doc README.rst *.md
%global python3_pkgversion 3 %global python3_pkgversion 3
%endif %endif

View File

@ -1,7 +1,7 @@
Name: python-ldap Name: python-ldap
Version: 3.3.0 Version: 3.3.0
Release: 0%{?dist} Release: 0%{?dist}
License: Python License: python-ldap
Summary: An object-oriented API to access LDAP directory servers Summary: An object-oriented API to access LDAP directory servers
Source0: %{pypi_source} Source0: %{pypi_source}
@ -17,7 +17,6 @@ BuildRequires: cyrus-sasl-devel
BuildRequires: gcc BuildRequires: gcc
BuildRequires: openldap-clients BuildRequires: openldap-clients
BuildRequires: openldap-devel BuildRequires: openldap-devel
BuildRequires: openldap-servers
BuildRequires: openssl-devel BuildRequires: openssl-devel
@ -40,7 +39,7 @@ Summary: %{summary}
%prep %prep
%autosetup %autosetup
# Hack: We remove tests that are broken by OpenLDAP 2.5+ # Hack: We remove tests that are broken by OpenLDAP 2.5+ and/or require openldap-servers
# Don't do this in the regular Fedora package, please # Don't do this in the regular Fedora package, please
rm Tests/t_ldapobject.py Tests/t_cext.py Tests/t_edit.py Tests/t_ldap_sasl.py Tests/t_ldap_syncrepl.py Tests/t_slapdobject.py Tests/t_bind.py Tests/t_ldap_options.py Tests/t_ldap_schema_subentry.py rm Tests/t_ldapobject.py Tests/t_cext.py Tests/t_edit.py Tests/t_ldap_sasl.py Tests/t_ldap_syncrepl.py Tests/t_slapdobject.py Tests/t_bind.py Tests/t_ldap_options.py Tests/t_ldap_schema_subentry.py
@ -95,8 +94,6 @@ grep -E '/site-packages/__pycache__/$' %{pyproject_files} && exit 1 || true
# Internal check for the value of %%{pyproject_build_lib} in an archful package # Internal check for the value of %%{pyproject_build_lib} in an archful package
%if 0%{?rhel} == 9 %if 0%{?rhel} == 9
test "%{pyproject_build_lib}" == "$(echo %{_pyproject_builddir}/pip-req-build-*/build/lib.%{python3_platform}-%{python3_version})"
%elif 0%{?fedora} == 36
test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/build/lib.%{python3_platform}-%{python3_version}" test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/build/lib.%{python3_platform}-%{python3_version}"
%else %else
test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/build/lib.%{python3_platform}-cpython-%{python3_version_nodots}" test "%{pyproject_build_lib}" == "%{_builddir}/%{buildsubdir}/build/lib.%{python3_platform}-cpython-%{python3_version_nodots}"

View File

@ -2,7 +2,7 @@ Name: python-markupsafe
Version: 2.0.1 Version: 2.0.1
Release: 0%{?dist} Release: 0%{?dist}
Summary: Implements a XML/HTML/XHTML Markup safe string for Python Summary: Implements a XML/HTML/XHTML Markup safe string for Python
License: BSD License: BSD-3-Clause
URL: https://github.com/pallets/markupsafe URL: https://github.com/pallets/markupsafe
Source0: %{url}/archive/%{version}/MarkupSafe-%{version}.tar.gz Source0: %{url}/archive/%{version}/MarkupSafe-%{version}.tar.gz

View File

@ -3,7 +3,7 @@ Version: 0.8.3
Release: 11%{?dist} Release: 11%{?dist}
Summary: Markdown parser for Python Summary: Markdown parser for Python
License: BSD License: BSD-3-Clause
URL: https://github.com/lepture/mistune URL: https://github.com/lepture/mistune
Source0: %{url}/archive/v%{version}.tar.gz Source0: %{url}/archive/v%{version}.tar.gz

View File

@ -4,7 +4,7 @@ Version: 4.0.0
Release: 1%{?dist} Release: 1%{?dist}
Summary: Python client library for openQA API Summary: Python client library for openQA API
License: GPLv2+ License: GPL-2.0-or-later
URL: https://github.com/os-autoinst/openQA-python-client URL: https://github.com/os-autoinst/openQA-python-client
Source0: %{pypi_source} Source0: %{pypi_source}

View File

@ -9,14 +9,18 @@ Source: %{url}/archive/v%{version}/Pello-%{version}.tar.gz
BuildArch: noarch BuildArch: noarch
# we use this specfile for 2 different tests, this bcond controls it # we use this specfile for various different tests, the bconds controls it
# a build --with options tests custom BuildOptions(generate_buildrequires) # a build --with options tests custom BuildOptions(generate_buildrequires)
%bcond options 0 %bcond options 0
# a build --with override_install has a custom %%install section
%bcond override_install 0
# unfortunately, the following is not even parsable on RPM < 4.20 # unfortunately, the following is not even parsable on RPM < 4.20
%if v"0%{?rpmversion}" >= v"4.19.90" %if v"0%{?rpmversion}" >= v"4.19.90"
BuildSystem: pyproject BuildSystem: pyproject
%if %{without override_install}
BuildOption(install): -l pello BuildOption(install): -l pello
%endif
%if %{with options} %if %{with options}
BuildOption(generate_buildrequires): -t BuildOption(generate_buildrequires): -t
%endif %endif
@ -44,6 +48,14 @@ Summary: %{summary}
%endif %endif
%if %{with override_install} && v"0%{?rpmversion}" >= v"4.19.90"
# to test a fix for https://github.com/rpm-software-management/rpm/issues/3890
%install
%pyproject_install
%pyproject_save_files -l pello
%endif
%if v"0%{?rpmversion}" >= v"4.19.90" %if v"0%{?rpmversion}" >= v"4.19.90"
%files -n python3-pello -f %{pyproject_files} %files -n python3-pello -f %{pyproject_files}
%doc README.md %doc README.md

View File

@ -1,6 +1,6 @@
%global pypi_name pluggy %global pypi_name pluggy
Name: python-%{pypi_name} Name: python-%{pypi_name}
Version: 0.13.0 Version: 1.5.0
Release: 1%{?dist} Release: 1%{?dist}
Summary: The plugin manager stripped of pytest specific details Summary: The plugin manager stripped of pytest specific details
@ -30,9 +30,9 @@ Summary: %{summary}
%prep %prep
%autosetup -p1 -n %{pypi_name}-%{version} %autosetup -p1 -n %{pypi_name}-%{version}
# Avoid pytest 8 for now. # internal check for our macros: insert a subprocess echo to setup.py
# Once the compat package is removed from Fedora, we will update pluggy. # to ensure it's not generated as BuildRequires
sed -i 's/{env:_PYTEST_DEP:pytest}$/{env:_PYTEST_DEP:pytest<8}/' tox.ini echo 'import os; os.system("echo if-this-is-generated-the-build-will-fail")' >> setup.py
%generate_buildrequires %generate_buildrequires

View File

@ -1,6 +1,6 @@
%global pypi_name pytest %global pypi_name pytest
Name: python-%{pypi_name} Name: python-%{pypi_name}
Version: 7.2.0 Version: 8.0.2
Release: 0%{?dist} Release: 0%{?dist}
Summary: Simple powerful testing with Python Summary: Simple powerful testing with Python
License: MIT License: MIT
@ -20,7 +20,7 @@ BuildRequires: pyproject-rpm-macros
%description %description
This is a pure Python package with executables. It has a test suite in tox.ini This is a pure Python package with executables. It has a test suite in tox.ini
and test dependencies specified via the [test] extra. and test dependencies specified via the [testing] extra.
Building this tests: Building this tests:
- generating runtime and test dependencies by both tox.ini and extras - generating runtime and test dependencies by both tox.ini and extras
- pyproject.toml with the setuptools backend and setuptools-scm - pyproject.toml with the setuptools backend and setuptools-scm
@ -37,9 +37,6 @@ Summary: %{summary}
%autosetup -p1 -n %{pypi_name}-%{version} %autosetup -p1 -n %{pypi_name}-%{version}
# remove optional test dependencies we don't like to pull in # remove optional test dependencies we don't like to pull in
sed -E -i '/mock|nose/d' setup.cfg sed -E -i '/mock|nose/d' setup.cfg
# internal check for our macros: insert a subprocess echo to setup.py
# to ensure it's not generated as BuildRequires
echo 'import os; os.system("echo if-this-is-generated-the-build-will-fail")' >> setup.py
%generate_buildrequires %generate_buildrequires

View File

@ -0,0 +1,38 @@
From 4612fd1b6b7f9d3fdbfad34863e5b04535bb44cc Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Tom=C3=A1=C5=A1=20Hrn=C4=8Diar?= <thrnciar@redhat.com>
Date: Wed, 8 Dec 2021 10:22:37 +0100
Subject: [PATCH] Remove optional or unpackaged test deps
---
setup.cfg | 10 ----------
1 file changed, 10 deletions(-)
diff --git a/setup.cfg b/setup.cfg
index 0bc0101..442da7a 100644
--- a/setup.cfg
+++ b/setup.cfg
@@ -37,21 +37,11 @@ exclude =
[options.extras_require]
testing =
pytest >= 6
- pytest-checkdocs >= 2.4
- pytest-flake8
- pytest-black >= 0.3.7; \
- python_implementation != "PyPy"
- pytest-cov
- pytest-mypy; \
- python_implementation != "PyPy"
- pytest-enabler >= 1.0.1
mock
- flake8-2020
virtualenv>=13.0.0
pytest-virtualenv>=1.2.7 # TODO: Update once man-group/pytest-plugins#188 is solved
wheel
- paver
pip>=19.1 # For proper file:// URLs support.
jaraco.envs>=2.2
pytest-xdist
--
2.33.1

View File

@ -1,7 +1,7 @@
Name: python-setuptools Name: python-setuptools
# on the CI we test different version of setuptools on different Fedora versions # on the CI we test different version of setuptools on different Fedora versions
# don't package software like this in Fedora please # don't package software like this in Fedora please
%if 0%{?fedora} || 0%{?rhel} >= 10 %if 0%{?rhel} != 9
Version: 67.7.2 Version: 67.7.2
%else %else
Version: 59.6.0 Version: 59.6.0
@ -9,16 +9,12 @@ Version: 59.6.0
Release: 0%{?dist} Release: 0%{?dist}
Summary: Easily build and distribute Python packages Summary: Easily build and distribute Python packages
# see the real Fedora package for explanation: # see the real Fedora package for explanation:
License: MIT and (BSD or ASL 2.0) License: MIT AND (BSD-2-Clause OR Apache-2.0)
URL: https://pypi.python.org/pypi/setuptools URL: https://pypi.python.org/pypi/setuptools
Source: %{pypi_source setuptools %{version}} Source: %{pypi_source setuptools %{version}}
# Patch from Fedora proper # Patch from Fedora proper
%if 0%{?fedora} || 0%{?rhel} >= 10 Patch: python-setuptools-%{version}-remove-optional-or-unpackaged-test-deps.patch
Patch: Remove-optional-or-unpackaged-test-deps.patch
%else
Patch: 0001-Remove-optional-or-unpackaged-test-deps.patch
%endif
BuildArch: noarch BuildArch: noarch
@ -54,7 +50,7 @@ Summary: %{summary}
%prep %prep
%autosetup -p1 -n setuptools-%{version} %autosetup -p1 -n setuptools-%{version}
%if 0%{?rhel} && 0%{?rhel} < 10 %if 0%{?rhel} == 9
# The following test deps are optional and either not desired or not available in Fedora: # The following test deps are optional and either not desired or not available in Fedora:
sed -Ei setup.cfg -e '/\bpytest-(checkdocs|black|cov|mypy|enabler)\b/d' \ sed -Ei setup.cfg -e '/\bpytest-(checkdocs|black|cov|mypy|enabler)\b/d' \
-e '/\bflake8\b/d' \ -e '/\bflake8\b/d' \

View File

@ -67,7 +67,7 @@ grep -E 'flake8: (OK|commands succeeded)' toxlog %{?!with_flake8:&& exit 1 || tr
# Internal check for our macros # Internal check for our macros
# making sure that %%{_pyproject_ghost_distinfo} has the right content # making sure that %%{_pyproject_ghost_distinfo} has the right content
test -f %{_pyproject_ghost_distinfo} test -f %{_pyproject_ghost_distinfo}
test "$(cat %{_pyproject_ghost_distinfo})" == "%ghost %{python3_sitelib}/setuptools_scm-%{version}.dist-info" test "$(cat %{_pyproject_ghost_distinfo})" == "%ghost %dir %{python3_sitelib}/setuptools_scm-%{version}.dist-info"
%files -n python3-setuptools_scm -f %{pyproject_files} %files -n python3-setuptools_scm -f %{pyproject_files}

View File

@ -37,7 +37,7 @@ sed -i -e 's/distlib<1,>=0.3.6/distlib<1,>=0.3.2/' \
# Drop the option for flaky # Drop the option for flaky
sed -i 's/--no-success-flaky-report//' pyproject.toml sed -i 's/--no-success-flaky-report//' pyproject.toml
# Hacky backport of https://src.fedoraproject.org/rpms/python-virtualenv/c/87b1f95664 # Hacky backport of https://src.fedoraproject.org/rpms/python-virtualenv/c/87b1f95664
%if 0%{?fedora} >= 39 || 0%{?rhel} >= 10 %if 0%{?rhel} != 9
sed -i 's/_nonwrappers/_hookimpls/' tests/conftest.py sed -i 's/_nonwrappers/_hookimpls/' tests/conftest.py
%endif %endif

View File

@ -2,7 +2,7 @@ Name: python-zope-event
Version: 4.2.0 Version: 4.2.0
Release: 0%{?dist} Release: 0%{?dist}
Summary: Zope Event Publication Summary: Zope Event Publication
License: ZPLv2.1 License: ZPL-2.1
URL: https://pypi.python.org/pypi/zope.event/ URL: https://pypi.python.org/pypi/zope.event/
Source0: %{pypi_source zope.event} Source0: %{pypi_source zope.event}
BuildArch: noarch BuildArch: noarch

View File

@ -1,132 +0,0 @@
---
- hosts: localhost
tags:
- classic
tasks:
- dnf:
name: "*"
state: latest
- hosts: localhost
roles:
- role: standard-test-basic
tags:
- classic
tests:
- pytest:
dir: .
run: ./mocktest.sh python-pytest
- entrypoints:
dir: .
run: ./mocktest.sh python-entrypoints
- pluggy:
dir: .
run: ./mocktest.sh python-pluggy
- clikit:
dir: .
run: ./mocktest.sh python-clikit
- distroinfo:
dir: .
run: ./mocktest.sh python-distroinfo
# No matching package to install: 'python3dist(termcolor)'
#- tldr:
# dir: .
# run: ./mocktest.sh tldr
# No matching package to install: 'python3dist(freezegun)'
#- openqa_client:
# dir: .
# run: ./mocktest.sh python-openqa_client
- httpbin:
dir: .
run: ./mocktest.sh python-httpbin
# No matching package to install: 'openldap-servers'
#- ldap:
# dir: .
# run: ./mocktest.sh python-ldap
- isort:
dir: .
run: ./mocktest.sh python-isort
- mistune:
dir: .
run: ./mocktest.sh python-mistune
- setuptools_scm:
dir: .
run: ./mocktest.sh python-setuptools_scm
# No matching package to install: 'python3dist(ipython) >= 5'
# No matching package to install: 'python3dist(jupyter-client)'
# No matching package to install: 'python3dist(jupyter-core) >= 4.2'
#- ipykernel:
# dir: .
# run: ./mocktest.sh python-ipykernel
- zope:
dir: .
run: ./mocktest.sh python-zope-event
- django:
dir: .
run: ./mocktest.sh python-django
- printrun:
dir: .
run: ./mocktest.sh printrun
# No matching package to install: 'python3dist(vcrpy) > 1.0'
#- dns_lexicon:
# dir: .
# run: ./mocktest.sh python-dns-lexicon
- flit_core:
dir: .
run: ./mocktest.sh python-flit-core
- poetry_core:
dir: .
run: ./mocktest.sh python-poetry-core
- setuptools:
dir: .
run: ./mocktest.sh python-setuptools
# No matching package to install: 'python3dist(mypy)'
# No matching package to install: 'python3dist(pallets-sphinx-themes)'
# No matching package to install: 'python3dist(pre-commit)'
# No matching package to install: 'python3dist(sphinx-issues)'
# No matching package to install: 'python3dist(sphinxcontrib-log-cabinet)'
#- markupsafe:
# dir: .
# run: ./mocktest.sh python-markupsafe
- getmac:
dir: .
run: ./mocktest.sh python-getmac
- userpath:
dir: .
run: ./mocktest.sh python-userpath
# No matching package to install: 'python3dist(pytest-cov)' [testing]
# No matching package to install: 'python3dist(pytest-regressions)' [testing]
# No matching package to install: 'python3dist(linkify-it-py)' [linkify]
# No matching package to install: 'python3dist(mdurl)'
#- markdown_it_py:
# dir: .
# run: ./mocktest.sh python-markdown-it-py
- double_install:
dir: .
run: ./mocktest.sh double-install
- fake_requirements:
dir: .
run: ./mocktest.sh fake-requirements
- virtualenv:
dir: .
run: ./mocktest.sh python-virtualenv
- pello:
dir: .
run: ./mocktest.sh python-pello
- pello_with_options:
dir: .
run: ./mocktest.sh python-pello --with options
- escape_paths:
dir: .
run: ./mocktest.sh escape_paths
- config-settings-test:
dir: .
run: ./mocktest.sh config-settings-test
- isort_c9s:
dir: .
run: NAME="CentOS Stream" VERSION_ID=9 ./mocktest.sh python-isort
required_packages:
- 'https://dl.fedoraproject.org/pub/epel/epel-release-latest-10.noarch.rpm'
- mock
- rpmdevtools
- rpm-build

View File

@ -49,11 +49,7 @@ head -n1 %{buildroot}%{_bindir}/%{name}.py | grep -E '#!\s*%{python3}\s+%{py3_sh
test ! -e %{buildroot}%{python3_sitelib}/*.dist-info/direct_url.json test ! -e %{buildroot}%{python3_sitelib}/*.dist-info/direct_url.json
# Internal check for the value of %%{pyproject_build_lib} in a noarch package # Internal check for the value of %%{pyproject_build_lib} in a noarch package
%if 0%{?rhel} == 9
test "%{pyproject_build_lib}" == "$(echo %{_pyproject_builddir}/pip-req-build-*/build/lib)"
%else
test "%{pyproject_build_lib}" == "${PWD}/build/lib" test "%{pyproject_build_lib}" == "${PWD}/build/lib"
%endif
%if 0%{?rhel} != 9 %if 0%{?rhel} != 9
# Internal check for custom prefix # Internal check for custom prefix