-
Notifications
You must be signed in to change notification settings - Fork 1
/
noxfile.py
106 lines (76 loc) · 2.66 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
103
104
105
106
import os
import nox
from nox import parametrize
from nox_poetry import Session, session
nox.options.error_on_external_run = True
nox.options.reuse_existing_virtualenvs = False
nox.options.sessions = [
"lint",
"type_check",
"typos",
"test",
"docs",
]
@session(python=["3.11", "3.12"])
def test(s: Session) -> None:
s.install(".[data,llm,local_llm,statistics,viz]", "pytest", "pytest-cov", "pytest-randomly")
# Skip tests in directories specified by the SKIP_TESTS_NAII environment variable.
skip_tests = os.getenv("SKIP_TESTS_NAAI", "")
skip_args = [f"--ignore={dir}" for dir in skip_tests.split()] if skip_tests else []
s.run(
"python",
"-m",
"pytest",
"--cov=not_again_ai",
"--cov-report=html",
"--cov-report=term",
"tests",
*skip_args,
"-W ignore::DeprecationWarning",
*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("ruff", "check", ".", "--select", "I", "--fix")
s.run("ruff", "format", ".")
@session(venv_backend="none")
def fmt_check(s: Session) -> None:
s.run("ruff", "check", ".", "--select", "I")
@session(venv_backend="none")
@parametrize(
"command",
[
["ruff", "check", "."],
["ruff", "format", "--check", "."],
],
)
def lint(s: Session, command: list[str]) -> None:
s.run(*command)
@session(venv_backend="none")
def lint_fix(s: Session) -> None:
s.run("ruff", "check", ".", "--fix")
@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:
s.run("mkdocs", "build", env={**doc_env, **{"HTMLPROOFER_VALIDATE_EXTERNAL_URLS": str(True)}})
@session(venv_backend="none")
def docs_offline(s: Session) -> None:
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)
@session(venv_backend="none")
def typos(s: Session) -> None:
s.run("typos", "-c", ".github/_typos.toml")