-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnoxfile.py
102 lines (75 loc) · 2.9 KB
/
noxfile.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
from pathlib import Path
from tempfile import NamedTemporaryFile
import nox
from nox_poetry import Session, session
nox.options.error_on_external_run = True
nox.options.reuse_existing_virtualenvs = True
nox.options.sessions = ["fmt_check", "lint", "type_check", "test", "docs"]
@session(python=["3.11"])
def test(s: Session) -> None:
s.install(".", "pytest", "pytest-cov")
s.run(
"python",
"-m",
"pytest",
"--cov=fact",
"--cov-report=html",
"--cov-report=term",
"tests",
*s.posargs,
)
# For some sessions, set venv_backend="none" to simply execute scripts within the existing Poetry
# environment. This requires that nox is run within `poetry shell` or using `poetry run nox ...`.
@session(venv_backend="none")
def fmt(s: Session) -> None:
s.run("isort", ".")
s.run("black", ".")
@session(venv_backend="none")
def fmt_check(s: Session) -> None:
s.run("isort", "--check", ".")
s.run("black", "--check", ".")
@session(venv_backend="none")
def lint(s: Session) -> None:
s.run("flake8")
@session(venv_backend="none")
def type_check(s: Session) -> None:
s.run("mypy", "src", "tests", "noxfile.py")
# Environment variable needed for mkdocstrings-python to locate source files.
doc_env = {"PYTHONPATH": "src"}
@session(venv_backend="none")
def docs(s: Session) -> None:
s.run("mkdocs", "build", env=doc_env)
@session(venv_backend="none")
def docs_check_urls(s: Session) -> None:
# TODO: Replace dict merge with d1 | d2 when dropping support for Python 3.8.
s.run("mkdocs", "build", env={**doc_env, **{"HTMLPROOFER_VALIDATE_EXTERNAL_URLS": str(True)}})
@session(venv_backend="none")
def docs_offline(s: Session) -> None:
# TODO: Replace dict merge with d1 | d2 when dropping support for Python 3.8.
s.run("mkdocs", "build", env={**doc_env, **{"MKDOCS_MATERIAL_OFFLINE": str(True)}})
@session(venv_backend="none")
def docs_serve(s: Session) -> None:
s.run("mkdocs", "serve", env=doc_env)
@session(venv_backend="none")
def docs_github_pages(s: Session) -> None:
s.run("mkdocs", "gh-deploy", "--force", env=doc_env)
# Note: This reuse_venv does not yet have affect due to:
# https://github.com/wntrblm/nox/issues/488
@session(reuse_venv=False)
def licenses(s: Session) -> None:
# Generate a unique temporary file name. Poetry cannot write to the temp file directly on
# Windows, so only use the name and allow Poetry to re-create it.
with NamedTemporaryFile() as t:
requirements_file = Path(t.name)
# Install dependencies without installing the package itself:
# https://github.com/cjolowicz/nox-poetry/issues/680
s.run_always(
"poetry",
"export",
"--without-hashes",
f"--output={requirements_file}",
external=True,
)
s.install("pip-licenses", "-r", str(requirements_file))
s.run("pip-licenses", *s.posargs)
requirements_file.unlink()