Update hacking to 0.10.0
Replace the whitelist of flake8 checks (select) with a blacklist
(ignore). It makes possible to disable a single check, which was not
possible before. This new approach permits to enable new tests more
easily and see which checks are currently disabled.
Only new checks are disabled, this change doesn't run less checks than
before. Currently, many checks are disabled, but following changes will
fix these new warnings.
When the "select" option of flake8 is used in tox.ini, the "ignore"
option is ignored. It is not possible to use "select" and "ignore"
options at the same time. See the code in pep8 (flake8 is based on
pep8):
d48eef0710/pep8.py (L1808)
The purpose of flake8 is to enhance the coding style, but also to help
to detect common bugs. Blacklisting checks permits to detect new bugs
when upgrading the tools. For example, new checks were recently added to
help porting code to Python 3.
This change permits to use pbr 1.0 and newer which is required to
support Python 3. Previously, hacking 0.8.1 was used, but hacking 0.8 is
incompatible with pbr 1.0 and newer (hacking 0.8 requires pbr<1.0).
pbr 1.0 is required to use environment markers on requirements to
install dnspython on Python 2 and dnspython3 on Python 3.
Change-Id: I41d63b9467083d7606ad18aaa398ca7738b27fae
This commit is contained in:
parent
389a97e352
commit
9cb7eb4a4b
@ -3,7 +3,7 @@
|
|||||||
# process, which may cause wedges in the gate later.
|
# process, which may cause wedges in the gate later.
|
||||||
|
|
||||||
# Hacking already pins down pep8, pyflakes and flake8
|
# Hacking already pins down pep8, pyflakes and flake8
|
||||||
hacking>=0.8.0,<0.9
|
hacking>=0.10.0,<0.11
|
||||||
coverage
|
coverage
|
||||||
nose
|
nose
|
||||||
nosexcover
|
nosexcover
|
||||||
|
28
tox.ini
28
tox.ini
@ -50,14 +50,24 @@ commands = {posargs}
|
|||||||
commands = python setup.py build_sphinx
|
commands = python setup.py build_sphinx
|
||||||
|
|
||||||
[flake8]
|
[flake8]
|
||||||
# it's not a bug that we aren't using all of hacking
|
# it's not a bug that we aren't using all of hacking, ignore:
|
||||||
# H102 -> apache2 license exists
|
# F402: import '_' from line 51 shadowed by loop variable
|
||||||
# H103 -> license is apache
|
# F812: list comprehension redefines ...
|
||||||
# H201 -> no bare excepts (unless marked with " # noqa")
|
# H101: Use TODO(NAME)
|
||||||
# H231 -> Check for except statements to be Python 3.x compatible
|
# H202: assertRaises Exception too broad
|
||||||
# H501 -> don't use locals() for str formatting
|
# H232: Python 3.x incompatible octal 000001234 should be written as 0o1234
|
||||||
# H903 -> \n not \r\n
|
# H233: Python 3.x incompatible use of print operator
|
||||||
ignore = H
|
# H234: assertEquals is deprecated, use assertEqual
|
||||||
select = F,E,W,H102,H103,H201,H231,H501,H903
|
# H235: assert_ is deprecated, use assertTrue
|
||||||
|
# H301: one import per line
|
||||||
|
# H306: imports not in alphabetical order (time, os)
|
||||||
|
# H401: docstring should not start with a space
|
||||||
|
# H403: multi line docstrings should end on a new line
|
||||||
|
# H404: multi line docstring should start without a leading new line
|
||||||
|
# H405: multi line docstring summary not separated with an empty line
|
||||||
|
# H501: Do not use self.__dict__ for string formatting
|
||||||
|
# H702: Formatting operation should be outside of localization method call
|
||||||
|
# H703: Multiple positional placeholders
|
||||||
|
ignore = F402,F812,H101,H202,H232,H233,H234,H235,H301,H306,H401,H403,H404,H405,H501,H702,H703
|
||||||
exclude = .venv,.tox,dist,doc,*egg
|
exclude = .venv,.tox,dist,doc,*egg
|
||||||
show-source = True
|
show-source = True
|
||||||
|
Loading…
Reference in New Issue
Block a user