forked from RunestoneInteractive/BookServer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpre_commit_check.py
executable file
·56 lines (50 loc) · 1.84 KB
/
pre_commit_check.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
#!/usr/bin/env python3
# *******************************************
# |docname| - Formatting, Lint, and Unittests
# *******************************************
# This script runs a series of checks that should all pass before submitting a pull request.
# In a perfect world, these would also pass before every commit. The checks are detailed in `pull requests`.
#
#
# Imports
# =======
# These are listed in the order prescribed by `PEP 8`_.
#
# Standard library
# ----------------
# None.
# Third-party imports
# -------------------
# None.
#
# Local application imports
# -------------------------
from test.ci_utils import xqt
# Checks
# ======
def checks():
xqt(
# Run this first, since it's quick and should always succeed.
"black --check .",
# Do this next -- it should be easy to fix most of these.
"flake8 .",
"mypy --install-types --non-interactive",
# Next, check the docs. Again, these only require fixes to comments, and should still be relatively easy to correct.
#
# Force a `full build <https://www.sphinx-doc.org/en/master/man/sphinx-build.html>`_:
#
# -E Don’t use a saved environment (the structure caching all cross-references), but rebuild it completely.
# -a If given, always write all output files.
"sphinx-build -E -a . _build",
# Finally, unit tests -- the hardest to get right.
"pytest -v",
)
# .. attention:: Coverage Reports
#
# The command ``coverage html`` will generate a test coverage report showing
# the lines of code that were executed (or not) by the tests. This is a great
# report to help figure out what new tests should be written to keep our coverage
# near 100% You can view the report by opening ``test/htmlcov/index.html`` in
# your browser.
if __name__ == "__main__":
checks()