forked from sunpy/sunraster
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tox.ini
80 lines (77 loc) · 3 KB
/
tox.ini
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
[tox]
envlist =
py{38,39,310}{,-oldestdeps,-devdeps,-online}
build_docs
codestyle
isolated_build = true
requires =
setuptools >=56, !=61.0.0
pip >= 19.3.1
tox-pypi-filter >= 0.12
[testenv]
# The following option combined with the use of the tox-pypi-filter above allows
# project-wide pinning of dependencies, e.g. if new versions of pytest do not
# work correctly with pytest-astropy plugins. Most of the time the pinnings file
# should be empty.
pypi_filter = https://raw.githubusercontent.com/sunpy/sunpy/main/.test_package_pins.txt
# Pass through the following environemnt variables which may be needed for the CI
passenv = HOME WINDIR LC_ALL LC_CTYPE CC CI TRAVIS
# Run the tests in a temporary directory to make sure that we don't import
# the package from the source tree
changedir = .tmp/{envname}
# tox environments are constructued with so-called 'factors' (or terms)
# separated by hyphens, e.g. test-devdeps-cov. Lines below starting with factor:
# will only take effect if that factor is included in the environment name. To
# see a list of example environments that can be run, along with a description,
# run:
#
# tox -l -v
#
description =
run tests
devdeps: with the latest developer version of key dependencies
oldestdeps: with the oldest supported version of key dependencies
setenv =
MPLBACKEND = agg
COLUMNS = 180
PYTEST_COMMAND = pytest -vvv --pyargs sunraster --cov=sunraster --cov-report=xml --cov-config={toxinidir}/setup.cfg {toxinidir}/docs
build_docs,online: HOME = {envtmpdir}
deps =
# All our tests run in parallel which this plugin allows us to.
pytest-xdist
# The devdeps factor is intended to be used to install the latest developer version.
# of key dependencies.
devdeps: cython
devdeps: git+https://github.com/astropy/astropy
devdeps: git+https://github.com/sunpy/ndcube
devdeps: git+https://github.com/sunpy/sunpy
# Oldest deps we pin against.
oldestdeps: ndcube<3.0.0
# These are specific online extras we use to run the online tests.
online: pytest-rerunfailures
online: pytest-timeout
# Needed to work out test code coverage
pytest-cov
# The following indicates which extras_require from setup.cfg will be installed
# dev is special in that it installs everything but we use tests here.
extras =
all
tests
commands =
!online: {env:PYTEST_COMMAND} {posargs}
online: {env:PYTEST_COMMAND} --reruns 2 --timeout=180 --remote-data=any {posargs}
[testenv:build_docs]
changedir = docs
description = Invoke sphinx-build to build the HTML docs
extras = docs
commands =
sphinx-build --color -W --keep-going -b html -d _build/.doctrees . _build/html {posargs}
python -c 'import pathlib; print("Documentation available under file://\{0\}".format(pathlib.Path(r"{toxinidir}") / "docs" / "_build" / "index.html"))'
[testenv:codestyle]
skip_install = true
description = Run all style and file checks with pre-commit
deps =
pre-commit
commands =
pre-commit install-hooks
pre-commit run --all-files