forked from pool/python-trio
* Don't crash on import in Anaconda interpreters. * Add type hints. * When exiting a nursery block, the parent task always waits for child tasks to exit. This wait cannot be cancelled. However, previously, if you tried to cancel it, it *would* inject a `Cancelled` exception, even though it wasn't cancelled. Most users probably never noticed either way, but injecting a `Cancelled` here is not really useful, and in some rare cases caused confusion or problems, so Trio no longer does that. * If called from a thread spawned by `trio.to_thread.run_sync`, `trio.from_thread.run` and `trio.from_thread.run_sync` now reuse the task and cancellation status of the host task; * this means that context variables and cancel scopes naturally propagate 'through' threads spawned by Trio. You can also use `trio.from_thread.check_cancelled` to efficiently check for cancellation without reentering the Trio thread. * :func:`trio.lowlevel.start_guest_run` now does a bit more setup of the guest run before it returns to its caller, so that the caller can immediately make calls to :func:`trio.current_time`, :func:`trio.lowlevel.spawn_system_task`, :func:`trio.lowlevel.current_trio_token`, etc. * When a starting function raises before calling :func:`trio.TaskStatus.started`, :func:`trio.Nursery.start` will no longer wrap the exception in an undocumented :exc:`ExceptionGroup`. * To better reflect the underlying thread handling semantics, the keyword argument for `trio.to_thread.run_sync` that was OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-trio?expand=0&rev=39
110 lines
3.7 KiB
RPMSpec
110 lines
3.7 KiB
RPMSpec
#
|
|
# spec file
|
|
#
|
|
# Copyright (c) 2023 SUSE LLC
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
#
|
|
|
|
|
|
%global flavor @BUILD_FLAVOR@%{nil}
|
|
%if "%{flavor}" == "test"
|
|
%define psuffix -test
|
|
%bcond_without test
|
|
%else
|
|
%define psuffix %{nil}
|
|
%bcond_with test
|
|
%endif
|
|
%{?sle15_python_module_pythons}
|
|
Name: python-trio%{psuffix}
|
|
Version: 0.23.1
|
|
Release: 0
|
|
Summary: Python async/await-native I/O library
|
|
License: Apache-2.0 OR MIT
|
|
URL: https://github.com/python-trio/trio
|
|
Source: https://files.pythonhosted.org/packages/source/t/trio/trio-%{version}.tar.gz
|
|
BuildRequires: %{python_module attrs >= 20.1.0}
|
|
BuildRequires: %{python_module pip}
|
|
BuildRequires: %{python_module sortedcontainers}
|
|
BuildRequires: %{python_module wheel}
|
|
BuildRequires: fdupes
|
|
BuildRequires: netcfg
|
|
BuildRequires: python-rpm-macros
|
|
Requires: python-attrs >= 19.2.0
|
|
Requires: python-idna
|
|
Requires: python-outcome
|
|
Requires: python-sniffio >= 1.3.0
|
|
Requires: python-sortedcontainers
|
|
Requires: (python-exceptiongroup if python-base < 3.11)
|
|
BuildArch: noarch
|
|
%if %{with test}
|
|
BuildRequires: %{python_module astor >= 0.8}
|
|
BuildRequires: %{python_module async_generator >= 1.9}
|
|
BuildRequires: %{python_module base >= 3.8}
|
|
BuildRequires: %{python_module idna}
|
|
BuildRequires: %{python_module outcome}
|
|
BuildRequires: %{python_module pyOpenSSL}
|
|
BuildRequires: %{python_module pytest >= 5.0}
|
|
# for protocol specifications
|
|
BuildRequires: %{python_module sniffio >= 1.3.0}
|
|
BuildRequires: %{python_module trio = %{version}}
|
|
BuildRequires: %{python_module trustme}
|
|
BuildRequires: %{python_module yapf >= 0.27.0}
|
|
%if 0%{?suse_version} > 1500
|
|
BuildRequires: %{python_module exceptiongroup >= 1.0.0~rc9 if %{python}-base < 3.11}
|
|
%endif
|
|
%endif
|
|
%python_subpackages
|
|
|
|
%description
|
|
The Trio project produces an async/await-native I/O library for
|
|
Python. Like all async libraries, its main purpose is to help write
|
|
programs that do multiple things at the same time with parallelized
|
|
I/O, such as a web spider that wants to fetch lots of pages in
|
|
parallel, a web server that needs to juggle lots of downloads and
|
|
websocket connections at the same time, a process supervisor
|
|
monitoring multiple subprocesses. Compared to other libraries, Trio
|
|
has an obsessive focus on usability and correctness.
|
|
|
|
%prep
|
|
%autosetup -p1 -n trio-%{version}
|
|
sed -i '1{/^#!/d}' trio/_tools/gen_exports.py
|
|
|
|
%build
|
|
%pyproject_wheel
|
|
|
|
%install
|
|
%if %{without test}
|
|
%pyproject_install
|
|
%python_expand %fdupes %{buildroot}%{$python_sitelib}
|
|
%endif
|
|
|
|
%check
|
|
%if %{with test}
|
|
# test_static_tool_sees_all_symbols uses jedi/pylint for static analysis,
|
|
# pointless for us.
|
|
# test_SSLStream_generic deadlocks in OBS
|
|
# test_close_at_bad_time_for_send_all fails on PPC https://github.com/python-trio/trio/issues/1753
|
|
# test_local_address_real fails on qemu_linux_user targets
|
|
%pytest -k 'not (test_static_tool_sees_all_symbols or test_SSLStream_generic or test_close_at_bad_time_for_send_all or test_local_address_real)'
|
|
%endif
|
|
|
|
%if %{without test}
|
|
%files %{python_files}
|
|
%doc README.rst
|
|
%license LICENSE LICENSE.APACHE2 LICENSE.MIT
|
|
%{python_sitelib}/trio
|
|
%{python_sitelib}/trio-%{version}*-info
|
|
%endif
|
|
|
|
%changelog
|