forked from pool/python-pandas
704 lines
23 KiB
RPMSpec
704 lines
23 KiB
RPMSpec
|
#
|
||
|
# spec file for package python-pandas
|
||
|
#
|
||
|
# Copyright (c) 2024 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}
|
||
|
%{?sle15_python_module_pythons}
|
||
|
|
||
|
%if "%{flavor}" == ""
|
||
|
%define psuffix %{nil}
|
||
|
%bcond_with test
|
||
|
%else
|
||
|
%define psuffix -%{flavor}
|
||
|
%bcond_without test
|
||
|
%if "%{flavor}" != "test-py310"
|
||
|
%define skip_python310 1
|
||
|
%endif
|
||
|
%if "%{flavor}" != "test-py311"
|
||
|
%define skip_python311 1
|
||
|
%endif
|
||
|
%if "%{flavor}" != "test-py312"
|
||
|
%define skip_python312 1
|
||
|
%endif
|
||
|
# Skip empty buildsets, last one is for sle15_python_module_pythons
|
||
|
%if "%{shrink:%{pythons}}" == "" || ("%pythons" == "python311" && 0%{?skip_python311})
|
||
|
ExclusiveArch: donotbuild
|
||
|
%define python_module() %flavor-not-enabled-in-buildset-for-suse-%{?suse_version}
|
||
|
%endif
|
||
|
%endif
|
||
|
|
||
|
# Only test the core functionality in Ring1 (Lettered Staging)
|
||
|
%bcond_with ringdisabled
|
||
|
# s3fs not available
|
||
|
%bcond_with aws
|
||
|
# pandas-gbq not available
|
||
|
%bcond_with gcp
|
||
|
# xlsb not available
|
||
|
%bcond_with xslb
|
||
|
%bcond_with consortium_standard
|
||
|
%bcond_with calamine
|
||
|
%bcond_with adbc
|
||
|
# depend/not depend on python-pyarrow and apache-arrow [bsc#1218592]
|
||
|
%bcond_without pyarrow
|
||
|
|
||
|
%if %{suse_version} <= 1500
|
||
|
# requires __has_builtin with keywords
|
||
|
%define gccver 13
|
||
|
%endif
|
||
|
Name: python-pandas%{psuffix}
|
||
|
# Set version through _service
|
||
|
Version: 2.2.2
|
||
|
Release: 0
|
||
|
Summary: Python data structures for data analysis, time series, and statistics
|
||
|
License: BSD-3-Clause
|
||
|
URL: https://pandas.pydata.org/
|
||
|
# SourceRepository: https://github.com/pandas-dev/pandas
|
||
|
# Must be created by cloning through `osc service runall`: gh#pandas-dev/pandas#54903, gh#pandas-dev/pandas#54907
|
||
|
Source0: pandas-%{version}.tar.gz
|
||
|
# PATCH-FIX-UPSTREAM pandas-pr58269-pyarrow16xpass.patch -- gh#pandas-dev/pandas#58269
|
||
|
Patch0: pandas-pr58269-pyarrow16xpass.patch
|
||
|
# PATCH-FIX-UPSTREAM pandas-pr58484-matplotlib.patch -- gh#pandas-dev/pandas#58484 mcepl@suse.com, make pandas compatible with the modern matplotlib
|
||
|
Patch2: pandas-pr58484-matplotlib.patch
|
||
|
# PATCH-FIX-UPSTREAM pandas-pr59175-matplotlib.patch -- gh#pandas-dev/pandas#59175
|
||
|
Patch3: https://github.com/pandas-dev/pandas/pull/59175.patch#/pandas-pr59175-matplotlib.patch
|
||
|
# PATCH-FIX-UPSTREAM pandas-pr59353-np2eval.patch -- gh#pandas-dev/pandas#59144 backported to 2.2, no new tests, see gh#pandas-dev/pandas#58548, gh#pandas-dev/pandas#59353
|
||
|
Patch4: pandas-pr59353-np2eval.patch
|
||
|
%if !%{with test}
|
||
|
BuildRequires: %{python_module Cython >= 3.0.5}
|
||
|
BuildRequires: %{python_module devel >= 3.9}
|
||
|
BuildRequires: %{python_module meson-python >= 0.13.1}
|
||
|
BuildRequires: %{python_module numpy-devel >= 1.26}
|
||
|
BuildRequires: %{python_module pip}
|
||
|
BuildRequires: %{python_module versioneer-toml}
|
||
|
BuildRequires: %{python_module wheel}
|
||
|
BuildRequires: fdupes
|
||
|
BuildRequires: gcc%{?gccver}-c++
|
||
|
BuildRequires: git-core
|
||
|
BuildRequires: meson >= 1.2.1
|
||
|
%endif
|
||
|
BuildRequires: python-rpm-macros
|
||
|
Requires: python-python-dateutil >= 2.8.2
|
||
|
Requires: python-pytz >= 2020.1
|
||
|
Requires: timezone >= 2022a
|
||
|
Obsoletes: python-pandas-doc < %{version}
|
||
|
Provides: python-pandas-doc = %{version}
|
||
|
%if 0%{python_version_nodots} < 311
|
||
|
Requires: python-numpy >= 1.22.4
|
||
|
%else
|
||
|
%if 0%{python_version_nodots} == 311
|
||
|
Requires: python-numpy >= 1.23.2
|
||
|
%else
|
||
|
Requires: python-numpy >= 1.26
|
||
|
%endif
|
||
|
%endif
|
||
|
# SECTION extras
|
||
|
Recommends: python-pandas-performance
|
||
|
Recommends: python-pandas-pyarrow
|
||
|
Suggests: python-pandas-all
|
||
|
Suggests: python-pandas-clipboard
|
||
|
Suggests: python-pandas-compression
|
||
|
Suggests: python-pandas-computation
|
||
|
Suggests: python-pandas-excel
|
||
|
Suggests: python-pandas-fss
|
||
|
Suggests: python-pandas-hdf5
|
||
|
Suggests: python-pandas-html
|
||
|
Suggests: python-pandas-mysql
|
||
|
Suggests: python-pandas-output_formatting
|
||
|
Suggests: python-pandas-plot
|
||
|
Suggests: python-pandas-postgresql
|
||
|
Suggests: python-pandas-spss
|
||
|
Suggests: python-pandas-sql-other
|
||
|
Suggests: python-pandas-test
|
||
|
Suggests: python-pandas-xml
|
||
|
%{?with_aws:Suggests: python-pandas-aws}
|
||
|
%{?with_gcp:Suggests: python-pandas-gcp}
|
||
|
%{?with_pyarrow:Suggests: python-pandas-parquet}
|
||
|
%{?with_pyarrow:Suggests: python-pandas-feather}
|
||
|
# /SECTION
|
||
|
%if %{with test}
|
||
|
# required for sqlite3 tests
|
||
|
BuildRequires: %{pythons}
|
||
|
BuildRequires: %{python_module pandas-test = %{version}}
|
||
|
BuildRequires: memory-constraints
|
||
|
BuildRequires: xvfb-run
|
||
|
%if !%{with ringdisabled}
|
||
|
BuildRequires: %{python_module IPython}
|
||
|
BuildRequires: %{python_module dask-array}
|
||
|
BuildRequires: %{python_module dask-dataframe}
|
||
|
BuildRequires: %{python_module pandas-all = %{version}}
|
||
|
BuildRequires: %{python_module pandas-clipboard = %{version}}
|
||
|
BuildRequires: %{python_module pandas-compression = %{version}}
|
||
|
BuildRequires: %{python_module pandas-computation = %{version}}
|
||
|
BuildRequires: %{python_module pandas-excel = %{version}}
|
||
|
%{?with_pyarrow:BuildRequires: %{python_module pandas-feather = %{version}}}
|
||
|
BuildRequires: %{python_module pandas-fss = %{version}}
|
||
|
BuildRequires: %{python_module pandas-hdf5 = %{version}}
|
||
|
BuildRequires: %{python_module pandas-html = %{version}}
|
||
|
BuildRequires: %{python_module pandas-mysql = %{version}}
|
||
|
BuildRequires: %{python_module pandas-output_formatting = %{version}}
|
||
|
%{?with_pyarrow:BuildRequires: %{python_module pandas-parquet = %{version}}}
|
||
|
BuildRequires: %{python_module pandas-performance = %{version}}
|
||
|
BuildRequires: %{python_module pandas-plot = %{version}}
|
||
|
BuildRequires: %{python_module pandas-postgresql = %{version}}
|
||
|
%{?with_pyarrow:BuildRequires: %{python_module pandas-pyarrow = %{version}}}
|
||
|
BuildRequires: %{python_module pandas-spss = %{version}}
|
||
|
BuildRequires: %{python_module pandas-sql-other = %{version}}
|
||
|
BuildRequires: %{python_module pandas-xml = %{version}}
|
||
|
BuildRequires: xclip
|
||
|
%{?with_aws:BuildRequires: %{python_module pandas-aws = %{version}}}
|
||
|
%{?with_gcp:BuildRequires: %{python_module pandas-gcp = %{version}}}
|
||
|
%{?with_consortium_standard:BuildRequires: %{python_module pandas-consortium-standard = %{version}}}
|
||
|
%endif
|
||
|
%endif
|
||
|
%python_subpackages
|
||
|
|
||
|
%description
|
||
|
Pandas is a Python package providing data structures designed for
|
||
|
working with structured (tabular, multidimensional, potentially
|
||
|
heterogeneous) and time series data. It is a high-level building
|
||
|
block for doing data analysis in Python.
|
||
|
|
||
|
%package test
|
||
|
Summary: The python pandas[test] extra
|
||
|
Requires: python-hypothesis >= 6.46.1
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-pytest >= 7.3.2
|
||
|
Requires: python-pytest-xdist >= 2.2.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description test
|
||
|
This package provides the [test] extra for python-pandas
|
||
|
|
||
|
%package pyarrow
|
||
|
Summary: The python pandas[pyarrow] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-pyarrow >= 10.0.1
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description pyarrow
|
||
|
This package provides the [pyarrow] extra for python-pandas
|
||
|
|
||
|
%package performance
|
||
|
Summary: The python pandas[performance] extra
|
||
|
Requires: python-Bottleneck >= 1.3.6
|
||
|
Requires: python-numba >= 0.56.4
|
||
|
Requires: python-numexpr >= 2.8.4
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description performance
|
||
|
This package provides the [performance] extra for python-pandas
|
||
|
|
||
|
It is highly recommended to install this subpackage, as its dependencies
|
||
|
provide speed improvements, especially when working with large data sets.
|
||
|
|
||
|
%package computation
|
||
|
Summary: The python pandas[computation] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-scipy >= 1.10.0
|
||
|
Requires: python-xarray >= 2022.12.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description computation
|
||
|
This package provides the [computation] extra for python-pandas
|
||
|
|
||
|
%package fss
|
||
|
Summary: The python pandas[fss] extra
|
||
|
Requires: python-fsspec >= 2022.11
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description fss
|
||
|
This package provides the [fss] extra for python-pandas
|
||
|
|
||
|
%package aws
|
||
|
Summary: The python pandas[aws] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-s3fs >= 2022.11
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description aws
|
||
|
This package provides the [aws] extra for python-pandas
|
||
|
|
||
|
%package gcp
|
||
|
Summary: The python pandas[gcp] extra
|
||
|
Requires: python-gcsfs >= 2022.11
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-pandas-gbq >= 0.19.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description gcp
|
||
|
This package provides the [gcp] extra for python-pandas
|
||
|
|
||
|
%package excel
|
||
|
Summary: The python pandas[excel] extra
|
||
|
Requires: python-odfpy >= 1.4.1
|
||
|
Requires: python-openpyxl >= 3.1.0
|
||
|
Requires: python-pandas = %{version}
|
||
|
%{?with_xlsb:Requires: python-pyxlsb >= 1.0.10}
|
||
|
Requires: python-XlsxWriter >= 3.0.5
|
||
|
Requires: python-xlrd >= 2.0.1
|
||
|
%{?with_calamine:Requires: python-calamine >= 0.1.7}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description excel
|
||
|
This package provides the [excel] extra for python-pandas.
|
||
|
(Except for pyxlsb and calamine which are not available as openSUSE rpm package)
|
||
|
|
||
|
%package parquet
|
||
|
Summary: The python pandas[parquet] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-pyarrow >= 10.0.1
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description parquet
|
||
|
This package provides the [parquet] extra for python-pandas
|
||
|
|
||
|
%package feather
|
||
|
Summary: The python pandas[feather] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-pyarrow >= 10.0.1
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description feather
|
||
|
This package provides the [feather] extra for python-pandas
|
||
|
|
||
|
%package hdf5
|
||
|
Summary: The python pandas[hdf5] extra
|
||
|
Requires: python-blosc
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-tables >= 3.8.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description hdf5
|
||
|
This package provides the [hdf5] extra for python-pandas
|
||
|
|
||
|
%package spss
|
||
|
Summary: The python pandas[spss] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-pyreadstat >= 1.2.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description spss
|
||
|
This package provides the [spss] extra for python-pandas
|
||
|
|
||
|
%package postgresql
|
||
|
Summary: The python pandas[postgresql] extra
|
||
|
Requires: python-SQLAlchemy >= 2.0.0
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-psycopg2 >= 2.9.6
|
||
|
%{?with_adbc:Requires: python-adbc-driver-postgresql >= 0.8}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description postgresql
|
||
|
This package provides the [postgresql] extra for python-pandas
|
||
|
|
||
|
%package mysql
|
||
|
Summary: The python pandas[mysql] extra
|
||
|
Requires: python-PyMySQL >= 1.0.2
|
||
|
Requires: python-SQLAlchemy >= 2.0.0
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description mysql
|
||
|
This package provides the [mysql] extra for python-pandas
|
||
|
|
||
|
%package sql-other
|
||
|
Summary: The python pandas[sql-other] extra
|
||
|
Requires: python-SQLAlchemy >= 2.0.0
|
||
|
%{?with_adbc:Requires: python-adbc-driver-postgresql >= 0.8}
|
||
|
%{?with_adbc:Requires: python-adbc-driver-sqlite >= 0.8}
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description sql-other
|
||
|
This package provides the [sql-other] extra for python-pandas
|
||
|
|
||
|
%package html
|
||
|
Summary: The python pandas[html] extra
|
||
|
Requires: python-beautifulsoup4 >= 4.11.2
|
||
|
Requires: python-html5lib >= 1.1
|
||
|
Requires: python-lxml >= 4.9.2
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description html
|
||
|
This package provides the [html] extra for python-pandas
|
||
|
|
||
|
%package xml
|
||
|
Summary: The python pandas[xml] extra
|
||
|
Requires: python-lxml >= 4.9.2
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description xml
|
||
|
This package provides the [xml] extra for python-pandas
|
||
|
|
||
|
%package plot
|
||
|
Summary: The python pandas[plot] extra
|
||
|
Requires: python-matplotlib >= 3.6.3
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description plot
|
||
|
This package provides the [plot] extra for python-pandas
|
||
|
|
||
|
%package output_formatting
|
||
|
Summary: The python pandas[output_formatting] extra
|
||
|
Requires: python-Jinja2 >= 3.1.2
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-tabulate >= 0.9.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description output_formatting
|
||
|
This package provides the [output_formatting] extra for python-pandas
|
||
|
|
||
|
%package clipboard
|
||
|
Summary: The python pandas[clipboard] extra
|
||
|
Requires: python-PyQt5 >= 5.15.9
|
||
|
Requires: python-QtPy >= 2.3.0
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description clipboard
|
||
|
This package provides the [clipboard] extra for python-pandas
|
||
|
|
||
|
%package compression
|
||
|
Summary: The python pandas[compression] extra
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-zstandard >= 0.19.0
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description compression
|
||
|
This package provides the [compression] extra for python-pandas
|
||
|
|
||
|
%package consortium-standard
|
||
|
Summary: The python pandas[consortium-standard] extra
|
||
|
Requires: python-dataframe-api-compat >= 0.1.7
|
||
|
Requires: python-pandas = %{version}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description consortium-standard
|
||
|
This package provides the [consortium-standard] extra for python-pandas
|
||
|
|
||
|
%package all
|
||
|
Summary: The python pandas[all] extra
|
||
|
Requires: python-Bottleneck >= 1.3.6
|
||
|
Requires: python-Jinja2 >= 3.1.2
|
||
|
Requires: python-PyMySQL >= 1.0.2
|
||
|
Requires: python-PyQt5 >= 5.15.9
|
||
|
Requires: python-QtPy >= 2.3.0
|
||
|
Requires: python-SQLAlchemy >= 2
|
||
|
Requires: python-XlsxWriter >= 3.0.5
|
||
|
Requires: python-beautifulsoup4 >= 4.11.2
|
||
|
%{?with_adbc:Requires: python-adbc-driver-postgresql >= 0.8}
|
||
|
%{?with_adbc:Requires: python-adbc-driver-sqlite >= 0.8}
|
||
|
Requires: python-blosc
|
||
|
%{?with_calamine:Requires: python-calamine >= 0.1.7}
|
||
|
%{?with_pyarrow:Requires: python-fastparquet >= 2022.12}
|
||
|
Requires: python-fsspec >= 2022.11
|
||
|
Requires: python-gcsfs >= 2022.11
|
||
|
Requires: python-html5lib >= 1.1
|
||
|
Requires: python-hypothesis >= 6.46.1
|
||
|
Requires: python-lxml >= 4.9.2
|
||
|
Requires: python-matplotlib >= 3.6.3
|
||
|
Requires: python-numba >= 0.56.4
|
||
|
Requires: python-numexpr >= 2.8.4
|
||
|
Requires: python-odfpy >= 1.4.1
|
||
|
Requires: python-openpyxl >= 3.1.0
|
||
|
Requires: python-pandas = %{version}
|
||
|
Requires: python-psycopg2 >= 2.9.6
|
||
|
%{?with_pyarrow:Requires: python-pyarrow >= 10.0.1}
|
||
|
Requires: python-pyreadstat >= 1.2.0
|
||
|
Requires: python-pytest >= 7.3.2
|
||
|
Requires: python-pytest-xdist >= 2.2.0
|
||
|
Requires: python-scipy >= 1.10.0
|
||
|
Requires: python-tables >= 3.8.0
|
||
|
Requires: python-tabulate >= 0.9
|
||
|
Requires: python-xarray >= 2022.12
|
||
|
Requires: python-xlrd >= 2.0.1
|
||
|
Requires: python-zstandard >= 0.19.0
|
||
|
%{?with_aws:Requires: python-s3fs >= 2022.05.0}
|
||
|
%{?with_gcp:Requires: python-pandas-gbq >= 0.19}
|
||
|
%{?with_xslb:Requires: python-pyxlsb >= 1.0.10}
|
||
|
%{?with_consortium_standard: Requires: python-dataframe-api-compat >= 0.1.7}
|
||
|
BuildArch: noarch
|
||
|
|
||
|
%description all
|
||
|
This package provides most the [all] extra for python-pandas
|
||
|
|
||
|
Some requirements defined in the PyPI package are left out
|
||
|
because they are not available as openSUSE RPM packages:
|
||
|
|
||
|
* pandas-gbq
|
||
|
* pyxlsb
|
||
|
* s3fs
|
||
|
* dataframe-api-compat
|
||
|
* adbc-driver-postgresql
|
||
|
* adbc-driver-sqlite
|
||
|
* calamine
|
||
|
|
||
|
You can install them directly through `pip%{python_bin_suffix} install --user`, if needed.
|
||
|
|
||
|
%prep
|
||
|
# ATTENTION: unpack and generate _version_meson.py before any patches and modifications for a clean version
|
||
|
%setup -q -n pandas-%{version}
|
||
|
%if !%{with test}
|
||
|
# use the last one from the buildset: need versioneer installed
|
||
|
%python_expand genpython="%__$python"
|
||
|
${genpython} generate_version.py -o _version_meson.py
|
||
|
sed -i "s|'generate_version.py',|'${genpython}', 'generate_version.py',|" meson.build
|
||
|
# don't require the PyPI data only tzdata package, we use the timezone RPM package
|
||
|
sed -i '/dependencies = \[/,/\]/ {/tzdata.*>=/d}' pyproject.toml
|
||
|
%endif
|
||
|
%autopatch -p1
|
||
|
|
||
|
%build
|
||
|
%if !%{with test}
|
||
|
%{?gccver:export CXX=g++-%{gccver}}
|
||
|
%{?gccver:export CC=gcc-%{gccver}}
|
||
|
export CFLAGS="%{optflags} -fno-strict-aliasing"
|
||
|
%pyproject_wheel
|
||
|
%endif
|
||
|
|
||
|
%install
|
||
|
%if !%{with test}
|
||
|
%pyproject_install
|
||
|
%{python_expand #
|
||
|
find %{buildroot}%{$python_sitearch}/pandas/_libs -name '*.[ch]' -delete
|
||
|
sed -i -e '/.[ch],/d' %{buildroot}%{$python_sitearch}/pandas-%{version}.dist-info/RECORD
|
||
|
%fdupes %{buildroot}%{$python_sitearch}
|
||
|
}
|
||
|
%else
|
||
|
# Copy the installed package back into the source tree
|
||
|
# This is equivalent to build and install editable (pip install -e .), and the only way
|
||
|
# to have a passing test suite due to how the test collection works in pytest >= 7.
|
||
|
# Only works for separate python flavors in multibuild.
|
||
|
%python_expand cp -rf %{$python_sitearch}/pandas/* pandas/
|
||
|
%endif
|
||
|
|
||
|
%check
|
||
|
%if %{with test}
|
||
|
export LANG=en_US.UTF-8
|
||
|
export LC_ALL=en_US.UTF-8
|
||
|
export PYTHONDONTWRITEBYTECODE=1
|
||
|
# Workaround for pytest-xdist flaky collection order
|
||
|
# https://github.com/pytest-dev/pytest/issues/920
|
||
|
# https://github.com/pytest-dev/pytest/issues/1075
|
||
|
export PYTHONHASHSEED=1
|
||
|
# no network connection on obs
|
||
|
SKIP_MARKERS="network"
|
||
|
# clipboard not set up properly in build service without window manager
|
||
|
SKIP_MARKERS+=" or clipboard"
|
||
|
# skip tests which upstream marked for -n 1 only.
|
||
|
SKIP_MARKERS+=" or single_cpu"
|
||
|
# pytest-xdist worker crash
|
||
|
SKIP_TESTS="test_pivot_number_of_levels_larger_than_int32"
|
||
|
# no locally running database server
|
||
|
SKIP_TESTS+=" or psycopg2_engine or psycopg2_conn or pymysql_engine or pymysql_conn"
|
||
|
SKIP_TESTS+=" or test_psycopg2_schema_support"
|
||
|
SKIP_TESTS+=" or test_self_join_date_columns"
|
||
|
# expects a dirty git revision from git repo
|
||
|
SKIP_TESTS+=" or test_git_version"
|
||
|
%if "%{flavor}" == "test-py312"
|
||
|
# https://github.com/pandas-dev/pandas/pull/57391, proposed change is not necessarily the right one
|
||
|
SKIP_TESTS+=" or (test_scalar_unary and numexpr-pandas)"
|
||
|
%endif
|
||
|
# Numpy2: unexpected 'np.str_(...)' in error message
|
||
|
SKIP_TESTS+=" or test_group_subplot_invalid_column_name"
|
||
|
|
||
|
%ifarch %{ix86} %{arm32}
|
||
|
# https://github.com/pandas-dev/pandas/issues/31856
|
||
|
SKIP_TESTS+=" or test_maybe_promote_int_with_int"
|
||
|
# rounding error
|
||
|
SKIP_TESTS+=" or (test_rolling_quantile_interpolation_options and data1 and linear and 0.1)"
|
||
|
# overflow
|
||
|
SKIP_TESTS+=" or test_large_string_pyarrow"
|
||
|
SKIP_TESTS+=" or test_pandas_nullable_with_missing_values"
|
||
|
SKIP_TESTS+=" or test_pandas_nullable_without_missing_values"
|
||
|
SKIP_TESTS+=" or (test_to_datetime and TestOrigin and test_epoch)"
|
||
|
SKIP_TESTS+=" or test_td_mul_numeric_ndarray_0d"
|
||
|
SKIP_TESTS+=" or test_get_indexer_non_unique_wrong_dtype"
|
||
|
# pyarrow read-only errors
|
||
|
SKIP_TESTS+=" or test_left_join_multi_index"
|
||
|
SKIP_TESTS+=" or test_join_on_single_col_dup_on_right"
|
||
|
# dtype mismatch
|
||
|
SKIP_TESTS+=" or test_frame_setitem_dask_array_into_new_col"
|
||
|
SKIP_TESTS+=" or test_get_indexer_arrow_dictionary_target"
|
||
|
# numba formats not supported on 32-bit
|
||
|
SKIP_TESTS+=" or numba"
|
||
|
%endif
|
||
|
%ifarch %{ix86}
|
||
|
# overflows on i586
|
||
|
SKIP_TESTS+=" or test_encode_non_c_locale"
|
||
|
# intp != int32 (still numpy 1)?
|
||
|
SKIP_TESTS+=" or test_ensure_platform_int"
|
||
|
# fails on i586 (was gcc10-skip-one-test.patch)
|
||
|
SKIP_TESTS+=" or test_merge_on_ints_floats_warning"
|
||
|
%endif
|
||
|
%ifarch ppc64 s390x
|
||
|
# big endian type issues
|
||
|
SKIP_TESTS+=" or test_astype"
|
||
|
SKIP_TESTS+=" or test_to_numpy_string"
|
||
|
SKIP_TESTS+=" or (test_construction and test_to_numpy)"
|
||
|
SKIP_TESTS+=" or test_to_records_index_name"
|
||
|
SKIP_TESTS+=" or test_to_records_dtype"
|
||
|
SKIP_TESTS+=" or test_to_records_dict_like"
|
||
|
SKIP_TESTS+=" or (test_c_parser_only and test_unsupported_dtype)"
|
||
|
SKIP_TESTS+=" or test_td_mul_td64_ndarray_invalid"
|
||
|
%endif
|
||
|
%ifnarch x86_64
|
||
|
# type and numeric precision issues, partially reported for arm and marked xfail upstream but not for e.g. ppc
|
||
|
SKIP_TESTS+=" or (test_astype and test_subtype_integer_errors)"
|
||
|
SKIP_TESTS+=" or (test_to_numeric and test_downcast_nullable_numeric and data12-UInt64-signed-UInt64)"
|
||
|
SKIP_TESTS+=" or (test_rolling and test_rolling_var_numerical_issues)"
|
||
|
SKIP_TESTS+=" or (test_groupby and test_groupby_numerical_stability_sum_mean)"
|
||
|
SKIP_TESTS+=" or (test_groupby and test_groupby_numerical_stability_cumsum)"
|
||
|
SKIP_TESTS+=" or (test_c_parser_only and test_float_precision_options)"
|
||
|
# run the slow tests only on x86_64
|
||
|
SKIP_MARKERS+=" or slow or db"
|
||
|
%endif
|
||
|
|
||
|
# The test collection consumes a lot of memory per worker. This sets %%jobs.
|
||
|
%limit_build -m 3072
|
||
|
|
||
|
%{python_expand $python -c 'import pandas; print(pandas.__path__); print(pandas.show_versions())'
|
||
|
# cache: can't just say no cacheprovider, because one test checks for the --lf option of pytest-cache
|
||
|
xvfb-run pytest-%{$python_bin_suffix} -v -n %{jobs} -rsfE --dist=loadfile \
|
||
|
-o cache_dir=$PWD/.pytest_cache --cache-clear \
|
||
|
-m "not (${SKIP_MARKERS})" \
|
||
|
-k "not (${SKIP_TESTS})" \
|
||
|
pandas
|
||
|
}
|
||
|
%endif
|
||
|
|
||
|
%if !%{with test}
|
||
|
%files %{python_files}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%{python_sitearch}/pandas/
|
||
|
%{python_sitearch}/pandas-%{version}.dist-info
|
||
|
|
||
|
%files %{python_files test}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%if !%{with ringdisabled}
|
||
|
%files %{python_files pyarrow}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files performance}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%if 0%{python_version_nodots} >= 310
|
||
|
%files %{python_files computation}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
|
||
|
%files %{python_files fss}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%if %{with aws}
|
||
|
%files %{python_files aws}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
|
||
|
%if %{with gcp}
|
||
|
%files %{python_files gcp}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
|
||
|
%files %{python_files excel}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%if %{with pyarrow}
|
||
|
%files %{python_files parquet}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
|
||
|
%if %{with pyarrow}
|
||
|
%files %{python_files feather}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
|
||
|
%files %{python_files hdf5}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files spss}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files postgresql}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files mysql}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files sql-other}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files html}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files xml}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files plot}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files output_formatting}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files clipboard}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%files %{python_files compression}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
|
||
|
%if %{with consortium_standard}
|
||
|
%files %{python_files consortium-standard}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
|
||
|
%files %{python_files all}
|
||
|
%license LICENSE
|
||
|
%doc README.md
|
||
|
%endif
|
||
|
%endif
|
||
|
|
||
|
%changelog
|