From d2a79385c6dc6bd3f5b7f535442d6bb06c13218b Mon Sep 17 00:00:00 2001 From: Rohit Goswami Date: Sun, 28 Jan 2024 19:53:12 +0000 Subject: [PATCH 1/2] ENH: Support externally defined plugins --- asv_runner/benchmarks/__init__.py | 30 ++++++++++++++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) diff --git a/asv_runner/benchmarks/__init__.py b/asv_runner/benchmarks/__init__.py index ed43ede..99d09a4 100644 --- a/asv_runner/benchmarks/__init__.py +++ b/asv_runner/benchmarks/__init__.py @@ -35,16 +35,26 @@ import importlib import pkgutil +from importlib.metadata import distributions +from pathlib import Path from ._exceptions import NotRequired pkgname = __name__ pkgpath = __path__ -module_names = [name for _, name, _ in pkgutil.iter_modules(pkgpath) if "_" not in name] +submodule_names = [ + name for _, name, _ in pkgutil.iter_modules(pkgpath) if "_" not in name +] +asv_modules = [ + dist.metadata["Name"] + for dist in distributions() + if dist.metadata["Name"].startswith("asv_bench") +] benchmark_types = [] -for module_name in module_names: +# Builtin modules +for module_name in submodule_names: try: module = importlib.import_module(f"{pkgname}.{module_name}") if "export_as_benchmark" in dir(module): @@ -52,3 +62,19 @@ except NotRequired: # Ignored. pass +# External asv_bench modules +for module_name in asv_modules: + try: + module = importlib.import_module(module_name) + benchmarks_path = Path(module.__file__).parent / "benchmarks" + benchmark_submodules = [ + name for _, name, _ in pkgutil.iter_modules([str(benchmarks_path)]) + ] + for submodule_name in benchmark_submodules: + submodule = importlib.import_module( + f"{module_name}.benchmarks.{submodule_name}" + ) + if "export_as_benchmark" in dir(submodule): + benchmark_types.extend(iter(getattr(submodule, "export_as_benchmark"))) + except (ImportError, NotRequired): + pass From 5e63cb39caf47fff1811b58821bc1d277f169847 Mon Sep 17 00:00:00 2001 From: Rohit Goswami Date: Thu, 1 Feb 2024 19:54:02 +0000 Subject: [PATCH 2/2] DOC: Detail external plugins --- docs/source/bplugin-list.md | 10 ++++++++++ docs/source/development/benchmark_plugins.md | 9 +++++++++ docs/source/index.md | 1 + 3 files changed, 20 insertions(+) create mode 100644 docs/source/bplugin-list.md create mode 100644 docs/source/development/benchmark_plugins.md diff --git a/docs/source/bplugin-list.md b/docs/source/bplugin-list.md new file mode 100644 index 0000000..0bdc1f0 --- /dev/null +++ b/docs/source/bplugin-list.md @@ -0,0 +1,10 @@ +# External Plugin List + +Here are the existing external plugins which are supported by `asv` and +`asv_runner` (pull requests welcome). + +## Benchmark Plugins + +- [`asv_bench_memray`](https://haozeke.github.io/asv_bench_memray/) enables + `RayMyClass` or `ray_funcname` for peak memory as profiled by `memray`, which + is able to handle native calls and traces every function call diff --git a/docs/source/development/benchmark_plugins.md b/docs/source/development/benchmark_plugins.md new file mode 100644 index 0000000..6534daa --- /dev/null +++ b/docs/source/development/benchmark_plugins.md @@ -0,0 +1,9 @@ +# Developing benchmarks + +All benchmark plugins must follow a strict hierarchy: + +- The package name must begin with `asv_bench`. +- Benchmark classes are defined in a `benchmarks` folder under the package module. +- Each exported new benchmark type has the `export_as_benchmark = [NAMEBenchmark]` attribute. + +For more conventions, see the internally defined benchmark types within `asv_runner`. diff --git a/docs/source/index.md b/docs/source/index.md index e2ca4b2..abcf22c 100644 --- a/docs/source/index.md +++ b/docs/source/index.md @@ -23,6 +23,7 @@ measure and analyze the performance of your Python packages. :caption: Contents apidocs/index +bplugin-list ``` ## Indices and tables