-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtox.ini
207 lines (182 loc) · 4.64 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
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
[tox]
envlist = py{36,37,38,39}-{linux,macos}
[gh-actions]
python =
3.6: py36
3.7: py37
3.8: py38
3.9: py39
pypy3: pypy3
[testenv]
description = Run tests with coverage with pytest under current Python env
usedevelop = true
setenv = COVERAGE_FILE=.coverage.{envname}
passenv = CI
deps =
-rtests/requirements.txt
coverage
commands =
bash -c 'grep -v "^#" requirements.txt | xargs -n 1 -L 1 pip install'
pip install -e .
coverage run --parallel-mode -m pytest -vv --timeout=900 {posargs}
coverage combine
coverage report -m
coverage xml
[testenv:final-coverage]
description = Combine coverage data across environments (run after tests)
skip_install = True
setenv = COVERAGE_FILE=.coverage
passenv = {[testenv]passenv}
deps = coverage
commands =
coverage erase
coverage combine
coverage report -m
coverage xml
[testenv:codecov]
description = Upload coverage data to codecov (only run on CI)
setenv =
{[testenv:final-coverage]setenv}
passenv = {[testenv]passenv}
deps = codecov
commands = codecov --required
## Configure linters
[testenv:lint]
description = Lint code and docs against some standard standards
basepython = python3
skip_install = false
deps =
{[testenv:black]deps}
{[testenv:pylint]deps}
{[testenv:doc8]deps}
{[testenv:packaging]deps}
commands =
{[testenv:black]commands}
{[testenv:pylint]commands}
{[testenv:doc8]commands}
{[testenv:packaging]commands}
[testenv:black]
description = Verify code style with black
basepython = python3
skip_install = true
deps =
black == 22.3.0
commands =
black --check src/orion/ tests/
[testenv:run-black]
description = Run code style modification with black
basepython = python3
skip_install = true
deps =
{[testenv:black]deps}
commands =
black src/orion/ tests/
[testenv:isort]
description = Use isort to check import orders
basepython = python3
skip_install = true
deps =
isort == 5.10.1
commands =
isort --profile black -c src/orion/ tests/
[testenv:run-isort]
description = Run isort to fix import orders
basepython = python3
skip_install = true
deps =
{[testenv:isort]deps}
commands =
isort --profile black src/orion/ tests/
[testenv:pylint] # Will use the configuration file `.pylintrc` automatically
description = Perform static analysis and output code metrics
basepython = python3
skip_install = false
deps =
pylint == 2.5.*
commands =
pylint src --ignore src/orion/algo/robo/_version.py
[testenv:packaging]
description = Check whether README.rst is reST and missing from MANIFEST.in
basepython = python3
deps =
check-manifest
readme_renderer
commands =
check-manifest
python setup.py check -r -s
## Setup development process
[testenv:devel]
description = Incremental devel env command, defaults to running tests
deps =
-rtests/requirements.txt
usedevelop = True
commands =
python setup.py test --addopts '-vvv --exitfirst --looponfail {posargs}'
[testenv:doc8]
description = Impose standards on *.rst documentation files
basepython = python3
skip_install = true
deps =
doc8 == 0.8.*
commands =
doc8 docs/
[testenv:docs]
description = Invoke sphinx to build documentation and API reference
basepython = python3
deps =
-rdocs/requirements.txt
commands =
bash -c 'grep -v "^#" requirements.txt | xargs -n 1 -L 1 pip install'
sphinx-build -b html -d build/doctrees -nWT docs/src/ docs/build/html
[testenv:serve-docs]
description = Host the documentation of the project and API reference in localhost
basepython = python3
skip_install = true
changedir = docs/build/html
deps =
commands =
python -m http.server 8000 --bind 127.0.0.1
## Release tooling (to be removed in favor of CI with CD)
[testenv:build]
basepython = python3
skip_install = true
deps =
wheel
setuptools
commands =
python setup.py -q sdist
[testenv:release]
basepython = python3
skip_install = true
deps =
{[testenv:build]deps}
twine >= 1.5.0
commands =
{[testenv:build]commands}
twine upload --skip-existing dist/*
#########################################################
# Packages & Tools configuration
#########################################################
[pytest]
addopts = -ra -q --color=yes
norecursedirs = .* *.egg* config dist build
xfail_strict = True
rsyncdirs = src tests
looponfailroots = src tests
[coverage:run]
branch = True
source =
src
tests
omit = **/_[a-zA-Z0-9]*.py
[coverage:report]
# Regexes for lines to exclude from consideration
exclude_lines =
# Don't complain if tests don't hit defensive assertion code:
pass
raise AssertionError
raise NotImplementedError
# Doc8 configuration
[doc8]
max-line-length = 100
file-encoding = utf-8