Releases: wemake-services/wemake-python-styleguide
Version 0.15.1
Bugfixes
- Fixes
dataclasses
import, it was failing onpython3.6
- Fixes
InconsistentComprehensionViolation
work withasync
comprehensions - Fixes nested compehensions 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
Misc
- Refactors how
tokenize
tests are executed,
now we have an option to compile fixture code
to make sure it is syntatically valid
Version 0.15.0 aka python3.9
Features
- 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 forself
/cls
/mcs
,
but not any other ones.
So, now writtingpoint.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 - WPS531: 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 miltiline 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
Bugfixes
- 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
Misc
- Updates lots of dependenices
- 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
Version 0.14.1 aka The broken release process
Bugfixes
- Fixes
isort@5
compatibility
Version 0.14.0 aka The Walrus fighter
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 migration guide.
One more thing: flake8
still fails on :=
operator.
And there's nothing we can do about it.
Please, be patient – this linter does not allow to have :=
in the source code anyway!
Features
- 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-loggin-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
Bugfixes
- 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 reporingsuper()
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
Misc
- 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
Version 0.13.4
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.
Bugfixes
- 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
Misc
- 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
Version 0.13.3
Misc
- Updates
radon
version - Updates
poetry
version to1.0
Version 0.13.2
Bugfixes
- Fixes that Github Action was failing for wrong status code
- Fixes
NegatedConditionsViolation
false positive on absent
else
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
Misc
pylint
docs fixed- Fixes docs about implicit
yield
violation
Version 0.13.1
Bufixes
- 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
Misc
- Now our GitHub Action can be used to leave PR review comments
0.13.0 aka The Lintoberfest
This is a huge release that was created during the Hactoberfest season.
It would have been 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.
Features
- 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)
Bugfixes
- 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
Misc
- 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 withWSP318
in docstring - Improves tests: we now ensure that each violation with previous codes also
has corresponding versions changed in their documentation
Version 0.12.5
Bugfixes
- We now ignore
@overload
fromBlockAndLocalOverlapViolation
- Now expressions that reuse block variables are not treated as violations,
example:my_var = do_some(my_var)
Misc
- 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