forked from pool/python-pytest-benchmark
* Fixed broken hooks handling on pytest 8.1 or later (the
TypeError: import_path() missing 1 required keyword-only
argument: 'consider_namespace_packages' issue). Unfortunately
this sets the minimum supported pytest version to 8.1.
* Fixed bad fixture check that broke down then nbmake was
enabled.
* Dropped support for now EOL Python 3.8. Also moved tests
suite to only test the latest pytest versions (8.3.x).
* Fix generate parametrize tests benchmark csv report errors
(issue #268). Contributed by Johnny Huang in #269.
* Added the --benchmark-time-unit cli option for overriding the
measurement unit used for display. Contributed by Tony Kuo in
#257.
* Fixes spelling in some help texts. Contributed by Eugeniy in
#267.
* Added new cprofile options: --benchmark-cprofile-loops=LOOPS
- previously profiling only ran the function once, this allow
customization. --benchmark-cprofile-top=COUNT - allows
showing more rows. --benchmark-cprofile-dump=[FILENAME-
PREFIX] - allows saving to a file (that you can load in
snakeviz, RunSnakeRun or other tools).
* --benchmark-cprofile-loops=LOOPS - previously profiling only
ran the function once, this allow customization.
* --benchmark-cprofile-top=COUNT - allows showing more rows.
* --benchmark-cprofile-dump=[FILENAME-PREFIX] - allows saving
to a file (that you can load in snakeviz, RunSnakeRun or
other tools).
* Removed hidden dependency on py.path (replaced with pathlib).
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python:pytest/python-pytest-benchmark?expand=0&rev=32
46 lines
1.4 KiB
Diff
46 lines
1.4 KiB
Diff
diff --git a/src/pytest_benchmark/compat.py b/src/pytest_benchmark/compat.py
|
|
index 63d01bd..9afecf2 100644
|
|
--- a/src/pytest_benchmark/compat.py
|
|
+++ b/src/pytest_benchmark/compat.py
|
|
@@ -1,3 +1,4 @@
|
|
import sys
|
|
|
|
PY38 = sys.version_info[0] == 3 and sys.version_info[1] >= 8
|
|
+PY311 = sys.version_info[0] == 3 and sys.version_info[1] >= 11
|
|
diff --git a/src/pytest_benchmark/utils.py b/src/pytest_benchmark/utils.py
|
|
index c80352a..e28c04e 100644
|
|
--- a/src/pytest_benchmark/utils.py
|
|
+++ b/src/pytest_benchmark/utils.py
|
|
@@ -26,7 +26,7 @@
|
|
|
|
import genericpath
|
|
|
|
-from .compat import PY38
|
|
+from .compat import PY38, PY311
|
|
|
|
# This is here (in the utils module) because it might be used by
|
|
# various other modules.
|
|
@@ -521,6 +521,10 @@ def clonefunc(f):
|
|
co.co_firstlineno, co.co_lnotab, co.co_freevars, co.co_cellvars]
|
|
if PY38:
|
|
args.insert(1, co.co_posonlyargcount)
|
|
+
|
|
+ if PY311:
|
|
+ args.insert(12, co.co_qualname)
|
|
+ args.insert(15, co.co_exceptiontable)
|
|
co2 = types.CodeType(*args)
|
|
#
|
|
# then, we clone the function itself, using the new co2
|
|
diff --git a/tests/test_benchmark.py b/tests/test_benchmark.py
|
|
index 280ce24..964787f 100644
|
|
--- a/tests/test_benchmark.py
|
|
+++ b/tests/test_benchmark.py
|
|
@@ -952,7 +952,6 @@ def result():
|
|
|
|
" def test_bad(benchmark):",
|
|
"? @benchmark",
|
|
- "? def result():",
|
|
|
|
"test_abort_broken.py:*",
|
|
"_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _*",
|