diff --git a/.github/workflows/bench.yml b/.github/workflows/bench.yml index c1c1919d35b..d6d673f660c 100644 --- a/.github/workflows/bench.yml +++ b/.github/workflows/bench.yml @@ -83,10 +83,8 @@ jobs: - name: Run benchmarks run: | - cd pytests/pyo3-benchmarks - pip install -r requirements-dev.txt - pip install . - pytest --benchmark-json ../../output.json --benchmark-enable + pip install nox + nox -f pytests/noxfile.py -s bench -- --benchmark-json $(pwd)/output.json - name: Store benchmark result uses: rhysd/github-action-benchmark@v1 with: diff --git a/Cargo.toml b/Cargo.toml index 7552ea88883..e54ac6568af 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -130,10 +130,10 @@ harness = false [workspace] members = [ "pyo3-ffi", + "pyo3-build-config", "pyo3-macros", "pyo3-macros-backend", - "pytests/pyo3-benchmarks", - "pytests/pyo3-pytests", + "pytests", "examples", "xtask" ] diff --git a/Contributing.md b/Contributing.md index e7d9b69d732..4fc2c246381 100644 --- a/Contributing.md +++ b/Contributing.md @@ -9,7 +9,7 @@ If you want to become familiar with the codebase, see ## Getting started contributing -Please join in with any part of PyO3 which interests you. We use GitHub issues to record all bugs and ideas. Feel free to request an issue to be assigned to you if you want to work on it. +Please join in with any part of PyO3 which interests you. We use GitHub issues to record all bugs and ideas. Feel free to request an issue to be assigned to you if you want to work on it. You can browse the API of the non-public parts of PyO3 [here](https://pyo3.rs/internal/doc/pyo3/index.html). @@ -47,7 +47,7 @@ There are some specific areas of focus where help is currently needed for the do - Issues requesting documentation improvements are tracked with the [documentation](https://github.com/PyO3/pyo3/issues?q=is%3Aissue+is%3Aopen+label%3Adocumentation) label. - Not all APIs had docs or examples when they were made. The goal is to have documentation on all PyO3 APIs ([#306](https://github.com/PyO3/pyo3/issues/306)). If you see an API lacking a doc, please write one and open a PR! -You can build the docs (including all features) with +You can build the docs (including all features) with ```cargo +nightly pyo3_doc_scrape``` #### Doctests @@ -115,7 +115,7 @@ First, there are Rust-based benchmarks located in the `benches` subdirectory. As cargo +nightly bench -Second, there is a Python-based benchmark contained in the `pyo3-benchmarks` example. You can read more about it [here](examples/pyo3-benchmarks). +Second, there is a Python-based benchmark contained in the `pytests` subdirectory. You can read more about it [here](pytests). ## Sponsor this project diff --git a/Makefile b/Makefile index 5a6b6a18151..d7a87d47c9d 100644 --- a/Makefile +++ b/Makefile @@ -14,37 +14,22 @@ test: lint test_py test_py: @for example in examples/*/noxfile.py; do echo "-- Running nox for $$example --"; nox -f $$example/noxfile.py || exit 1; echo ""; done - @for package in pytests/*/noxfile.py; do echo "-- Running nox for $$package --"; nox -f $$package/noxfile.py || exit 1; echo ""; done + echo "-- Running nox for pytests/noxfile.py --"; + nox -f pytests/noxfile.py || exit 1; fmt_py: black . --check fmt_rust: cargo fmt --all -- --check - for package in pytests/*/; do cargo fmt --manifest-path $$package/Cargo.toml -- --check || exit 1; done fmt: fmt_rust fmt_py @true -coverage: - # cargo llvm-cov clean --workspace - # cargo llvm-cov $(COVERAGE_PACKAGES) --no-report - # cargo llvm-cov $(COVERAGE_PACKAGES) --no-report --features abi3 - # cargo llvm-cov $(COVERAGE_PACKAGES) --no-report --features $(ALL_ADDITIVE_FEATURES) - # cargo llvm-cov $(COVERAGE_PACKAGES) --no-report --features abi3 $(ALL_ADDITIVE_FEATURES) - bash -c "\ - set -a\ - source <(cargo llvm-cov show-env)\ - make test_py\ - " - cargo llvm-cov $(COVERAGE_PACKAGES) --no-run --summary-only - - clippy: cargo clippy --features="$(ALL_ADDITIVE_FEATURES)" --all-targets --workspace -- -Dwarnings cargo clippy --features="abi3 $(ALL_ADDITIVE_FEATURES)" --all-targets --workspace -- -Dwarnings for example in examples/*/; do cargo clippy --manifest-path $$example/Cargo.toml -- -Dwarnings || exit 1; done - for package in pytests/*/; do cargo clippy --manifest-path $$package/Cargo.toml -- -Dwarnings || exit 1; done lint: fmt clippy @true diff --git a/pytests/pyo3-pytests/Cargo.toml b/pytests/Cargo.toml similarity index 82% rename from pytests/pyo3-pytests/Cargo.toml rename to pytests/Cargo.toml index 8fdcda88bf2..1e387ca229b 100644 --- a/pytests/pyo3-pytests/Cargo.toml +++ b/pytests/Cargo.toml @@ -6,10 +6,10 @@ description = "Python-based tests for PyO3" edition = "2018" [dependencies] -pyo3 = { path = "../../", features = ["extension-module"] } +pyo3 = { path = "../", features = ["extension-module"] } [build-dependencies] -pyo3-build-config = { path = "../../pyo3-build-config" } +pyo3-build-config = { path = "../pyo3-build-config" } [lib] name = "pyo3_pytests" diff --git a/pytests/pyo3-pytests/MANIFEST.in b/pytests/MANIFEST.in similarity index 100% rename from pytests/pyo3-pytests/MANIFEST.in rename to pytests/MANIFEST.in diff --git a/pytests/README.md b/pytests/README.md index 7db3fabedc5..7ced072aa36 100644 --- a/pytests/README.md +++ b/pytests/README.md @@ -1,10 +1,34 @@ -# PyO3 Python tests +# pyo3-pytests -These crates are a collection of test extension modules built with PyO3. They are all tested using `nox` in PyO3's CI. +An extension module built using PyO3, used to test and benchmark PyO3 from Python. -Below is a brief description of each of these: +## Testing -| Example | Description | -| ------- | ----------- | -| `pyo3-benchmarks` | A project containing some benchmarks of PyO3 functionality called from Python. | -| `pyo3-pytests` | A project containing some tests of PyO3 functionality called from Python. | +This package is intended to be built using `maturin`. Once built, you can run the tests using `pytest`: + +```shell +pip install maturin +maturin develop +pytest +``` + +Alternatively, install nox and run the tests inside an isolated environment: + +```shell +nox +``` + +## Running benchmarks + +You can install the module in your Python environment and then run the benchmarks with pytest: + +```shell +pip install . +pytest --benchmark-enable +``` + +Or with nox: + +```shell +nox -s bench +``` diff --git a/pytests/pyo3-pytests/build.rs b/pytests/build.rs similarity index 100% rename from pytests/pyo3-pytests/build.rs rename to pytests/build.rs diff --git a/pytests/pyo3-benchmarks/noxfile.py b/pytests/noxfile.py similarity index 79% rename from pytests/pyo3-benchmarks/noxfile.py rename to pytests/noxfile.py index c15b4f7ae56..22d0691f92a 100644 --- a/pytests/pyo3-benchmarks/noxfile.py +++ b/pytests/noxfile.py @@ -15,4 +15,4 @@ def test(session): def bench(session): session.install("-rrequirements-dev.txt") session.install(".") - session.run("pytest", "--benchmark-enable", *session.posargs) + session.run("pytest", "--benchmark-enable", "--benchmark-only", *session.posargs) diff --git a/pytests/pyo3-benchmarks/Cargo.toml b/pytests/pyo3-benchmarks/Cargo.toml deleted file mode 100644 index 56305b66ba1..00000000000 --- a/pytests/pyo3-benchmarks/Cargo.toml +++ /dev/null @@ -1,16 +0,0 @@ -[package] -authors = ["PyO3 Authors"] -name = "pyo3-benchmarks" -version = "0.1.0" -description = "Python-based benchmarks for various PyO3 functionality" -edition = "2018" - -[dependencies] - -[dependencies.pyo3] -path = "../../" -features = ["extension-module"] - -[lib] -name = "pyo3_benchmarks" -crate-type = ["cdylib"] diff --git a/pytests/pyo3-benchmarks/MANIFEST.in b/pytests/pyo3-benchmarks/MANIFEST.in deleted file mode 100644 index 70181be8bd6..00000000000 --- a/pytests/pyo3-benchmarks/MANIFEST.in +++ /dev/null @@ -1,3 +0,0 @@ -include Cargo.toml -recursive-include src * -recursive-include tests diff --git a/pytests/pyo3-benchmarks/README.md b/pytests/pyo3-benchmarks/README.md deleted file mode 100644 index 2d7c33eae79..00000000000 --- a/pytests/pyo3-benchmarks/README.md +++ /dev/null @@ -1,18 +0,0 @@ -# pyo3-benchmarks - -This extension module contains benchmarks for pieces of PyO3's API accessible from Python. - -## Running the benchmarks - -You can install the module in your Python environment and then run the benchmarks with pytest: - -```shell -pip install . -pytest --benchmark-enable -``` - -Or with nox: - -```shell -nox -s bench -``` diff --git a/pytests/pyo3-benchmarks/requirements-dev.txt b/pytests/pyo3-benchmarks/requirements-dev.txt deleted file mode 100644 index 8005ca5e43b..00000000000 --- a/pytests/pyo3-benchmarks/requirements-dev.txt +++ /dev/null @@ -1,4 +0,0 @@ -pytest>=3.5.0 -setuptools_rust~=1.0.0 -pytest-benchmark~=3.2 -pip>=21.3 diff --git a/pytests/pyo3-pytests/README.md b/pytests/pyo3-pytests/README.md deleted file mode 100644 index ddb9573b2b5..00000000000 --- a/pytests/pyo3-pytests/README.md +++ /dev/null @@ -1,19 +0,0 @@ -# pyo3-pytests - -An extension module built using PyO3, used to test PyO3 from Python. - -## Testing - -This package is intended to be built using `maturin`. Once built, you can run the tests using `pytest`: - -```shell -pip install maturin -maturin develop -pytest -``` - -Alternatively, install nox and run the tests inside an isolated environment: - -```shell -nox -``` diff --git a/pytests/pyo3-pytests/noxfile.py b/pytests/pyo3-pytests/noxfile.py deleted file mode 100644 index 17a6b80f3f5..00000000000 --- a/pytests/pyo3-pytests/noxfile.py +++ /dev/null @@ -1,9 +0,0 @@ -import nox - - -@nox.session -def python(session): - session.install("-rrequirements-dev.txt") - session.install("maturin") - session.run_always("maturin", "develop") - session.run("pytest") diff --git a/pytests/pyo3-pytests/pyproject.toml b/pytests/pyo3-pytests/pyproject.toml deleted file mode 100644 index 256b3705748..00000000000 --- a/pytests/pyo3-pytests/pyproject.toml +++ /dev/null @@ -1,3 +0,0 @@ -[build-system] -requires = ["maturin>=0.12,<0.13"] -build-backend = "maturin" diff --git a/pytests/pyo3-pytests/requirements-dev.txt b/pytests/pyo3-pytests/requirements-dev.txt deleted file mode 100644 index cc06de6966f..00000000000 --- a/pytests/pyo3-pytests/requirements-dev.txt +++ /dev/null @@ -1,4 +0,0 @@ -hypothesis>=3.55 -pytest>=3.5.0 -psutil>=5.6 -pip>=21.3 diff --git a/pytests/pyo3-pytests/src/pyclass_iter.rs b/pytests/pyo3-pytests/src/pyclass_iter.rs deleted file mode 100644 index bb09e260699..00000000000 --- a/pytests/pyo3-pytests/src/pyclass_iter.rs +++ /dev/null @@ -1,34 +0,0 @@ -use pyo3::class::iter::{IterNextOutput, PyIterProtocol}; -use pyo3::prelude::*; - -/// This is for demonstrating how to return a value from __next__ -#[pyclass] -struct PyClassIter { - count: usize, -} - -#[pymethods] -impl PyClassIter { - #[new] - pub fn new() -> Self { - PyClassIter { count: 0 } - } -} - -#[pyproto] -impl PyIterProtocol for PyClassIter { - fn __next__(mut slf: PyRefMut) -> IterNextOutput { - if slf.count < 5 { - slf.count += 1; - IterNextOutput::Yield(slf.count) - } else { - IterNextOutput::Return("Ended") - } - } -} - -#[pymodule] -pub fn pyclass_iter(_py: Python, m: &PyModule) -> PyResult<()> { - m.add_class::()?; - Ok(()) -} diff --git a/pytests/pyo3-pytests/pyo3_pytests/__init__.py b/pytests/pyo3_pytests/__init__.py similarity index 100% rename from pytests/pyo3-pytests/pyo3_pytests/__init__.py rename to pytests/pyo3_pytests/__init__.py diff --git a/pytests/pyo3-benchmarks/pyproject.toml b/pytests/pyproject.toml similarity index 100% rename from pytests/pyo3-benchmarks/pyproject.toml rename to pytests/pyproject.toml diff --git a/pytests/requirements-dev.txt b/pytests/requirements-dev.txt new file mode 100644 index 00000000000..d1fa05414e9 --- /dev/null +++ b/pytests/requirements-dev.txt @@ -0,0 +1,4 @@ +hypothesis>=3.55 +pytest>=6.0 +pytest-benchmark>=3.4 +psutil>=5.6 diff --git a/pytests/pyo3-pytests/src/buf_and_str.rs b/pytests/src/buf_and_str.rs similarity index 100% rename from pytests/pyo3-pytests/src/buf_and_str.rs rename to pytests/src/buf_and_str.rs diff --git a/pytests/pyo3-pytests/src/datetime.rs b/pytests/src/datetime.rs similarity index 100% rename from pytests/pyo3-pytests/src/datetime.rs rename to pytests/src/datetime.rs diff --git a/pytests/pyo3-pytests/src/dict_iter.rs b/pytests/src/dict_iter.rs similarity index 100% rename from pytests/pyo3-pytests/src/dict_iter.rs rename to pytests/src/dict_iter.rs diff --git a/pytests/pyo3-pytests/src/lib.rs b/pytests/src/lib.rs similarity index 83% rename from pytests/pyo3-pytests/src/lib.rs rename to pytests/src/lib.rs index b435e668db5..09549142c2d 100644 --- a/pytests/pyo3-pytests/src/lib.rs +++ b/pytests/src/lib.rs @@ -9,7 +9,8 @@ pub mod misc; pub mod objstore; pub mod othermod; pub mod path; -pub mod pyclass_iter; +pub mod pyclasses; +pub mod pyfunctions; pub mod subclassing; #[pymodule] @@ -23,7 +24,8 @@ fn pyo3_pytests(py: Python, m: &PyModule) -> PyResult<()> { m.add_wrapped(wrap_pymodule!(objstore::objstore))?; m.add_wrapped(wrap_pymodule!(othermod::othermod))?; m.add_wrapped(wrap_pymodule!(path::path))?; - m.add_wrapped(wrap_pymodule!(pyclass_iter::pyclass_iter))?; + m.add_wrapped(wrap_pymodule!(pyclasses::pyclasses))?; + m.add_wrapped(wrap_pymodule!(pyfunctions::pyfunctions))?; m.add_wrapped(wrap_pymodule!(subclassing::subclassing))?; // Inserting to sys.modules allows importing submodules nicely from Python @@ -38,7 +40,8 @@ fn pyo3_pytests(py: Python, m: &PyModule) -> PyResult<()> { sys_modules.set_item("pyo3_pytests.objstore", m.getattr("objstore")?)?; sys_modules.set_item("pyo3_pytests.othermod", m.getattr("othermod")?)?; sys_modules.set_item("pyo3_pytests.path", m.getattr("path")?)?; - sys_modules.set_item("pyo3_pytests.pyclass_iter", m.getattr("pyclass_iter")?)?; + sys_modules.set_item("pyo3_pytests.pyclasses", m.getattr("pyclasses")?)?; + sys_modules.set_item("pyo3_pytests.pyfunctions", m.getattr("pyfunctions")?)?; sys_modules.set_item("pyo3_pytests.subclassing", m.getattr("subclassing")?)?; Ok(()) diff --git a/pytests/pyo3-pytests/src/misc.rs b/pytests/src/misc.rs similarity index 100% rename from pytests/pyo3-pytests/src/misc.rs rename to pytests/src/misc.rs diff --git a/pytests/pyo3-pytests/src/objstore.rs b/pytests/src/objstore.rs similarity index 100% rename from pytests/pyo3-pytests/src/objstore.rs rename to pytests/src/objstore.rs diff --git a/pytests/pyo3-pytests/src/othermod.rs b/pytests/src/othermod.rs similarity index 100% rename from pytests/pyo3-pytests/src/othermod.rs rename to pytests/src/othermod.rs diff --git a/pytests/pyo3-pytests/src/path.rs b/pytests/src/path.rs similarity index 100% rename from pytests/pyo3-pytests/src/path.rs rename to pytests/src/path.rs diff --git a/pytests/src/pyclasses.rs b/pytests/src/pyclasses.rs new file mode 100644 index 00000000000..362ce4a7262 --- /dev/null +++ b/pytests/src/pyclasses.rs @@ -0,0 +1,43 @@ +use pyo3::iter::IterNextOutput; +use pyo3::prelude::*; + +#[pyclass] +struct EmptyClass {} + +#[pymethods] +impl EmptyClass { + #[new] + fn new() -> Self { + EmptyClass {} + } +} + +/// This is for demonstrating how to return a value from __next__ +#[pyclass] +struct PyClassIter { + count: usize, +} + +#[pymethods] +impl PyClassIter { + #[new] + pub fn new() -> Self { + PyClassIter { count: 0 } + } + + fn __next__(&mut self) -> IterNextOutput { + if self.count < 5 { + self.count += 1; + IterNextOutput::Yield(self.count) + } else { + IterNextOutput::Return("Ended") + } + } +} + +#[pymodule] +pub fn pyclasses(_py: Python<'_>, m: &PyModule) -> PyResult<()> { + m.add_class::()?; + m.add_class::()?; + Ok(()) +} diff --git a/pytests/pyo3-benchmarks/src/lib.rs b/pytests/src/pyfunctions.rs similarity index 87% rename from pytests/pyo3-benchmarks/src/lib.rs rename to pytests/src/pyfunctions.rs index 1f858091880..a259aea06d6 100644 --- a/pytests/pyo3-benchmarks/src/lib.rs +++ b/pytests/src/pyfunctions.rs @@ -54,25 +54,13 @@ fn args_kwargs<'a>( (args, kwargs) } -#[pyclass] -struct EmptyClass {} - -#[pymethods] -impl EmptyClass { - #[new] - fn new() -> Self { - EmptyClass {} - } -} - #[pymodule] -fn pyo3_benchmarks(_py: Python<'_>, m: &PyModule) -> PyResult<()> { +pub fn pyfunctions(_py: Python<'_>, m: &PyModule) -> PyResult<()> { m.add_function(wrap_pyfunction!(none, m)?)?; m.add_function(wrap_pyfunction!(simple, m)?)?; m.add_function(wrap_pyfunction!(simple_args, m)?)?; m.add_function(wrap_pyfunction!(simple_kwargs, m)?)?; m.add_function(wrap_pyfunction!(simple_args_kwargs, m)?)?; m.add_function(wrap_pyfunction!(args_kwargs, m)?)?; - m.add_class::()?; Ok(()) } diff --git a/pytests/pyo3-pytests/src/subclassing.rs b/pytests/src/subclassing.rs similarity index 100% rename from pytests/pyo3-pytests/src/subclassing.rs rename to pytests/src/subclassing.rs diff --git a/pytests/pyo3-pytests/tests/test_buf_and_str.py b/pytests/tests/test_buf_and_str.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_buf_and_str.py rename to pytests/tests/test_buf_and_str.py diff --git a/pytests/pyo3-pytests/tests/test_datetime.py b/pytests/tests/test_datetime.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_datetime.py rename to pytests/tests/test_datetime.py diff --git a/pytests/pyo3-pytests/tests/test_dict_iter.py b/pytests/tests/test_dict_iter.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_dict_iter.py rename to pytests/tests/test_dict_iter.py diff --git a/pytests/pyo3-pytests/tests/test_misc.py b/pytests/tests/test_misc.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_misc.py rename to pytests/tests/test_misc.py diff --git a/pytests/pyo3-pytests/tests/test_objstore.py b/pytests/tests/test_objstore.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_objstore.py rename to pytests/tests/test_objstore.py diff --git a/pytests/pyo3-pytests/tests/test_othermod.py b/pytests/tests/test_othermod.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_othermod.py rename to pytests/tests/test_othermod.py diff --git a/pytests/pyo3-pytests/tests/test_path.py b/pytests/tests/test_path.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_path.py rename to pytests/tests/test_path.py diff --git a/pytests/pyo3-pytests/tests/test_pyclass_iter.py b/pytests/tests/test_pyclasses.py similarity index 51% rename from pytests/pyo3-pytests/tests/test_pyclass_iter.py rename to pytests/tests/test_pyclasses.py index e7d7d47c222..c8697b4e510 100644 --- a/pytests/pyo3-pytests/tests/test_pyclass_iter.py +++ b/pytests/tests/test_pyclasses.py @@ -1,9 +1,21 @@ import pytest -from pyo3_pytests import pyclass_iter +from pyo3_pytests import pyclasses + + +def test_empty_class_init(benchmark): + benchmark(pyclasses.EmptyClass) + + +class EmptyClassPy: + pass + + +def test_empty_class_init_py(benchmark): + benchmark(EmptyClassPy) def test_iter(): - i = pyclass_iter.PyClassIter() + i = pyclasses.PyClassIter() assert next(i) == 1 assert next(i) == 2 assert next(i) == 3 diff --git a/pytests/pyo3-benchmarks/tests/test_benchmarks.py b/pytests/tests/test_pyfunctions.py similarity index 63% rename from pytests/pyo3-benchmarks/tests/test_benchmarks.py rename to pytests/tests/test_pyfunctions.py index c00b85833d0..1dda25285b6 100644 --- a/pytests/pyo3-benchmarks/tests/test_benchmarks.py +++ b/pytests/tests/test_pyfunctions.py @@ -1,4 +1,4 @@ -import pyo3_benchmarks +from pyo3_pytests import pyfunctions def none_py(): @@ -10,10 +10,10 @@ def test_none_py(benchmark): def test_none_rs(benchmark): - rust = pyo3_benchmarks.none() + rust = pyfunctions.none() py = none_py() assert rust == py - benchmark(pyo3_benchmarks.none) + benchmark(pyfunctions.none) def simple_py(a, b="bar", *, c=None): @@ -25,10 +25,10 @@ def test_simple_py(benchmark): def test_simple_rs(benchmark): - rust = pyo3_benchmarks.simple(1, "foo", c={1: 2}) + rust = pyfunctions.simple(1, "foo", c={1: 2}) py = simple_py(1, "foo", c={1: 2}) assert rust == py - benchmark(pyo3_benchmarks.simple, 1, "foo", c={1: 2}) + benchmark(pyfunctions.simple, 1, "foo", c={1: 2}) def simple_args_py(a, b="bar", *args, c=None): @@ -40,10 +40,10 @@ def test_simple_args_py(benchmark): def test_simple_args_rs(benchmark): - rust = pyo3_benchmarks.simple_args(1, "foo", 4, 5, 6, c={1: 2}) + rust = pyfunctions.simple_args(1, "foo", 4, 5, 6, c={1: 2}) py = simple_args_py(1, "foo", 4, 5, 6, c={1: 2}) assert rust == py - benchmark(pyo3_benchmarks.simple_args, 1, "foo", 4, 5, 6, c={1: 2}) + benchmark(pyfunctions.simple_args, 1, "foo", 4, 5, 6, c={1: 2}) def simple_kwargs_py(a, b="bar", c=None, **kwargs): @@ -55,10 +55,10 @@ def test_simple_kwargs_py(benchmark): def test_simple_kwargs_rs(benchmark): - rust = pyo3_benchmarks.simple_kwargs(1, "foo", c={1: 2}, bar=4, foo=10) + rust = pyfunctions.simple_kwargs(1, "foo", c={1: 2}, bar=4, foo=10) py = simple_kwargs_py(1, "foo", c={1: 2}, bar=4, foo=10) assert rust == py - benchmark(pyo3_benchmarks.simple_kwargs, 1, "foo", c={1: 2}, bar=4, foo=10) + benchmark(pyfunctions.simple_kwargs, 1, "foo", c={1: 2}, bar=4, foo=10) def simple_args_kwargs_py(a, b="bar", *args, c=None, **kwargs): @@ -70,10 +70,10 @@ def test_simple_args_kwargs_py(benchmark): def test_simple_args_kwargs_rs(benchmark): - rust = pyo3_benchmarks.simple_args_kwargs(1, "foo", "baz", bar=4, foo=10) + rust = pyfunctions.simple_args_kwargs(1, "foo", "baz", bar=4, foo=10) py = simple_args_kwargs_py(1, "foo", "baz", bar=4, foo=10) assert rust == py - benchmark(pyo3_benchmarks.simple_args_kwargs, 1, "foo", "baz", bar=4, foo=10) + benchmark(pyfunctions.simple_args_kwargs, 1, "foo", "baz", bar=4, foo=10) def args_kwargs_py(*args, **kwargs): @@ -85,19 +85,7 @@ def test_args_kwargs_py(benchmark): def test_args_kwargs_rs(benchmark): - rust = pyo3_benchmarks.args_kwargs(1, "foo", {1: 2}, bar=4, foo=10) + rust = pyfunctions.args_kwargs(1, "foo", {1: 2}, bar=4, foo=10) py = args_kwargs_py(1, "foo", {1: 2}, bar=4, foo=10) assert rust == py - benchmark(pyo3_benchmarks.args_kwargs, 1, "foo", {1: 2}, a=4, foo=10) - - -def test_empty_class_init(benchmark): - benchmark(pyo3_benchmarks.EmptyClass) - - -class EmptyClassPy: - pass - - -def test_empty_class_init_py(benchmark): - benchmark(EmptyClassPy) + benchmark(pyfunctions.args_kwargs, 1, "foo", {1: 2}, a=4, foo=10) diff --git a/pytests/pyo3-pytests/tests/test_subclassing.py b/pytests/tests/test_subclassing.py similarity index 100% rename from pytests/pyo3-pytests/tests/test_subclassing.py rename to pytests/tests/test_subclassing.py diff --git a/src/class/iter.rs b/src/class/iter.rs index 97b47fe3775..2ac29a9d96a 100644 --- a/src/class/iter.rs +++ b/src/class/iter.rs @@ -41,7 +41,7 @@ use crate::{ffi, IntoPy, IntoPyPointer, PyClass, PyObject, Python}; /// # Python::with_gil(|py| { /// # let inst = Py::new(py, Iter { count: 0 }).unwrap(); /// # pyo3::py_run!(py, inst, "assert next(inst) == 1"); -/// # }); // test of StopIteration is done in examples/pyo3-pytests/pyclass_iter.rs +/// # }); // test of StopIteration is done in pytests/src/pyclasses.rs /// ``` #[allow(unused_variables)] pub trait PyIterProtocol<'p>: PyClass { diff --git a/xtask/src/main.rs b/xtask/src/main.rs index f6d9b4b6c0e..cdbfbf146b6 100644 --- a/xtask/src/main.rs +++ b/xtask/src/main.rs @@ -1,5 +1,5 @@ use anyhow::{ensure, Context, Result}; -use std::{collections::HashMap, process::Command}; +use std::{collections::HashMap, path::Path, process::Command}; use structopt::StructOpt; #[derive(StructOpt)] @@ -116,16 +116,12 @@ fn llvm_cov_command(args: &[&str]) -> Command { fn run_python_tests<'a>( env: impl IntoIterator + Copy, ) -> Result<()> { - for entry in std::fs::read_dir("pytests")? { - let path = entry?.path(); - if path.is_dir() && path.join("noxfile.py").exists() { - run(Command::new("nox") - .arg("--non-interactive") - .arg("-f") - .arg(path.join("noxfile.py")) - .envs(env))?; - } - } + run(Command::new("nox") + .arg("--non-interactive") + .arg("-f") + .arg(Path::new("pytests").join("noxfile.py")) + .envs(env))?; + for entry in std::fs::read_dir("examples")? { let path = entry?.path(); if path.is_dir() && path.join("noxfile.py").exists() {