# Sphinx-generated HTML documentation is not suitable for packaging; see # https://bugzilla.redhat.com/show_bug.cgi?id=2006555 for discussion. # # We can generate PDF documentation as a substitute. %bcond_without doc_pdf %if 0%{?el9} # https://bugzilla.redhat.com/show_bug.cgi?id=2034654 %bcond_with gevent %else %bcond_without gevent %endif Summary: OpenTracing interface for Python Name: python-opentracing Version: 2.4.0 Release: 4%{?dist} # The files are under the Apache License 2.0, # except for: # - mocktracer-related files # - scope-related files # - tests/conftest.py # which are under the Expat License (classified as MIT by the Open # Source Initiative). License: ASL 2.0 and MIT URL: https://github.com/opentracing/opentracing-python Source0: https://github.com/opentracing/opentracing-python/archive/%{version}.tar.gz # Issue filed upstream as https://github.com/opentracing/opentracing-python/issues/142 # Upstream has merged the change on master as https://github.com/opentracing/opentracing-python/pull/143 Patch0: 0001-Do-not-use-mock-the-PyPI-backport-library-when-possi.patch BuildArch: noarch BuildRequires: python3-devel BuildRequires: make BuildRequires: texinfo %if %{with doc_pdf} BuildRequires: python3-sphinx-latex BuildRequires: latexmk # Required to provide its intersphinx inventory %if ! 0%{?el9} BuildRequires: python3-docs %endif %endif %global _description %{expand: This library is a Python platform API for OpenTracing. It allows Python programs to interact with an OpenTracing server.} %description %{_description} %prep %autosetup -n opentracing-python-%{version} -p1 %if 0%{?el9} echo 'intersphinx_mapping.clear()' >> docs/conf.py %else # Reconfigure intersphinx to use the local inventory. sed -e '/^ \+.python.:/s,None,"%{_docdir}/python3-docs/html/objects.inv",' -i docs/conf.py %endif # https://docs.fedoraproject.org/en-US/packaging-guidelines/Python/#_linters sed -r -i '/\b(pytest-cov|flake8(-quotest)?)\b/d' setup.py # https://pypi.org/project/doubles/ is not yet packaged, and does not seem to # be used in practice. sed -r -i '/\bdoubles\b/d' setup.py %if %{without gevent} # https://bugzilla.redhat.com/show_bug.cgi?id=2034654 sed -r -i '/\bgevent\b/d' setup.py %endif %generate_buildrequires %pyproject_buildrequires -x tests %build %pyproject_wheel # Generate the documentation. for target in info %{?with_doc_pdf:latex} do PYTHONPATH="%{pyproject_build_lib}" \ %make_build -C docs "${target}" SPHINXOPTS='%{?_smp_mflags}' done %if %{with doc_pdf} %make_build -C docs/_build/latex LATEXMKOPTS='-quiet' %endif %install %pyproject_install %pyproject_save_files opentracing mkdir -p %{buildroot}%{_infodir} cp -p docs/_build/texinfo/opentracing-python.info %{buildroot}%{_infodir}/ %check # Based on the “test” Makefile target, but with coverage options removed %pytest \ %if %{without gevent} --ignore='tests/scope_managers/test_gevent.py' \ %endif --tb short -rxs opentracing tests %package -n python3-opentracing Summary: %{summary} %description -n python3-opentracing %{_description} %files -n python3-opentracing -f %{pyproject_files} # pyproject_files handles LICENSE; verify with “rpm -qL -p …” %doc README.rst %doc CHANGELOG.rst %{_infodir}/opentracing-python.info* %package doc Summary: %{summary} - documentation %description doc %{_description} This package contains the documentation. %files doc %license LICENSE %if %{with doc_pdf} %doc docs/_build/latex/opentracing-python.pdf %endif %changelog * Fri Apr 22 2022 Benjamin A. Beasley - 2.4.0-4 - Assorted minor spec file cleanup - Build Sphinx-generated documentation as PDF instead of HTML - Switch to pyproject-rpm-macros (“new Python guidelines”) * Fri Jan 21 2022 Fedora Release Engineering - 2.4.0-3 - Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild * Fri Jul 23 2021 Fedora Release Engineering - 2.4.0-2 - Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild * Thu Dec 10 2020 Fabrice BAUZAC 2.4.0-1 - Initial version.