diff options
| author | CoprDistGit <infra@openeuler.org> | 2023-05-05 05:25:12 +0000 |
|---|---|---|
| committer | CoprDistGit <infra@openeuler.org> | 2023-05-05 05:25:12 +0000 |
| commit | a7787dd1ad5455b5a11aa0df07899739192e1762 (patch) | |
| tree | 57465e61b60cded47a3da44b1f5aa8cb9e637730 | |
| parent | f4bfb2cd32f62af812a73fb3fe8f8e90aefd3a0f (diff) | |
automatic import of python-fluvioopeneuler20.03
| -rw-r--r-- | .gitignore | 1 | ||||
| -rw-r--r-- | python-fluvio.spec | 309 | ||||
| -rw-r--r-- | sources | 1 |
3 files changed, 311 insertions, 0 deletions
@@ -0,0 +1 @@ +/fluvio-0.15.0.tar.gz diff --git a/python-fluvio.spec b/python-fluvio.spec new file mode 100644 index 0000000..17fd1a0 --- /dev/null +++ b/python-fluvio.spec @@ -0,0 +1,309 @@ +%global _empty_manifest_terminate_build 0 +Name: python-fluvio +Version: 0.15.0 +Release: 1 +Summary: Python client library for Fluvio +License: APACHE +URL: https://www.fluvio.io/ +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/8b/ad/0d538ee67a58270d3224e6868715383e650aef496a61a5e272e346377a4d/fluvio-0.15.0.tar.gz +BuildArch: noarch + + +%description +<h1 align="center">Fluvio Client for Python</h1> +<div align="center"> + <strong> + Python binding for Fluvio streaming platform. + </strong> +</div> +<br /> + +[](https://github.com/infinyon/fluvio-client-python/actions/workflows/cloud.yml) +[](https://github.com/infinyon/fluvio-client-python/blob/master/LICENSE-APACHE) +[](https://img.shields.io/pypi/v/fluvio.svg) + +## Documentation + +Fluvio client uses [pdoc](https://github.com/mitmproxy/pdoc) to generate the client API [documentation](https://infinyon.github.io/fluvio-client-python/fluvio.html). + +## Installation + +``` +pip install fluvio +``` + +This will get the wheel for the os/architecture of the installation system if available, otherwise it will try to build from source. If building from source, you will need the rust compiler and maybe some operating system sources. + +# Example Usage + +## Producer +```python +from fluvio import Fluvio +fluvio = Fluvio.connect() +producer = fluvio.topic_producer('my-topic') +producer.send_string("FOOBAR") +``` + +## Consumer +```python +from fluvio import (Fluvio, Offset) +fluvio = Fluvio.connect() +consumer = fluvio.partition_consumer('my-topic-while', 0) +stream = consumer.stream(Offset.beginning()) + +for i in stream: + print(i.value_string()) +``` + +# Developer Notes + +This project uses [flapigen](https://github.com/Dushistov/flapigen-rs) to +genate the C static library and +[setuptools-rust](https://github.com/PyO3/setuptools-rust) to bundle it into a +python package. For cross platform builds, + [cibuildwheel](https://github.com/joerick/cibuildwheel) is used. + +Running the tests locally require having already setup a [fluvio +locally](https://www.fluvio.io/docs/getting-started/fluvio-local/) or on +[fluvio cloud](https://cloud.fluvio.io). + + +Add python unit tests in the `tests` directory using the built in python +[`unittest` framework](https://docs.python.org/3/library/unittest.html) + +You should probably stick to using `make integration-tests` which will create the [virtual +environment](https://docs.python.org/3/tutorial/venv.html) and install the +package in the site-packages in the venv directory. This makes sure that the +package is also packaged correctly. + +If you'd like more rapid testing, once you've got the virtual environment +activated, `python setup.py test` will compile the rust as a static library and +put it as `fluvio/fluvio_python.cpython-39-x86_64-linux-gnu.so`. This filename +is dependent on the host OS and python version. +FLUVIO_CLOUD_TEST_PASSWORD` to your fork's secrets. + +When submitting a PR, CI checks a few things: +* `make integration-tests` against a fluvio cluster in CI. +* `make macos-ci-tests` with no fluvio cluster present (the macOS github runner is flakey) to verify linking is done correctly. +* `make lint`. This checks that [`cargo +fmt`](https://github.com/rust-lang/rustfmt), +[`flake8`](https://pypi.org/project/flake8) and +[`black`](https://pypi.org/project/black/) are all clear. + + +%package -n python3-fluvio +Summary: Python client library for Fluvio +Provides: python-fluvio +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-fluvio +<h1 align="center">Fluvio Client for Python</h1> +<div align="center"> + <strong> + Python binding for Fluvio streaming platform. + </strong> +</div> +<br /> + +[](https://github.com/infinyon/fluvio-client-python/actions/workflows/cloud.yml) +[](https://github.com/infinyon/fluvio-client-python/blob/master/LICENSE-APACHE) +[](https://img.shields.io/pypi/v/fluvio.svg) + +## Documentation + +Fluvio client uses [pdoc](https://github.com/mitmproxy/pdoc) to generate the client API [documentation](https://infinyon.github.io/fluvio-client-python/fluvio.html). + +## Installation + +``` +pip install fluvio +``` + +This will get the wheel for the os/architecture of the installation system if available, otherwise it will try to build from source. If building from source, you will need the rust compiler and maybe some operating system sources. + +# Example Usage + +## Producer +```python +from fluvio import Fluvio +fluvio = Fluvio.connect() +producer = fluvio.topic_producer('my-topic') +producer.send_string("FOOBAR") +``` + +## Consumer +```python +from fluvio import (Fluvio, Offset) +fluvio = Fluvio.connect() +consumer = fluvio.partition_consumer('my-topic-while', 0) +stream = consumer.stream(Offset.beginning()) + +for i in stream: + print(i.value_string()) +``` + +# Developer Notes + +This project uses [flapigen](https://github.com/Dushistov/flapigen-rs) to +genate the C static library and +[setuptools-rust](https://github.com/PyO3/setuptools-rust) to bundle it into a +python package. For cross platform builds, + [cibuildwheel](https://github.com/joerick/cibuildwheel) is used. + +Running the tests locally require having already setup a [fluvio +locally](https://www.fluvio.io/docs/getting-started/fluvio-local/) or on +[fluvio cloud](https://cloud.fluvio.io). + + +Add python unit tests in the `tests` directory using the built in python +[`unittest` framework](https://docs.python.org/3/library/unittest.html) + +You should probably stick to using `make integration-tests` which will create the [virtual +environment](https://docs.python.org/3/tutorial/venv.html) and install the +package in the site-packages in the venv directory. This makes sure that the +package is also packaged correctly. + +If you'd like more rapid testing, once you've got the virtual environment +activated, `python setup.py test` will compile the rust as a static library and +put it as `fluvio/fluvio_python.cpython-39-x86_64-linux-gnu.so`. This filename +is dependent on the host OS and python version. +FLUVIO_CLOUD_TEST_PASSWORD` to your fork's secrets. + +When submitting a PR, CI checks a few things: +* `make integration-tests` against a fluvio cluster in CI. +* `make macos-ci-tests` with no fluvio cluster present (the macOS github runner is flakey) to verify linking is done correctly. +* `make lint`. This checks that [`cargo +fmt`](https://github.com/rust-lang/rustfmt), +[`flake8`](https://pypi.org/project/flake8) and +[`black`](https://pypi.org/project/black/) are all clear. + + +%package help +Summary: Development documents and examples for fluvio +Provides: python3-fluvio-doc +%description help +<h1 align="center">Fluvio Client for Python</h1> +<div align="center"> + <strong> + Python binding for Fluvio streaming platform. + </strong> +</div> +<br /> + +[](https://github.com/infinyon/fluvio-client-python/actions/workflows/cloud.yml) +[](https://github.com/infinyon/fluvio-client-python/blob/master/LICENSE-APACHE) +[](https://img.shields.io/pypi/v/fluvio.svg) + +## Documentation + +Fluvio client uses [pdoc](https://github.com/mitmproxy/pdoc) to generate the client API [documentation](https://infinyon.github.io/fluvio-client-python/fluvio.html). + +## Installation + +``` +pip install fluvio +``` + +This will get the wheel for the os/architecture of the installation system if available, otherwise it will try to build from source. If building from source, you will need the rust compiler and maybe some operating system sources. + +# Example Usage + +## Producer +```python +from fluvio import Fluvio +fluvio = Fluvio.connect() +producer = fluvio.topic_producer('my-topic') +producer.send_string("FOOBAR") +``` + +## Consumer +```python +from fluvio import (Fluvio, Offset) +fluvio = Fluvio.connect() +consumer = fluvio.partition_consumer('my-topic-while', 0) +stream = consumer.stream(Offset.beginning()) + +for i in stream: + print(i.value_string()) +``` + +# Developer Notes + +This project uses [flapigen](https://github.com/Dushistov/flapigen-rs) to +genate the C static library and +[setuptools-rust](https://github.com/PyO3/setuptools-rust) to bundle it into a +python package. For cross platform builds, + [cibuildwheel](https://github.com/joerick/cibuildwheel) is used. + +Running the tests locally require having already setup a [fluvio +locally](https://www.fluvio.io/docs/getting-started/fluvio-local/) or on +[fluvio cloud](https://cloud.fluvio.io). + + +Add python unit tests in the `tests` directory using the built in python +[`unittest` framework](https://docs.python.org/3/library/unittest.html) + +You should probably stick to using `make integration-tests` which will create the [virtual +environment](https://docs.python.org/3/tutorial/venv.html) and install the +package in the site-packages in the venv directory. This makes sure that the +package is also packaged correctly. + +If you'd like more rapid testing, once you've got the virtual environment +activated, `python setup.py test` will compile the rust as a static library and +put it as `fluvio/fluvio_python.cpython-39-x86_64-linux-gnu.so`. This filename +is dependent on the host OS and python version. +FLUVIO_CLOUD_TEST_PASSWORD` to your fork's secrets. + +When submitting a PR, CI checks a few things: +* `make integration-tests` against a fluvio cluster in CI. +* `make macos-ci-tests` with no fluvio cluster present (the macOS github runner is flakey) to verify linking is done correctly. +* `make lint`. This checks that [`cargo +fmt`](https://github.com/rust-lang/rustfmt), +[`flake8`](https://pypi.org/project/flake8) and +[`black`](https://pypi.org/project/black/) are all clear. + + +%prep +%autosetup -n fluvio-0.15.0 + +%build +%py3_build + +%install +%py3_install +install -d -m755 %{buildroot}/%{_pkgdocdir} +if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi +if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi +if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi +if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi +pushd %{buildroot} +if [ -d usr/lib ]; then + find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/lib64 ]; then + find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/bin ]; then + find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/sbin ]; then + find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst +fi +touch doclist.lst +if [ -d usr/share/man ]; then + find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst +fi +popd +mv %{buildroot}/filelist.lst . +mv %{buildroot}/doclist.lst . + +%files -n python3-fluvio -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Fri May 05 2023 Python_Bot <Python_Bot@openeuler.org> - 0.15.0-1 +- Package Spec generated @@ -0,0 +1 @@ +7670b254b4ed6b0c1592756352c1b641 fluvio-0.15.0.tar.gz |
