mirror of
https://github.com/pybind/pybind11.git
synced 2025-01-18 17:05:53 +00:00
f1a2e03d19
* Change Python version guard: PYTHON < 3.7 IS UNSUPPORTED.
* Replace or remove Python 3.6 jobs.
* Move appveyor to Python 3.8
* Change `[tool.pylint]` `master.py-version` from `3.6` to `3.8`
* Change `[tool.pylint]` `master.py-version` to `3.7`
* Remove `centos:7` job; Change almalinux:8 job to use Python 3.8
* Try 🐍 3.8 • ubuntu-20.04 • x64 without `-DCMAKE_CXX_FLAGS="-D_=1"`
* Update setup.cfg as suggested by @henryiii
* Try running `cmake --build . --target cpptest` on all platforms (`standard` job).
* Disable deadsnakes jobs entirely.
* Apply PR #5179: Add Python 3.10, 3.11, 3.12 to win32 job matrix.
* Add back `-DCMAKE_CXX_FLAGS="-D_=1"` but do not install boost in that case.
* PY_VERSION_HEX < 3.7 cleanup pass: include/pybind11
* WITH_THREAD cleanup pass: include/pybind11
* Undo incorrect change.
* Revert "Disable deadsnakes jobs entirely."
This reverts commit bbcd0087b2
.
* WITH_THREAD cleanup pass: tests/
* Change Python version guard in pybind11/__init__.py: pybind11 does not support Python < 3.7.
* Misc cleanup pass
* chore: use future imports
Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
* Update tests/test_numpy_array.py
* Update test_numpy_array.py
---------
Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
Co-authored-by: Henry Schreiner <henryschreineriii@gmail.com>
37 lines
1.1 KiB
Python
37 lines
1.1 KiB
Python
from __future__ import annotations
|
|
|
|
import pytest
|
|
|
|
from pybind11_tests import unnamed_namespace_a as m
|
|
from pybind11_tests import unnamed_namespace_b as mb
|
|
|
|
XFAIL_CONDITION = (
|
|
"(m.PYBIND11_INTERNALS_VERSION <= 4 and (m.defined___clang__ or not m.defined___GLIBCXX__))"
|
|
" or "
|
|
"(m.PYBIND11_INTERNALS_VERSION >= 5 and not m.defined_WIN32_or__WIN32"
|
|
" and "
|
|
"(m.defined___clang__ or m.defined__LIBCPP_VERSION))"
|
|
)
|
|
XFAIL_REASON = "Known issues: https://github.com/pybind/pybind11/pull/4319"
|
|
|
|
|
|
@pytest.mark.xfail(XFAIL_CONDITION, reason=XFAIL_REASON, strict=False)
|
|
@pytest.mark.parametrize(
|
|
"any_struct", [m.unnamed_namespace_a_any_struct, mb.unnamed_namespace_b_any_struct]
|
|
)
|
|
def test_have_class_any_struct(any_struct):
|
|
assert any_struct is not None
|
|
|
|
|
|
def test_have_at_least_one_class_any_struct():
|
|
assert (
|
|
m.unnamed_namespace_a_any_struct is not None
|
|
or mb.unnamed_namespace_b_any_struct is not None
|
|
)
|
|
|
|
|
|
@pytest.mark.xfail(XFAIL_CONDITION, reason=XFAIL_REASON, strict=True)
|
|
def test_have_both_class_any_struct():
|
|
assert m.unnamed_namespace_a_any_struct is not None
|
|
assert mb.unnamed_namespace_b_any_struct is not None
|