#
# spec file for package python-streamz
#
# Copyright (c) 2022 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/
#
%{?!python_module:%define python_module() python3-%{**}}
%define skip_python2 1
Name: python-streamz
Version: 0.6.3
Release: 0
Summary: Tool to build continuous data pipelines
License: BSD-3-Clause
Group: Development/Languages/Python
URL: https://github.com/python-streamz/streamz/
Source: https://files.pythonhosted.org/packages/source/s/streamz/streamz-%{version}.tar.gz
# PATCH-FIX-UPSTREAM streamz-pr434-asyncdask.patch -- gh#python-streamz/streamz#434, gh#python-streamz/streamz#439
Patch1: streamz-pr434-asyncdask.patch
# PATCH-FIX-OPENSUSE streamz-opensuse-python-exec.patch -- call tests with correct flavor
Patch2: streamz-opensuse-python-exec.patch
BuildRequires: %{python_module setuptools}
BuildRequires: fdupes
BuildRequires: python-rpm-macros
Requires: python-six
Requires: python-toolz
Requires: python-tornado
Requires: python-zict
Recommends: python-certifi
Recommends: python-dask
Recommends: python-dask-dataframe
Recommends: python-dask-distributed
Recommends: python-distributed
Recommends: python-graphviz
Recommends: python-networkx
Recommends: python-pandas
BuildArch: noarch
# SECTION test requirements
BuildRequires: %{python_module certifi}
BuildRequires: %{python_module confluent-kafka}
BuildRequires: %{python_module dask if %python-base < 3.10}
BuildRequires: %{python_module dask-dataframe if %python-base < 3.10}
BuildRequires: %{python_module dask-distributed if %python-base < 3.10}
BuildRequires: %{python_module distributed if %python-base < 3.10}
BuildRequires: %{python_module flaky}
BuildRequires: %{python_module graphviz}
BuildRequires: %{python_module ipywidgets}
BuildRequires: %{python_module networkx}
BuildRequires: %{python_module pandas}
BuildRequires: %{python_module pytest-asyncio}
BuildRequires: %{python_module pytest}
BuildRequires: %{python_module requests}
BuildRequires: %{python_module six}
BuildRequires: %{python_module toolz}
BuildRequires: %{python_module tornado}
BuildRequires: %{python_module zict}
BuildRequires: graphviz
BuildRequires: graphviz-gnome
# /SECTION
%python_subpackages
%description
Streamz helps you build pipelines to manage continuous streams of data.
%prep
%autosetup -p1 -n streamz-%{version}
%build
%python_build
%install
%python_install
%python_expand %fdupes %{buildroot}%{$python_sitelib}
%check
# infinite loop because the automatic skip does not work here; the kafka tests need a docker container with STREAMZ_LAUNCH_KAFKA=true
donttest="test_from_kafka or test_to_kafka"
# no dask on python310 yet: this disables a majority of the test suite, but dask and kafka are nominally optional
python310_flags="--ignore streamz/dataframe/tests/test_dataframes.py"
python310_flags+=" --ignore streamz/tests/test_core.py"
python310_flags+=" --ignore streamz/tests/test_kafka.py"
if [ $(getconf LONG_BIT) -eq 32 ]; then
# don't test on 32-bit: 64-bit datatypes expected
donttest+=" or test_dataframes"
fi
# flaky: some tests are very fragile when run server-side
%pytest -m "not network" --asyncio-mode=auto --force-flaky --max-runs=10 --no-success-flaky-report -rsfE ${$python_flags} -k "not ($donttest)"
%files %{python_files}
%doc README.rst
%license LICENSE.txt
%{python_sitelib}/streamz
%{python_sitelib}/streamz-%{version}*-info
%changelog