We follow Semantic Versions since the 0.1.0
release.
We used to have incremental versioning before 0.1.0
.
Semantic versioning in our case means:
- Bugfixes do not bring new features, code that passes on
x.y.0
should pass onx.y.1
. With the only exception that bugfix can raise old violations in new places, if they were hidden by a buggy behaviour. But we do not add new checks. - Minor releases do bring new features and configuration options.
New violations can be added. Code that passes on
x.0.y
might not pass onx.1.y
release because of the new checks. - Major releases indicate significant milestones or serious breaking changes.
There are no major releases right now: we are still at
0.x.y
version. But, in the future we might change the configuration names/logic, change the client facing API, change code conventions significantly, etc.
- Fixes
WPS115
false-positive onEnum
attributes, #3238 - Removes duplicated
WPS312
, #3239 - Fixes
WPS432
, now it shows literal num, #1402 - Fixes
WPS226
, now it points to the first string literal occurrence, #3267
This release introduces the new main concept: ruff
compatibility.
Now WPS
is the only flake8
plugin that is installed.
Other things are done by ruff
.
It is faster, it has autofixing, there are lots of rules.
Basically, this way WPS
just gain lots
of new rule and plugins almost for free.
It is now stricter than ever! WPS
now officially supports
ALL ruff
existing rules. This means that there are no conflicts
between two linters.
To run WPS
and ruff
together, use:
ruff format && ruff check && flake8 --select=WPS .
You can copy our configuration from pyproject.toml
(for ruff
) and setup.cfg
(for flake8
).
WPS
can now also be used with black
with default configuration.
However, we recommend using ruff format
instead.
WPS
got a lot faster! Because:
- We removed a lot of
flake8
plugins - We removed a lot of rules covered by
ruff
Running 0.19.2
(previous version) on https://github.com/dry-python/returns
» time flake8 .
flake8 . 20.63s user 2.47s system 469% cpu 4.919 total
The same on 1.0.0
:
» time flake8 .
flake8 . 8.56s user 0.54s system 898% cpu 1.013 total
Which is 2.4x times faster!
We also significantly improved all the integrations!
WPS
can now be used as first-class pre-commit
hook with:
repos:
- repo: https://github.com/wemake-services/wemake-python-styleguide
rev: 1.0.0
hooks:
- id: wemake-python-styleguide
Our GitHub Action also got a lot of new options and fixes.
- Breaking: Drops
python3.9
support - Breaking: Drops
nitpick
support - Breaking: Drops
flake8-commas
,flake8-isort
,flake8-debugger
,flake8-string-format
,flake8-quotes
,flake8-comprehensions
,flake8-bugbear
,flake8-docstrings
,flake8-eradicate
,flake8-bandit
,flake8-broken-line
,flake8-rst-docstrings
,pep8-naming
support, useruff format
andruff check
instead - Breaking: Drops
darglint
support, because it is unmaintained - Breaking: Removes
WPS113
, because is covered bypylint
linter - Breaking: Removes
WPS119
, because is covered bypylint
linter - Breaking: Removes
WPS125
, because it is covered byruff
linter - Breaking: Removes
WPS302
, because it is covered byruff
formatter - Breaking: Removes
WPS304
, because it is covered byruff
formatter - Breaking: Removes
WPS305
, because it is covered byruff
formatter - Breaking: Removes
WPS306
, because it is covered byruff
formatter - Breaking: Removes
WPS309
, because it is covered byruff
formatter - Breaking: Removes
WPS310
, because it is covered byruff
formatter - Breaking: Removes
WPS313
, because it is covered byruff
formatter - Breaking: Removes
WPS315
, because it is covered byruff
formatter - Breaking: Removes
WPS316
, because it is covered byruff
linter - Breaking: Removes
WPS317
, because it is covered byruff
formatter - Breaking: Removes
WPS318
, because it is covered byruff
formatter - Breaking: Removes
WPS319
, because it is covered byruff
formatter - Breaking: Removes
WPS320
, because it is covered byruff
formatter - Breaking: Removes
WPS323
, because it is covered byruff
formatter - Breaking: Removes
WPS326
, because it is covered byruff
linter - Breaking: Removes
WPS329
, because it is covered byruff
linter - Breaking: Removes
WPS331
, because it is covered byruff
linter - Breaking: Removes
WPS333
, because is covered bypylint
linter - Breaking: Removes
WPS337
, because it is covered byruff
formatter - Breaking: Removes
WPS340
, because it is covered byruff
formatter - Breaking: Removes
WPS341
, because it is covered byruff
formatter - Breaking: Removes
WPS343
, because it is covered byruff
formatter - Breaking: Removes
WPS348
, because it conflicts withruff
formatter - Breaking: Removes
WPS351
, because it is covered byruff
linter - Breaking: Removes
WPS352
, because it is covered byruff
formatter - Breaking: Removes
WPS355
, because it is covered byruff
formatter - Breaking: Removes
WPS360
, because it is covered byruff
formatter - Breaking: Removes
WPS361
, because it is covered byruff
formatter - Breaking: Removes
WPS415
, because is covered byruff
linter - Breaking: Removes
WPS417
, because is covered byruff
linter - Breaking: Removes
WPS419
, because is covered byruff
linter - Breaking: Removes
WPS423
, because is covered byruff
linter - Breaking: Removes
WPS424
, because is covered byruff
linter - Breaking: Removes
WPS425
, because is covered byruff
linter - Breaking: Removes
WPS428
, because is covered byruff
linter - Breaking: Removes
WPS433
, because is covered bypylint
linter - Breaking: Removes
WPS434
, because is covered bypylint
linter - Breaking: Removes
WPS436
, because is covered bypylint
linter - Breaking: Removes
WPS437
, because is covered byruff
linter - Breaking: Removes
WPS440
, because it was buggy and is covered bymypy
, #3209 - Breaking: Removes
WPS442
, because it was buggy and is covered bymypy
, #3209 - Breaking: Removes
WPS450
, because is covered bypylint
linter - Breaking: Removes
WPS452
, because is covered byruff
linter - Breaking: Removes
WPS454
, because is covered byruff
linter - Breaking: Removes
WPS456
, because is covered byruff
linter - Breaking: Removes
WPS465
, because|
is now heavily used by typing - Breaking: Removes
WPS467
, because is covered bypylint
linter - Breaking: Removes
WPS502
, because is covered byruff
linter - Breaking: Removes
WPS503
, because is covered byruff
linter - Breaking: Removes
WPS507
, because is covered bypylint
linter - Breaking: Removes
WPS508
, because is covered byruff
linter - Breaking: Removes
WPS510
, because is covered bypylint
linter - Breaking: Removes
WPS514
, because is covered bypylint
linter - Breaking: Removes
WPS528
, because is covered bypylint
linter - Breaking: Removes
WPS525
, because is covered byruff
linter - Breaking: Removes
WPS526
, because is covered byruff
linter - Breaking: Removes
WPS521
, because is covered byruff
linter - Breaking: Removes
WPS609
, because is covered bypylint
linter - Breaking: Removes
--i-control-code
setting, if you want to disable some violations, just use# noqa
or--ignore
with code that you want to exclude, there's no need to create one more way of disabling some specific violations
- Adds official
python3.13
support - Allows any compares in
assert
statements forWPS520
, #3112 - Allows walrus operator (
:=
) in comprehesions, #3121 - Allows
pass
incase
bodies, #2642 - Allows subclassing builtins in
WPS600
, when creating anEnum
, #2506 - Allows using variables after blocks for
WPS441
inassert
statements, #2543 - Does not count
self
,cls
, andmcs
as arguments forWPS211
complexity check anymore, #2394 - Allows underscores (
_
) with exactly 3 digits after it inWPS303
, #3120 - Allows class / instance attribute shadowing
in
@dataclass
es forWPS601
, #1926 - Allows any number of instance attributes on
@dataclass
es inWPS230
, #2448 - Allows any number of function parameters
in
@overload
definitions forWPS211
, #1957 - Allows using multiline strings when placed on separate lines, #3056
- Allows using
hasattr
builtin function, #2228 - Disallows using
is not
andnot in
as negated conditions inWPS504
, #2617 - Allows all branches in
if/elif/else
to be negated inWPS504
, #2617 - Adds a new rule to forbid
lambda
assigns to special attributes, #1733 - Adds a new rule to check problematic function params, #1343
- Adds a new rule to detect duplicate conditions in
if
s andelif
s, #2241 - Adds a new rule to detect duplicate
case
pattens inmatch
, #3206 - Adds a new rule to find too many
match
subjects, #3201 - Adds a new rule to detect too many
case
statements, #3202 - Adds a new rule to find too complex
except
with too many exceptions - Adds a new rule to find too many
PEP695
type params - Adds a new rule to find useless ternary expressions, #1706
- Adds a new rule to forbid
raise SystemExit
, usesys.exit
instead, #1786 - Adds a new rule to forbid extra syntax in
match ...
subjects, #3217 - Adds new
--allowed-module-metadata
and--forbidden-module-metadata
configuration options forWPS410
, #3060 - Now
--allowed-domain-names
also affectWPS11
to allow custom short variable names, #2554 - Adds support to run
wemake-python-styleguide
as apre-commit
hook, #2588 - GitHub Action can now use
cwd:
parameter to specify where your configuration file is, #2474 - GitHub Action can now use
fail_workflow:
parameter to not fail the workflow even if the check did find any issues - GitHub Action can now use
filter_mode:
parameter to specify how ReviewDog will filter found violations, see https://github.com/reviewdog/reviewdog#filter-mode #2239
- Fixes
WPS217
to allow simple calls inf
strings, #3150 - Fixes
WPS217
not to raise on emptyf
strings, becauseruff check
handles that now for us - Fixes
OverusedStringViolation
not to include'...'
string - Removes
astor
package in favour ofast.unparse
- Fixes
WPS210
to not count nested local variables in nested scopes #3108 - Fixes
IterableUnpackingViolation
with generic types andTypeVarTuple
- Fixes
WPS469
detecting incorrect names of raised exceptions, #3109 - Fixes unnormalized paths in formatter output
- Fixes
WPS221
to ignore PEP695'sTypeAlias
from line complexity checks - Fixes
WPS474
to only count import collisions in the same context, #2962 - Fixes
WPS612
to count defaults in function definitions, #2478 - Fixes several bugs in
WPS322
with multiline strings detection - Fixes several violations not been detected in
case:
statements - Fixes
WPS314
not detectingmatch
statements - Fixes
match
+case
does not increase cognitive complexity
- Integration with
ondivi
doc for legacy codebases - Fixes a documentation error for the Formatter (Showing statistic) section
- Source code is now formatted with
ruff
- Removes deprecated
ast
nodes from code:ast.Num
,ast.Bytes
,ast.Str
,ast.NamedConstant
, etc
- Fixes
WrongEmptyLinesCountViolation
crash onCallable[..., ...]
#2899
This release fixes how ...
is used. For example, it is common to define
function stubs / protocols like this:
def some_function(): ...
Now, ...
will be excluded from several rules.
- Fixes
TooDeepNestingViolation
not to trigger on...
in functions and classes - Fixes
StatementHasNoEffectViolation
not to trigger on...
in functions and classes, when it is the only node
This minor version will be the last release with all the flake8
plugins.
In the future this project will be migrated to be used together with ruff
.
- Adds official
python3.12
support - Breaking: drops
python3.8
support - Breaking: Reconsider
object
required base class exception: sinceclass Klass[_Type]
must not containobject
, this rule is change to be the opposite:object
explicit base class must not be used. You can useruff
to change allobject
-based types to the new style:ruff check --select=UP004 --fix .
https://docs.astral.sh/ruff/rules/useless-object-inheritance/ - Breaking: allow positional-only parameters,
since it is required by
mypy
when usingConcatenate
- Adds support for naming rules for PEP695 type params
- Due to how
f
-string are parsed inpython3.12
several token-based violations are not reported anymore for them:UselessMultilineStringViolation
,ImplicitRawStringViolation
,WrongUnicodeEscapeViolation
,RawStringNotNeededViolation
wemake
output formatter now respectsNO_COLOR=1
option to disable text highlighting. See https://no-color.org- Adds
ImportObjectCollisionViolation
to detect the same objects imported under different aliases - Adds
reveal_locals
to the list of forbidden functions - Updates
flake8
to7.x
- Fixes
ForbiddenInlineIgnoreViolation
config parsing. #2590 - Fixes
WrongEmptyLinesCountViolation
for func definitions with ellipsis. #2847 - Fixes
WrongEmptyLinesCountViolation
for multiline implicit string concatenation. #2787 - Fixes
ObjectInBaseClassesListViolation
,UnpythonicGetterSetterViolation
,ImplicitInConditionViolation
,RedundantSubscriptViolation
,TooLongCompareViolation
to include better error details - Fixes
TooDeepNestingViolation
forTryStar
andMatch
statements - Fixes
TooLongTryBodyViolation
andTooManyExceptCasesViolation
to work forTryStar
statements as well - Fixes
UselessNodeViolation
to work withTryStar
- Fixes
DuplicateExceptionViolation
to work withTryStar
- Fixes
TryExceptMultipleReturnPathViolation
to work withTryStar
- Fixes
IncorrectExceptOrderViolation
to work withTryStar
- Fixes that
MatchStar
was not checked in pattern matching name assignments - Fixes pattern matching support
in
BlockAndLocalOverlapViolation
andOuterScopeShadowingViolation
- Updates multiple
flake8-*
dependencies - Fixes multiple typos in docs
- Breaking: drops
python3.7
support, because it has almost reached its EOL - Adds
python3.11
support - Bump
flake8
to version5.x
- Bump
flake8-*
dependencies to newer versions - Added
ChainedIsViolation
#2443 - Added
BuggySuperContextViolation
#2310
- Make
generic_visit()
check script properly handlewith
statements. - Allow calling magic methods with the same name as the enclosing method #2381
- Fix WrongEmptyLinesCountViolation false positive #2531
- Fix OpenWithoutContextManagerViolation false positive #2577
- Replaced
flakehell
mentions toflakeheaven
#2409
- Breaking: drops
python3.6
support - Adds support for pattern matching naming rules, same as other variables
- Adds
--show-violation-links
option to show links to violation docs - Adds
__init_subclass__
in the beginning of accepted methods order as per WPS338 #2411 - Adds
WrongEmptyLinesCountViolation
to check for too many lines in functions and methods definitions #2486
- Fixes
WPS226
false positives on|
use inSomeType | AnotherType
type hints syntax - Now
-1
is not reported to be an overused expression - Allow
__aiter__
to be async iterator - Adds violation method name to error message of
YieldMagicMethodViolation
- Fixes direct docker image invocation #2492
- Adds full violation codes to docs and
BaseViolation.full_code
#2409 - Fix documentation mismatch between default setting
for
max-string-usages
and enforced rule #2456 - Domain name was changed from
wemake-python-stylegui.de
towemake-python-styleguide.rtfd.io
- Fixes crash on
'Literal["raise"]'
annotation #2341 - Fixes
WPS471
was not detected on complex assignment targets #2301 - Fixes
flake8-bandit
andbandit
version conflict #2368
- Supports new
flake8
version4.x
- Now
InconsistentYieldViolation
andInconsistentReturnViolation
are raised whenyield
orreturn
is used withNone
where plain version should be used #2151 - Dot
'.'
and comma','
do not count against string literal overuse limit anymore #2209 - Added
RedundantEnumerateViolation
#1825 - Adds
RaiseFromItselfViolation
#2133 - Adds
ConsecutiveSlicesViolation
#2064 - Adds
KwargsUnpackingInClassDefinitionViolation
#1754 DirectMagicAttributeAccessViolation
now only flags instances for which a known alternative exists #2268- Forbids getting collection element of list by unpacking #1824
- Now
WPS227
forbids returning tuples that are too long #1731
- Fixes that
InconsistentComprehensionViolation
was ignoring misalignedin
expressions #2075 - Fixes some common magic methods not being recognized as such #2281
- Removes all
Raises:
from docstrings, they were unused - Added example to
README.md
- Added
why strict is good
- Replaced all
python
withPython
inREADME.md
- Improve Docs: Fixed all typos and grammatical errors in
CHANGELOG.md
- Updated documentation with the recommended
isort
config. #1934 - Updates
typing_extensions
to4.x
- Fixes crash on
python3.10
- Fixes
UselessReturningElseViolation
to not reportelse
withbreak
#1958 - Fixes
ReassigningVariableToItselfViolation
to not report onx = (x,)
#1807 - Fixes
ReassigningVariableToItselfViolation
to extract variables from unary operators #1874 - Fixes that
f'{some:,}'
was considered too complex #1921 - Fixes that
range(len(x))
was not allowed even outsidefor
loops #1883 - Fixes
UselessReturningElseViolation
to not reportelse
withbreak
#2187 (even if we haveexcept
in loop) - Fixes fixture in
UselessReturningElseViolation
#2191
- Adds documentation (and tests) for how to run project on Jupyter Notebooks
- Updates
mypy
to0.902
and fixes type issues
- Fixes
BitwiseAndBooleanMixupViolation
work with PEP 604 union types #1884 - Fixes
CognitiveModuleComplexityViolation
to not trigger for a single-item modules - Fixes that
ConstantConditionViolation
was not reported for aBoolOp
- Functions and methods marked as
@overload
or@typing.overload
do not count in complexity rules
- Updates GitHub Action's base Python image version to
3.8.8
- Adds a math operations evaluator to improve and allow several violation checks.
- Fixes
dataclasses
import, it was failing onpython3.6
- Fixes
InconsistentComprehensionViolation
work withasync
comprehensions - Fixes nested comprehensions support for
InconsistentComprehensionViolation
- Fixes multiple
if
support forInconsistentComprehensionViolation
- Fixes that
NestedTernaryViolation
was not reported for a comprehension - Fixes that
ConstantConditionViolation
was not reported for a comprehension - Fixes that
ConstantConditionViolation
was triggering forwhile x := True:
- Fixes that
UselessElseViolation
was not reported forfor
,while
, andtry
keywords - Fixes false positive
InfiniteWhileLoopViolation
fortry
#1857 - Fixes that
InfiniteWhileLoopViolation
was not triggered on1
or other truthy nodes
- Refactors how
tokenize
tests are executed, now we have an option to compile fixture code to make sure it is syntactically valid.
- Adds
python3.9
support - Forbids to use new-style decorators on
python3.9
- Changes how we treat own/foreign attributes,
since now we only check assigned attribute names for
self
/cls
/mcs
, but not any other ones. So, now writingpoint.x = 1
will not trigger any violations. Previously, it would raise "too short name". - Forbids using non-trivial expressions as an argument to
except
- Forbids using too many variables in a tuple unpacking
- Forbids using
float("NaN")
. - Forbids assigning to a slice
- Allow
__call__
method to be asynchronous - Allows common strings not to be counted against string constant overuse limit
- Forbids to unpack iterable objects to lists #1259
- Forbids to use single
return None
- Add
__await__
to the list of priority magic methods - Forbids to use float zeros (
0.0
) - Forbids
raise Exception
andraise BaseException
- Forbids to use
%
with zero as the divisor - Forbids testing conditions to just return booleans when it is possible to simply return the condition itself
- Forbids to use unsafe infinite loops
- Forbids to use raw strings
r''
when not necessary - Forbids to use too complex
f
-strings - Forbids to use too many
raise
statements inside a single function - Forbids to compare with
float
andcomplex
values - Forbids single element destruct
- Forbids to ignore some violations (configurable) on a line level
- Forbids single element unpacking
- Forbids to unpack lists with side-effects
- Forbids to use multiline strings except for assignments and docstrings
- Forbids not returning anything in functions and methods starting with
get_
- Forbids to use empty comment
- Forbids using bitwise operation with boolean operation
- Forbids inconsistent structuring of multiline comprehensions
- Forbids to use unpythonic getters and setters such as
get_attribute
orset_attribute
- Now
credits
,license
, andcopyright
builtins are free to shadow
- Fixes fails of annotation complexity on
Literal[""]
- Fixes how wrong variable names were checked case sensitive with
WPS110
- Fixes false positives DirectMagicAttributeAccessViolation with
__mro__
,__subclasses__
and__version__
- Make
WPS326
work when there is comment between string literals - Allowed yield statements in call method
- Allow to use
^
with1
- Fixes false positives in WPS513 and WPS323
- Fixes false positive WPS426 if
lambda
in loop uses only its arguments - Fixes false negative WPS421 with
pprint.pprint
- Fixes WPS441 triggering when reusing variable names in multiple loops
- Fixes false positive ImplicitEnumerateViolation on range with step #1742
- Allows to use
_
to declare several unused variables, like:x, _, _ = coordinates()
- Fixes variable reassignment in class context
- Fixes that
*'abc'
was not counted as pointless star expression - Fixes that
-some
was counted as overused expression - Fixes several bugs with attribute names
- Updates lots of dependencies
- Fixed documentation for TooManyPublicAttributesViolation
- Updated isort config
- Introduce helper script to check
for missing calls to
self.generic_visit(node)
in AST visitors - Updates
poetry
version to1.1
- Updates
reviewdog
version to0.11.0
and addsaction-depup
This release was focused on adding python3.8
support,
removing dependencies that can be removed, and fixing bugs.
There are breaking changes ahead!
We also have this nice 0.14 migration guide.
- Breaking: removes
flake8-executable
, now usingWPS452
instead ofEXE001..EXE005
- Breaking: removes
flake8-print
, now usingWPS421
instead ofT001
- Breaking: removes
flake8-builtins
, now usingWPS125
instead ofA001..A005
- Breaking: removes
flake8-annotations-complexity
, now usingWPS234
instead ofTAE002
- Breaking: removes
flake8-pep3101
, now usingWPS323
instead ofS001
, we also use a new logic for this violation: we check string defs for%
patterns, and not for%
operator - Breaking:
WPS441
is no longer triggered forexcept
blocks, it is now handled byF821
fromflake8
- Breaking: removes
radon
, becausecognitive-complexity
andmccabe
is enough - Breaking: removes
flake8-logging-format
as a direct dependency - Breaking: removes
ImplicitTernaryViolation
orWPS332
, because it has too many false positives #1099 - Removes
flake8-coding
, all encoding strings, visitor and tests for oldWPS323
which is now reused for modulo formatting checks - Adds
python3.8
support - Changes
styleguide.toml
andflake8.toml
scripts definition - Extracts new violation -
WPS450
fromWPS436
#1118 - Adds domain names options:
--allowed-domain-names
and--forbidden-domain-names
, that are used to create variable names' blacklist #1106 - Forbids to use
\r
(carriage return) as line breaks in strings #1111 - Forbids to use
:=
operator, it now reusesWPS332
code - Forbids to use positional only
/
arguments - Forbids to have too many names imported from a single
from ... import
- Forbids to use
continue
andbreak
infinally
- Forbids to use
__reduce__
and__reduce_ex__
magic methods - Adds
__call__
to list of methods that should be on top #1125 - Allows
_
to be now used as a defined variable - Removes
cognitive_complexity
dependency, now it is built in into our linter - Adds baseline information for all complexity violation messages:
x > baseline
- Changes how cognitive complexity is calculated
- Adds support for positional arguments in different checks
- Adds
UnreadableNameViolation
asWPS124
because there are some character combination which is not easy to read - Adds support for
NamedExpr
with in compare type violation - Forbids
float
andcomplex
compares
- Fixes how
i_control_code
behaves withWPS113
- Fixes that cognitive complexity was ignoring
ast.Continue
,ast.Break
, andast.Raise
statements - Fixes that cognitive complexity was ignoring
ast.AsyncFor
loops - Fixes that annotation complexity was not reported for
async
functions - Fixes that annotation complexity was not reported for lists
- Fixes that annotation complexity was not reported for
*
and/
args - Fixes that annotation complexity was not tested for dot notation attributes
- Fixes that annotation complexity fails on string expressions
- Fixes bug when
TooManyPublicAttributesViolation
was counting duplicate fields - Fixes negated conditions
WPS504
was not reported forif
expressions - Fixes that
import dumps
was reported asWPS347
, now onlyfrom ... import dumps
is checked - Fixes that
from some import a as std
was reported as a vague import withWPS347
despite having a meaningful alias - Fixes that
WPS501
was reported for@contextmanager
definition - Fixes
WPS226
to be thrown at nested string type annotations - Fixes
WPS204
reported simplest nodes as overused like[]
andcall()
- Fixes
WPS204
not reporting overusedf
strings - Fixes
WPS204
reporting overused return type annotations - Fixes
WPS204
reportingself.
attribute access - Fixes
WPS331
reporting cases that do require some extra steps before return - Fixes
WPS612
not reportingsuper()
calls without return - Fixes
WPS404
not raising on wrong*
and/
defaults - Fixes
WPS425
raising on.get
,getattr
,setattr
, and other builtin functions without keyword arguments - Fixes
WPS221
reporting differently on differentpython
versions - Fixes
WPS221
reporting nested variable annotations - Fixes
WPS509
not reporting nested ternary in grandchildren ofif
- Fixes
WPS509
not reporting nested ternary in ternary - Fixes
WPS426
not reporting nestedlambda
in comprehensions - Fixes several violations to reporting for
ast.Bytes
andast.FormattedStr
whereast.Str
was checked - Fixes
WPS601
reporting shadowing for non-self
attributes - Fixes
WPS114
not to be so strict - Fixes
WPS122
not raising forfor
andasync for
definitions - Fixes
WPS400
raising for# type: ignore[override]
comments - Fixes
WPS115
not raising for attributes inside other nodes
- Changes how tests are executed
- Changes how coverage is calculated, adds
coverage-conditional-plugin
- Adds how a violation can be deprecated
- Improves old visitor tests with
/
argument cases - Improves old visitor tests with
:=
cases - Adds
local-partial-types
to mypy config - Uses
abc
stdlib's module to mark abstract base classes #1122 - Adds
python3.8
to the CI - Updates a lot of dependencies
This is the last 0.13.x
supporting release,
we have to concentrate on python3.8
support
and 0.14.0
which will introduce it to the public.
- Fix false positive ImplicitYieldFromViolation for async functions #1057
- Fixes nested-classes-whitelist option default value for flake8 prior 3.7.8 #1093
- Improve boolean non-keyword arguments validation #1114
- Updates
flake8-pep3101
- Updates
flake8-builtins
- Updates
flake8-eradicate
- Several small refactoring sessions
- Adds
hypothesis
-based tests - Adds
flakehell
base config - Fixes
flakehell
docs - Fixes
MAX_NOQA_COMMENTS
and related violation docs - Fixes
OverusedExpressionViolation
andTooManyExpressionsViolation
docs
- Updates
radon
version - Updates
poetry
version to1.0
- Fixes that Github Action was failing for wrong status code
- Fixes
NegatedConditionsViolation
false positive on absentelse
in combination withelif
- Fixes
WPS528
false positive on augmented assigns - Fixes incorrect message for
WPS349
- Fixes that
reviewdog
was not able to create more than30
comments per PR
pylint
docs fixed- Fixes docs about implicit
yield
violation
- Fixes that
_
was marked as invalid byVagueImportViolation
- Fixes that docs for
VagueImportViolation
were misleading - Fixes invalid docs for
BracketBlankLineViolation
#1020 - Add more complex example to
ParametersIndentationViolation
#1021
- Now our GitHub Action can be used to leave PR review comments
This is a huge release that was created during the Hactoberfest season. It was impossible without the huge help from our awesome contributors. Thanks a lot to everyone!
This release is not focused on any particular area. It features a lot of new rules from different categories.
- Adds cognitive complexity metric, introduced by
cognitive_complexity
- Adds docstrings linter
darglint
- Updates
pep8-naming
andflake8-comprehensions
WPS431
now allow customize whitelist vianested-classes-whitelist
setting- Forbids to have invalid strings in stared expressions like
**{'@': 1}
- Forbids to use implicit primitive values in a form of
lambda: 0
- Forbids to use approximate math constants
- Forbids to redefine string constants
- Forbids use of vague import names (e.g.
from json import loads
) - Makes
OveruseOfNoqaCommentViolation
configurable via--max-noqa-comments
- Forbid incorrectly swapped variables
- Forbids to use redundant subscripts (e.g.,
[0:7]
or[3:None]
) - Allows
super()
as a valid overused expression - Forbids to use
super()
with other methods and properties WPS350
enforces using augmented assign pattern- Forbids unnecessary literals
WPS525
forbids comparisons wherein
is compared with single item container- Forbids wrong annotations in assignment
- Forbids using multiline
for
andwhile
statements WPS113
now can be tweaked withI_CONTROL_CODE
setting- Adds
WPS000
that indicates internal errors - Forbids to use implicit
yield from
- Forbids to start lines with
.
- Enforces better
&
,|
,>>
,<<
,^
operators usage - Forbids incorrect exception order
- Enforces tuples usage with frozenset constructor
- Changes how
WPS444
works, now we use stricter logic forwhile
andassert
- Forbids to use
yield from
with incorrect types - Forbids to use consecutive
yield
expressions - Enforces to use
.items()
in loops - Enforces using
.get()
overkey in dict
checks - Forbids to use and declare
float
keys in arrays and dictionaries - Forbids to use
a[len(a) - 1]
because it is justa[-1]
- Forbids too long call chains like
foo(a)(b)(c)(d)
- Fixes
ImplicitElifViolation
false positives on a specific edge cases - Fixes
--i-control-code
setting forBadMagicModuleFunctionViolation
- Fixes compatibility with flake8
3.8.x
- Fixes that
not not True
was not detected asWPS330
- Fixes addition of
MisrefactoredAssignmentViolation
check - Fixes
WrongMagicCommentViolation
not catching certain wrong comments - Fixes
BadMagicModuleFunctionViolation
false positives on class-level methods - Fixes
InconsistentReturnViolation
false positives on nested functions - Fixes that
--i-dont-control-code
was not present in command line options - Fixes
BlockVariableVisitor
false positives on a properties - Fixes that
//
was not recognised as a math operation - Fixes false positive
BlockAndLocalOverlapViolation
on annotations without value assign - Fixes bug when
x and not x
was not detected as the similar conditions byWPS408
- Fixed that
1.0
and0.1
were treated as magic numbers
- Improves Github Action stability
- Replace
scripts/tokens.py
andscripts/parse.py
with external tools - Improves violation code testing
- Improves testing of
.. versionchanged
andprevious_codes
properties - Reference
isort
settings requirement for compliance withWPS318
in docstring - Improves tests: we now ensure that each violation with previous codes also has corresponding versions changed in their documentation
- We now ignore
@overload
fromBlockAndLocalOverlapViolation
- Now expressions that reuse block variables are not treated as violations,
example:
my_var = do_some(my_var)
- Adds Github Action and docs how to use it
- Adds local Github Action that uses itself for testing
- Adds official Docker image and docs about it
- Fixes bug with
nitpick
colors and new files API - Updates
flake8-docstrings
- Fixes that formatting was failing sometimes when colours were not available
- Fixes that
1 / number
was not allowed - Fixes that
%
operator was allowed for0
and1
- Adds
reveal_type
to the list of forbidden functions WPS517
now allows to use non-string keys inside**{}
, so this is allowed:Users.objects.get(**{User.USERNAME_FIELD: username})
- Fixes that
{**a, **b}
was reported as duplicate hash items
- Tweaks
nitpick
configuration
- Changes
radon
andpydocstyle
versions for better resolution - Fixes
nitpick
urls
- Improves
README.md
withflakehell
andnitpick
mentions - Improves docs all across the project
In this release we had a little focus on:
- Primitives and constants and how to use them
- Strings and numbers and how to write them
- OOP features
- Blocks and code structure, including variable scoping and overlapping variables
- Overused expressions and new complexity metrics
- Breaking: moves
ImplicitInConditionViolation
fromWPS336
toWPS514
- Breaking: now
ExplicitStringConcatViolation
usesWPS336
- Breaking: moves
YieldMagicMethodViolation
fromWPS435
toWPS611
- Adds
xenon
as a dependency, it also checks for cyclomatic complexity, but uses more advanced algorithm with better results - Forbids to have modules with too many imported names
configured by
--max-imported-names
option which is 50 by default - Forbids to raise
StopIteration
inside generators - Forbids to have incorrect method order inside classes
- Forbids to make some magic methods async
- Forbids to use meaningless zeros in float, binary, octal, hex, and expanentional numbers
- Enforces to use
1e10
instead of1e+10
- Enforces to use big letters for hex numbers:
0xAB
instead of0xab
- Enforces to use
r'\n'
instead of'\\n'
- Forbids to have unicode escape characters inside binary strings
- Forbids to use
else if
instead ofelif
- Forbids to have too long
try
bodies, basicallytry
bodies with more than one statement - Forbids to overlap local and block variables
- Forbids to use block variables after the block definitions
- Changes how
WrongSlotsViolation
works, now(...) + value
is restricted in favor of(..., *value)
- Forbids to have explicit unhashable types in sets and dicts
- Forbids to define useless overwritten methods
- Enforces
j
prefix overJ
forcomplex
numbers - Forbids overused expressions
- Forbids explicit
0
division, multiply, pow, addition, and subtraction - Fordids to pow, multiply, or divide by
1
- Forbids to use expressions like
x + -2
, ory - -1
, orz -= -1
- Forbids to multiply lists like
[0] * 2
- Forbids to use variable names like
__
and_____
- Forbids to define unused variables explicitly:
_unused = 2
- Forbids to shadow outer scope variables with local ones
- Forbids to have too many
assert
statements in a function - Forbids to have explicit string contact:
'a' + some_data
, use.format()
- Now
YieldInsideInitViolation
is namedYieldMagicMethodViolation
and it also checks different magic methods in a class - Forbids to use
assert False
and other false-constants - Forbids to use
while False:
and other false-constants - Forbids to use
open()
outside ofwith
- Forbids to use
type()
for compares - Forbids to have consecutive expressions with too deep access level
- Forbids to have too many public instance attributes
- Forbids to use pointless star operations:
print(*[])
- Forbids to use
range(len(some))
, useenumerate(some)
instead - Forbids to use implicit
sum()
calls and replace them with loops - Forbids to compare with the falsy constants like
if some == []:
- Bumps
flake8-eradicate
version and solvesattrs
incompatible versions issue - Bumps
flake8-dosctrings
version and solvedpydocstyle
issue - Fixes
TryExceptMultipleReturnPathViolation
not trackingelse
andfinally
returns at the same time - Fixes how
TryExceptMultipleReturnPathViolation
works: now handlesbreak
andraise
statements as well - Fixes
WrongLoopIterTypeViolation
not triggering for generator expressions and empty tuples - Fixes
WrongLoopIterTypeViolation
not triggering for numbers (including negative), booleans,None
- Fixes
WrongLoopIterTypeViolation
position - Fixes
WrongLoopIterTypeViolation
not triggering for compehensions - Fixes
WrongSlotsViolation
not triggering for comprehensions and incorrect__slots__
names and types - Fixes
WrongSlotsViolation
not triggering for invalidpython
identifiers like__slots__ = ('123_slot',)
- Fixes
WrongSlotsViolation
triggering for subscripts - Fixes
NestedClassViolation
andNestedFunctionViolation
not reporting when placed deeply inside other nodes - Fixes when
WrongUnpackingViolation
was not raised forasync for
andasync with
nodes - Fixes when
WrongUnpackingViolation
was not raised for comprehensions - Fixes that
x, y, z = x, z, y
was not recognized asReassigningVariableToItselfViolation
- Fixes that
{1, True, 1.0}
was not recognised as a set with duplicates - Fixes that
{(1, 2), (1, 2)}
was not recognised as a set with duplicates - Fixes that
{*(1, 2), *(1, 2)}
was not recognised as a set with duplicates - Fixes that
{1: 1, True: 1}
was not recognised as a dict with duplicates - Fixes that
complex
numbers were always treated like magic, now1j
is allowed - Fixes that
0.0
was treated as a magic number - Fixes that it was possible to use
_
in module body - Fixes
WrongBaseClassViolation
not triggering for nested nodes likeclass Test(call().length):
- Fixes
ComplexDefaultValueViolation
not triggering for nested nodes likedef func(arg=call().attr)
- Fixes
TooShortNameViolation
was not triggering for_x
andx_
- Fixes that some magic method were allowed to be generators
- Fixes that some magic method were allowed to contain
yield from
- Fixes bug when some correct
noqa:
comments were reported as incorrect - Fixes bug when some
else: return
were not reported as incorrect - Fixes bug when
WPS507
sometimes were raisingValueError
- Fixes bug when
return None
was not recognized as inconsistent
- Adds
styles/
directory with style presets for tools we use and recommend - Adds
bellybutton
to the list of other linters - Documents how to use
nitpick
to sync the configuration - Documents how to use
flakehell
to createbaseline
s for legacy integrations - Improves tests for binary, octal, hex, and exponentional numbers
- Adds new
xenon
CI check - Now handles exceptions in our own code, hope to never see them!
- Now uses
coverage
checks in deepsource - Now
@alias
checks that all aliases are valid - Changes how presets are defined
- Improves how
DirectMagicAttributeAccessViolation
is tested - Refactors a lot of tests to tests
ast.Starred
- Refactors a lot of tests to have less tests with the same logical coverage
- We now use
import-linter
instead oflayer-linter
- Adds docs about CI integration
- Now wheels are not universal
- Updates docs about
snake_case
inEnum
fields - Updates docs about
WPS400
and incorrect line number
- Now using
pygments
as a direct dependency
We had a really big problem: all violations inside best_practices
was messed up together with no clear structure.
We had to fix it before it is too late. So, we broke existing error codes. And now we can promise not to do it ever again.
We also have this nice 0.11 migration guide for you to rename your violations with a script.
- Breaking: replaces
Z
error code toWPS
code - Breaking: creates new violation group
refactoring.py
- Breaking: creates new violation group
oop.py
- Breaking: moving a lot of violations
from
best_practices
torefactoring
,oop
, andconsistency
- Adds new
wemake
formatter (using it now by default)
- Fixes error message of
OverusedStringViolation
for empty strings - Now does not count string annotations as strings for
OverusedStringViolation
- Fixes
InconsistentReturnVariableViolation
was raised twice
- Adds migration guide to
0.11
- Improves legacy guide
- Adds
--show-source
to the default recommended configuration - Adds better docs about auto-formatters
- Adds
autopep8
to CI to make sure thatwps
is compatible with it - Ensures that
--diff
mode works forflake8
- Renames
Incorrect
toWrong
where possible - Renames
IncorrectlyNestedTernaryViolation
toNestedTernaryViolation
- Renames
IncorectLoopIterTypeViolation
toWrongLoopIterTypeViolation
This release is mostly targeted at writing better compares and conditions. We introduce a lot of new rules related to this topic improving: consistency, complexity, and general feel from your code.
In this release we have ported a lot of existing pylint
rules,
big kudos to the developers of this wonderful tool.
- Adds
flake8-executable
as a dependency - Adds
flake8-rst-docstrings
as a dependency - Validates options that are passed with
flake8
- Forbids to use module level mutable constants
- Forbids to over-use strings
- Forbids to use
breakpoint
function - Limits yield tuple lengths
- Forbids to have too many
await
statements - Forbids to subclass lowercase
builtins
- Forbids to have useless
lambda
s - Forbids to use
len(sized) > 0
andif len(sized)
style checks - Forbids to use repeatable conditions:
flag or flag
- Forbids to write conditions like
not some > 1
- Forbids to use heterogeneous compares like
x == x > 0
- Forbids to use complex compare with several items (
>= 3
) - Forbids to have class variables that are shadowed by instance variables
- Forbids to use ternary expressions inside
if
conditions - Forces to use ternary instead of
... and ... or ...
expression - Forces to use
c < b < a
instead ofa > b and b > c
- Forces to use
c < b < a
instead ofa > b > c
- Forbids to use explicit
in []
andin ()
, use sets or variables instead - Forces to write
isinstance(some, (A, B))
instead ofisinstance(some, A) or isinstance(some, B)
- Forbids to use
isinstance(some (A,))
- Forces to merge
a == b or a == c
intoa in {b, c}
and to mergea != b and a != c
intoa not in {b, c}
- Fixes incorrect line number for
Z331
- Fixes that
Z311
was not raising for multiplenot in
cases - Fixes a bunch of bugs for rules working with
Assign
and notAnnAssign
- Fixes that
continue
was not triggeringUselessReturningElseViolation
- Renames
logics/
tologic/
since it is grammatically correct - Renames
Redundant
toUseless
- Renames
Comparison
toCompare
- Renames
WrongConditionalViolation
toConstantConditionViolation
- Renames
ComplexDefaultValuesViolation
toComplexDefaultValueViolation
- Refactors
UselessOperatorsVisitor
- Adds
compat/
package, getting ready forpython3.8
- Adds
Makefile
- A lot of minor dependency updates
- Fixes issue with
pydocstyle>=4
by glueing its version topydocstyle<4
This is mostly a supporting release with several new features and lots of bug fixes.
- Forbids to use magic module methods
__getattr__
and__dir__
- Forbids to use multiline conditions
- Forbids local variables that are only used in
return
statements
- Fixes module names for modules like
io.py
- Fixes false positive
Z310
for numbers like0xE
- Fixes false positive for compare ordering with
await
- Fixes problem with missing
_allowed_left_nodes
- Fixes problem false positive for
Z121
when using_
for unused var names - Fixes false positive for negative number in default values
- Fixes error text for
ComplexDefaultValueViolation
- Fixes problem with false positive for
Z459
when a default value is anEllipsis
- Adds
py.typed
file in case someone will import our code, now it will have types - Adds several missing
@final
decorators - Enforces typing support
- Refactors how
typing_extensions
package is used - Adds docs about
black
- Adds big "Star" button
- Multiple dependencies update
- Better
exclude
rule forflake8
check - Removed warnings from
pytest
- Fixes how
wps_context
is calculated, sosuper()
calls are now working
- Updates
flake8
to3.7+
- Adds
flake8-annotations-complexity
as a dependency, forbids complex annotations - Forbids to use redundant
+
,~
,not
, and-
operators before numbers - Forbids to use complex default values
- Forbids to use anything rather than names in
for
loop vars definitions - Forbids to use anything rather than names in
with
block vars definitions - Forbids to use anything rather than names in comprehension vars definitions
- Forbids to use direct magic attributes access
- Forbids to use negated conditions
- Forbids to use too many
# pragma: no cover
comments - Forbids to use nested
try
blocks
- Fixes problems with empty lines after magic comments, see #492
- Fixes error message for
del
keyword: it is now just'del'
not'delete'
- Removes
flake8-per-file-ignores
plugin, sinceflake8
now handles it - Removes
flake8-type-annotations
plugin, sinceflake8
now handles it - Improves docs for
WrongKeywordViolation
- Improves docs for
EmptyLineAfterCodingViolation
- Improves docs for
ProtectedAttributeViolation
- Adds docs about
.pyi
files
- Allows
Generic[SomeType]
to be a valid superclass - Forces to use
flake8
version3.6
instead of3.7
- Improves docs about using
# type: some
comment infor
loops
- Now raising a violation for every
bool
non-keyword argument and showing better error message - Changes how
max-arguments
are counted Nowself
,cls
, andmcs
count as real arguments - Forbids to use
yield
inside comprehensions - Forbids to have single line triple-quoted string assignments
- Forbids to have same items in
set
literals - Forbids to subclass
BaseException
- Forbids to use simplifiable
if
expressions and nodes - Forbids to have incorrect nodes in
class
body - Forbids to have methods without any arguments
- Forbids to have incorrect base classes nodes
- Enforces consistent
__slots__
syntax - Forbids to use names with trailing
_
without a reason - Forbids to use
super()
with arguments or outside of methods - Forbids to have too many
except
cases - Enforces to have an empty line after
coding
comment - Forbids to use too many
# noqa
comments - Forbids to use variables declared as unused
- Forbids to use redundant
else
blocks - Forbids to use inconsistent
return
andyield
statements - Forbids to use multiple
return
path intry
/expect
/finally
- Forbids to use implicit string concatenation
- Forbids to have useless
continue
nodes inside the loops - Forbids to have useless nodes
- Forbids to have useless
raise
statements - Adds
params
andparameters
to black-listed names
- Fixes a lot of rules that were ignoring
Bytes
node as constant type - Fixes location of the
BooleanPositionalArgumentViolation
- Fixes argument count issue with
async
functions - Fixes
WrongConditionalVisitor
not detectingtuple
as constants - Fixes
WrongConditionalVisitor
not detecting negative numbers as constants - Fixes some magic number that were not detected based on their location
- Fixes error when regular functions named as blacklisted magic methods were forbidden, now we check for methods only
- Fixes error when strings like
U'some'
was not triggering unicode violation - Fixes error when string like
U'some'
was not triggering modifier violation
- Adds
safety
and other dependency checks to the CI process - Improves tests: now
tokenize
works differently inside tests - Improves tests: now testing more brackets cases aka "magic coverage bug"
- Improves docs: adds new badge about our code style
- Refactoring: trying to use
astor
where possible to simplify the codebase - Refactoring: introduces some new
transformations
- Refactoring: now we do not have any magical text casts for violations
- Improves tests: changes how
flake8
is executed, now it is twice as fast - Improves docs: now linting
conf.py
withflake8
- Improves tests: now we check that ignored violation are raised with
noqa
- Improves docs: we have added a special graph to show our architecture
- Improves docs: we now have a clean page for
checker
without extra junk - Improves docs: we now have a tutorial for creating new rules
- Refactoring: moves
presets
package to the root - Improves tests: we now lint our layered architecture with
layer-lint
- Fixes an issue-450 with
dict
s with just values and no keys
- Fixes a crash with class attributes assignment
- Fixes a conflict between our plugin and
pyflakes
- Adds
flake8-per-file-ignore
plugin dependency - Adds default values to the
flake8 --help
output - Adds
do
as a restricted variable name - Forbids multiple assignment targets for context managers
- Forbids to use incorrect multi-line parameters
- Forbids to use
bool
values as positional arguments - Forbids to use extra indentation
- Forbids to use inconsistent brackets
- Forbids to use multi-line function type annotations
- Forbids to use uppercase string modifiers
- Forbids to use assign chains: now we only can use one assign per line
- Forbids to use assign with unpacking for any nodes except
Name
- Forbids to have duplicate
except
blocks
- Fixes tests failing on windows (@sobolevn hates windows!), but it still fails sometimes
- Fixes bug when
@staticmethod
was treated as a module member - Fixes bug when some nodes were not checked with
TooDeepNestingViolation
- Fixes bug when it was possible to provide non-unique aliases
- Fixes incorrect line number for incorrect parameter names
- Fixes bug when names like
__some__value__
were not treated as underscored - Fixes bug when assignment to anything rather than name was raising an error
- Refactoring: now we fix
async
nodes offset in a special transformation - Improves docs: specifies what
transformation
is - Improves docs: making contributing section in the
README
more friendly - Improves build: changes how CI installs
poetry
- Fixes all possible errors that happen
because of unset
parent
andfunction_type
properties
- Breaking: removes
--max-conditions
and--max-elifs
options - Breaking: removes
--max-offset-blocks
- Breaking: changes default
TooManyConditionsViolation
threshold from3
to4
- Breaking: changes
TooManyBaseClassesViolation
code from225
to215
- Forbids to use
lambda
inside loops - Forbids to use
self
,cls
, andmcs
except for first arguments only - Forbids to use too many decorators
- Forbids to have unreachable code
- Forbids to have statements that have no effect
- Forbids to have too long names for modules and variables
- Forbids to have names with unicode for modules and variables
- Add
variable
to the blacklisted names - Now
RedundantLoopElseViolation
also checkswhile
loops
- Fixes
TooManyConditionsViolation
to work with any conditions, not justif
s - Fixes
TooManyConditionsViolation
that did not count conditions correctly - Fixes
TooManyForsInComprehensionViolation
to find all comprehension types - Fixes
TooManyElifsViolation
to check module level conditions - Fixes
TooManyBaseClassesViolation
docs location - Fixes
WrongVariableNameViolation
not checkinglambda
argument names - Fixes
OffsetVisitor
incorrectawait
handling
- Refactoring: moves all complexity checks into
complexity/
folder - Refactoring: improves how different keyword visitors are coupled
- Improves docs: we have removed magic comments and code duplication
- Improves docs: now
_pages/
is named justpages/
- Improves docs: now all violations are sorted correctly
- Improves tests: now testing different keywords separately
- Improves tests: now all violations must be contained in
test_noqa.py
- Improves tests: now we also run
compile()
on allast
examples - Improves tests: now we are sure about correct order of violations
Development was focused around better test coverage and providing a better API for tests. We also now covering more cases and testing violation texts.
- Breaking: removes duplicating module name rules, now we use the same rules for both variables and modules
- Breaking: removes
--min-module-name-length
options - Breaking: renames
--min-variable-name-length
into--min-name-length
- Dependencies: updates
flake8
version to3.6
- Dependencies: removes
pycodestyle
pinned version - Restrict unicode names
- Multiple fixes to error text formats to be more readable
- Fixes
UNDERSCORED_NUMBER_PATTERN
to match names likecome_22_me
- Fixes
UpperCaseAttributeViolation
not being displayed in the docs - Fixes consistency checks being duplicated in the docs
- Fixes
UnderscoredNumberNameViolation
showing incorrect line number - Fixes
ProtectedAttributeViolation
to respectsuper()
andmcs
- Fixes
ProtectedAttributeViolation
to show correct text - Fixes
BadNumberSuffixViolation
to show correct text - Fixes
TooManyBaseClassesViolation
to show correct text - Fixes
TooManyElifsViolation
to show correct text - Fixes
TooDeepNestingViolation
to show correct text - Fixes
TooManyMethodsViolation
to show correct text - Fixes
ReassigningVariableToItselfViolation
to show correct text - Renames
UnderscoredNumberNameViolation
toUnderscoredNumberNameViolation
- Refactoring: removed duplicate logic inside
logics/filenames.py
- Improves tests: now testing almost all violations inside
noqa.py
- Improves tests: now testing violations text
- Improves tests: now all common patterns live in related
conftest.py
- Improves docs: now all configuration options are listed in the violations
This release was made possible by awesome people who contributed
to the project during #hactoberfest
. List of awesome people:
- @novikovfred
- @riyasyash
- @sathwikmatsa
- @tipabu
- @roxe322
- @geoc0ld
- @lensvol
- @SheldonNunes
- @tommbee
- @valignatev
- @vsmaxim
- Adds
flake8-print
as a dependency - Adds
typing-extensions
as a dependency - Forbids to use
quit
andexit
functions - Forbids the comparison of two literals
- Forbids the incorrect order comparison, enforcing variable to come first
- Forbids underscores before numbers in names
- Forbids class level attributes whose name is not in
snake_case
- Forbids comparison of the same variables
- Forbids inconsistent octal, binary, and hex numbers
- Forbids too many arguments in
lambda
functions - Forbids extra
object
in parent classes list - Forbids
for
loops with unusedelse
- Forbids variables self reassignment
- Forbids
try
withfinally
withoutexcept
- Forbids
if
statements with invalid conditionals - Forbids opening parenthesis from following keyword without space in between them
- Forbids the use of more than 2
for
loops within a comprehension - Forbids variable names with more than one consecutive underscore
- Restricts the maximum number of base classes aka mixins
- Forbids importing protected names
- Forbids using protected methods and attributes
- Forbids
yield
inside__init__
method
- Fixes that
MultipleIfsInComprehensionViolation
was not enabled - Fixes flaky behaviour of
test_module_names
test package - Fixed
TooManyMethodsViolation
not displaying line number in output - Fixed
OffsetVisitor
due to python bug
- Updates
poetry
version - Refactoring: some general changes, including better names and APIs
- Improves docs: now we have
versionadded
for each violation - Improves docs: now we explicitly state how some violations might be ignored
- Improves tests: now we are testing options
- Improves tests: now we have different
tests/
folder structure - Improves tests: now we are testing presets
- Improves tests: now we are using different logic inside
assert_errors
- Improves tests: now testing magic numbers in more situations
- Improves tests: now testing more situations with empty base classes
- Improves tests: now testing presets, that they have all the existing visitors
- Improves tests: now using stricter
noqa
checks - Improves tests: now testing that any name is allowed when using a variable
- Improves types: now all class attributes are marked as
ClassVar
- Improves types: now we use
final
to indicate what should not be changed - Improves types: now we do not have any ugly import hacks
This release was made possible by awesome people who contributed
to the project during #hactoberfest
. List of awesome people:
- Now we are counting
async
function as a module member - We now forbid to use
credits()
builtin function - We now check
async for
andasync with
nesting level - We now check
async for
andasync with
variable names - We now count
async
methods as method for classes complexity check - We now count
async
functions as functions for module complexity check - We now check
async
functions names and arguments - We now count
async
functions complexity - We now ignore
async
functions in jones complexity check - We now check for nested
async
functions - We now check for
async
functions with@staticmethod
decorator
- Improves docs: add
usage.rst
- Improves docs: adds naming convention to the
naming.py
- Improves docs: multiple typos, bugs, and issues fixes
- Improves tests: now we are testing
async
comprehensions
- Breaking: changes violation codes, now they are grouped by meaning
- Refactoring: changes how visitors are organized inside the package
- Improves docs: now we have a glossary
- Refactoring: refactoring terms that violate our glossary
- Improves docs: now all error files contain fancy documentation and summary
- Improves docs: now we have added API reference to the docs
- Improves docs: adds new plugin development guide
- Adds
flake8-logging-format
dependency - Adds
flake8-type-annotations
dependency - Adds
flake8-breaking-line
dependency - Removes
flake8-super-call
dependency - Adds
PartialFloatViolation
- Adds
MagicNumberViolation
- Adds
WrongDocCommentViolation
- Adds
MAGIC_NUMBERS_WHITELIST
constant - Changes what variable names are blacklisted, adds
false
,true
, andno
- Improves docs: now including docs for
--max-condition
option - Improves docs: adds some new
Zen of Python
references - Improves tests: adds many new examples
- Improves docs: now each error has its error message displayed in the docs
- Improves docs: readme is now ready for the release
- Improves docs: now error pages are split
- Improves docs: now all
flake8
plugin dependencies are documented
- Adds
MultipleIfsInComprehensionViolation
- Adds
TooManyConditionsViolation
- Adds
--max-conditions
option
- Improves
CONTRIBUTING.md
- Moves issues templates to
.github/
folder - Update error thrown on
RedundantSubscriptViolation
- Adds
WrongModuleNamePatternViolation
andWrongModuleNameUnderscoresViolation
- Adds
TooManyImportsViolation
error and--max-imports
option - Adds
--i-control-code
option to ignoreInitModuleHasLogicViolation
- Adds check for underscored numbers
- Forbids
u''
strings - Adds
noqa
andtype
comments checks
- Changes how many errors are generated for limits violations
- Refactors how visitors are injected into the checker, now using presets
- Creates new visitor type:
BaseTokenVisitor
for working withtokenize
- Improves typing support
- Adds
flake8-bandit
plugin - Adds
flake8-eradicate
plugin - Adds
flake8-print
plugin for development - Removes
delegate
concept from the codebase
- Adds
jones
complexity checker - Adds
--max-line-complexity
and--max-jones-score
options
- Improves docs: adds detailed installation instructions
- Removes
flake8-blind-except
plugin
This is just a supporting release. There are no new features introduced.
We have changed the error codes for general checks.
- Fixes bug with nested imports missing
parent
- Fixes bug with incorrect
pycodestyle
version - Removes
BareRaiseViolation
as it does not fit the purpose of this package
- Improves docs: now all errors are sorted by
code
- Improves docs: now all errors have reasoning
- Improves docs: some references are now clickable in web version
- Improves docs: now docs include
CHANGELOG.md
- Improves docs: now we have templates for
bug
andrule-request
- Replaced
pytest-isort
withflake8-isort
This is just a supporting release. There are no new features introduced.
- Introduced the concept of regression testing, see
test/fixtures/regression
- Removed
compat.py
- Fixes some minor typos, problems, markup inside the docs
- Adds some new configuration to
sphinx
- Changes
sphinx
docs structure a little bit
- Adds
WrongModuleNameViolation
,WrongModuleMagicNameViolation
, andTooShortModuleNameViolation
- Adds
--min-module-name-length
config option - Adds a blacklist of module names
- Adds
InitModuleHasLogicsViolation
- Adds
EmptyModuleViolation
- Adds a whitelist of magic module names
- Fixes
Option
class to have have incorrecttype
field, now using strings - Fixes that
WrongStringTokenVisitor
was not activated
- Improved typing support
- Now each error has a link to the corresponding constant (if any)
- Improved docs with links to the corresponding configuration flags
This is just a supporting release. There are no new features introduced.
- Fixes
Attribute has no 'id'
error - Fixes
missing 'typing_extension'
error
- Errors are now tested
- Complexity tests are refactored
- Now all dependencies are direct, they will be installed together with this package
- Adds direct dependencies, now there's no need to install any extra packages
- Adds
TooDeepNestingViolation
andTooManyElifsViolation
checks - Adds
--max-offset-blocks
and--max-elifs
options - Adds
TooManyModuleMembersViolation
andTooManyMethodsViolation
checks - Adds
--max-module-members
and--max-methods
options - Restricts to use
f
strings
- Removes incorrect
generic_visit()
calls - Removes some unused
getattr()
calls - Refactors how options are registered
- Improved type support for options parsing
- Added new magic methods to the black list
- We now do not count
_
as a variable inTooManyLocals
check - We now restrict to nest
lambda
s - We now allow to configure the minimal variable's name length via
setup.cfg
- Refactored how complexity checks are defined
- Refactored how errors are defined
- Now each check has strict
Raises:
policy which lists all possible errors that this check can find and raise - Changed how visitors are initialized in tests
- Tests now cover nested classes' explicit bases
- Tests now cover nested classes and functions
noqa
comment
- We now check import aliases to be different from the original name
- Default complexity checks' values have changed
- ReadTheDocs build is fixed by providing extra dependencies
- Changed how local variables are counted
- Improved typing support
- Added new documentation sections
- We now allow
generator_stop
to be a__future__
import - We now restrict dotted raw imports like:
import os.path
- We now check import aliases as regular variable names
- We have added a
CONTRIBUTING.md
file to help new contributors
- We now check
class
es to match our styleguide - Classes have their own error group
Z3
- Using
@staticmethod
is now forbidden - Declaring
object
as a base class is now required - Now we check that
__del__
magic method is not used - Variable names
async
andawait
are forbidden - We now forbid to use
__future__
imports - We now have a whitelist for
__future__
imports - Imports are now have its own subgroup
Z10
- General rules now start from
Z11
- We now use
Z
as the default code for our errors - We have shuffled errors around, changing code and formats
- Now all name errors share the same class
- Adds
PrivateNameViolation
- Now imports inside any structures rather than
Module
raises an error - Adds
file
andklass
as restricted names - Now
__import__
is just a bad function name, not a special case - Now version is defined in
poetry.toml
only - We now have configuration! And it covers all design errors
- Fixes issue with missing
parent
s :batman: - Fixes issue with
_$NAME
patterns being ignored
- Adds some new blacklisted variables' names
- Adds docs for each existing error code
- Adds whitelisted names for nested functions:
decorator
andfactory
- Adds new blacklisted module's metadata variables
- Removed
BAD_IMPORT_FUNCTIONS
variable, now just checking__import__
- Add gen-tests that cover most of the issues
- Removed almost all integration tests, saving just a few of them
- Adds
poetry
as the main project tool - Adds
shpinx
as a documentation tool
- Initial release