2022-06-20 22:59:56 +00:00
|
|
|
import nox
|
|
|
|
|
|
|
|
nox.needs_version = ">=2022.1.7"
|
|
|
|
nox.options.sessions = ["lint", "tests", "tests_packaging"]
|
|
|
|
|
2023-04-18 16:11:43 +00:00
|
|
|
PYTHON_VERSIONS = ["2.7", "3.5", "3.6", "3.7", "3.8", "3.9", "3.10", "3.11"]
|
2022-06-20 22:59:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
@nox.session(reuse_venv=True)
|
|
|
|
def lint(session: nox.Session) -> None:
|
|
|
|
"""
|
|
|
|
Lint the codebase (except for clang-format/tidy).
|
|
|
|
"""
|
|
|
|
session.install("pre-commit")
|
2023-04-18 16:11:43 +00:00
|
|
|
session.run("pre-commit", "run", "-a")
|
2022-06-20 22:59:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
@nox.session(python=PYTHON_VERSIONS)
|
|
|
|
def tests(session: nox.Session) -> None:
|
|
|
|
"""
|
|
|
|
Run the tests (requires a compiler).
|
|
|
|
"""
|
|
|
|
tmpdir = session.create_tmp()
|
|
|
|
session.install("cmake")
|
|
|
|
session.install("-r", "tests/requirements.txt")
|
|
|
|
session.run(
|
|
|
|
"cmake",
|
|
|
|
"-S.",
|
|
|
|
f"-B{tmpdir}",
|
|
|
|
"-DPYBIND11_WERROR=ON",
|
|
|
|
"-DDOWNLOAD_CATCH=ON",
|
|
|
|
"-DDOWNLOAD_EIGEN=ON",
|
|
|
|
*session.posargs,
|
|
|
|
)
|
|
|
|
session.run("cmake", "--build", tmpdir)
|
|
|
|
session.run("cmake", "--build", tmpdir, "--config=Release", "--target", "check")
|
|
|
|
|
|
|
|
|
|
|
|
@nox.session
|
|
|
|
def tests_packaging(session: nox.Session) -> None:
|
|
|
|
"""
|
|
|
|
Run the packaging tests.
|
|
|
|
"""
|
|
|
|
|
|
|
|
session.install("-r", "tests/requirements.txt", "--prefer-binary")
|
2023-04-18 16:11:43 +00:00
|
|
|
session.run("pytest", "tests/extra_python_package")
|
2022-06-20 22:59:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
@nox.session(reuse_venv=True)
|
|
|
|
def docs(session: nox.Session) -> None:
|
|
|
|
"""
|
|
|
|
Build the docs. Pass "serve" to serve.
|
|
|
|
"""
|
|
|
|
|
|
|
|
session.install("-r", "docs/requirements.txt")
|
|
|
|
session.chdir("docs")
|
|
|
|
|
|
|
|
if "pdf" in session.posargs:
|
2023-04-18 16:11:43 +00:00
|
|
|
session.run("sphinx-build", "-b", "latexpdf", ".", "_build")
|
2022-06-20 22:59:56 +00:00
|
|
|
return
|
|
|
|
|
2023-04-18 16:11:43 +00:00
|
|
|
session.run("sphinx-build", "-b", "html", ".", "_build")
|
2022-06-20 22:59:56 +00:00
|
|
|
|
|
|
|
if "serve" in session.posargs:
|
|
|
|
session.log("Launching docs at http://localhost:8000/ - use Ctrl-C to quit")
|
|
|
|
session.run("python", "-m", "http.server", "8000", "-d", "_build/html")
|
|
|
|
elif session.posargs:
|
|
|
|
session.error("Unsupported argument to docs")
|
|
|
|
|
|
|
|
|
|
|
|
@nox.session(reuse_venv=True)
|
|
|
|
def make_changelog(session: nox.Session) -> None:
|
|
|
|
"""
|
|
|
|
Inspect the closed issues and make entries for a changelog.
|
|
|
|
"""
|
|
|
|
session.install("ghapi", "rich")
|
|
|
|
session.run("python", "tools/make_changelog.py")
|
|
|
|
|
|
|
|
|
|
|
|
@nox.session(reuse_venv=True)
|
|
|
|
def build(session: nox.Session) -> None:
|
|
|
|
"""
|
|
|
|
Build SDists and wheels.
|
|
|
|
"""
|
|
|
|
|
|
|
|
session.install("build")
|
|
|
|
session.log("Building normal files")
|
|
|
|
session.run("python", "-m", "build", *session.posargs)
|
|
|
|
session.log("Building pybind11-global files (PYBIND11_GLOBAL_SDIST=1)")
|
|
|
|
session.run(
|
|
|
|
"python", "-m", "build", *session.posargs, env={"PYBIND11_GLOBAL_SDIST": "1"}
|
|
|
|
)
|