-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathnoxfile.py
100 lines (79 loc) · 2.77 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
"""Notes:
* 'test' command: nox will create new virtualenvs per python version
* 'lint' command: tools and environments are managed by pre-commit
* All other commands: will use the project virtualenv managed by uv
"""
from os import getenv
from os.path import join
from shutil import rmtree
import nox
nox.options.reuse_existing_virtualenvs = True
nox.options.sessions = ['lint', 'cov']
LIVE_DOCS_PORT = 8181
LIVE_DOCS_IGNORE = ['*.csv', '*.ipynb', '*.pyc', '*.tmp', '**/modules/*']
LIVE_DOCS_WATCH = ['pyinaturalist', 'examples']
DEFAULT_COVERAGE_FORMATS = ['html', 'term']
DOC_BUILD_DIR = join('docs', '_build', 'html')
CLEAN_DIRS = [
'dist',
'build',
join('docs', '_build'),
join('docs', 'models'),
join('docs', 'modules'),
]
def install_deps(session):
"""Install project and test dependencies into a nox session using uv"""
session.env['UV_PROJECT_ENVIRONMENT'] = session.virtualenv.location
session.run_install(
'uv',
'sync',
'--frozen',
'--all-extras',
)
@nox.session(python=['3.8', '3.9', '3.10', '3.11', '3.12', '3.13'], venv_backend='uv')
def test(session):
"""Run tests for a specific python version"""
test_paths = session.posargs or ['test']
install_deps(session)
session.run('pytest', '-n', 'auto', *test_paths)
@nox.session(python=False)
def clean(session):
"""Clean up temporary build + documentation files"""
for dir in CLEAN_DIRS:
print(f'Removing {dir}')
rmtree(dir, ignore_errors=True)
@nox.session(python=False, name='cov')
def coverage(session):
"""Run tests and generate coverage report"""
cmd = ['pytest', '--numprocesses=auto', '--cov']
# Add coverage formats
cov_formats = session.posargs or DEFAULT_COVERAGE_FORMATS
cmd += [f'--cov-report={f}' for f in cov_formats]
# Add verbose flag, if set by environment
if getenv('PYTEST_VERBOSE'):
cmd += ['--verbose']
session.run(*cmd)
@nox.session(python=False)
def docs(session):
"""Build Sphinx documentation"""
session.run('sphinx-build', 'docs', DOC_BUILD_DIR, '-j', 'auto')
@nox.session(python=False)
def livedocs(session):
"""Auto-build docs with live reload in browser.
Add `-- open` to also open the browser after starting.
"""
cmd = ['sphinx-autobuild', 'docs', DOC_BUILD_DIR]
cmd += ['-a']
cmd += ['--port', str(LIVE_DOCS_PORT), '-j', 'auto']
for pattern in LIVE_DOCS_WATCH:
cmd += ['--watch', pattern]
for pattern in LIVE_DOCS_IGNORE:
cmd += ['--ignore', pattern]
if session.posargs == ['open']:
cmd.append('--open-browser')
clean(session)
session.run(*cmd)
@nox.session(python=False)
def lint(session):
"""Run linters and code formatters via pre-commit"""
session.run('pre-commit', 'run', '--all-files')