-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Release branch 3.0.0 #9093
Release branch 3.0.0 #9093
Conversation
Blocked by #9092 |
Maybe not blocked, the github CI are not ready yet. |
Codecov Report
Additional details and impacted files@@ Coverage Diff @@
## main #9093 +/- ##
=======================================
Coverage 95.75% 95.75%
=======================================
Files 173 173
Lines 18663 18663
=======================================
Hits 17871 17871
Misses 792 792
|
b716c38
to
c61edea
Compare
This long anticipated major version also provides some important usability | ||
and performance improvements, along with enacting necessary breaking changes | ||
and long-announced deprecations. The documentation of each message with an | ||
example is very close too. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
pyreverse also got a lot of love but hard to pinpoint a particular issues that was super important compared to the others.
It'll probably take a day or two until |
🤖 According to the primer, this change has no effect on the checked open source code. 🤖🎉 This comment was generated for commit c61edea |
What's new in Pylint 3.0.0?
Release date: 2023-10-02
Breaking Changes
Enabling or disabling individual messages will now take effect even if an
--enable=all
ordisable=all
follows in the same configuration file(or on the command line).
This means for the following example,
fixme
messages will now be emitted:To regain the prior behavior, remove the superfluous earlier option.
Closes enable/disable options in rcfile should not depend on the order with which they are specified #3696
Remove support for launching pylint with Python 3.7.
Code that supports Python 3.7 can still be linted with the
--py-version=3.7
setting.Refs Cleanup after we drop support for Python 3.7 #6306
Disables placed in a
try
block now apply to theexcept
block.Previously, they only happened to do so in the presence of an
else
clause.Refs Use
Try
node #7767pyreverse
now uses a new default color palette that is more colorblind friendly.The color scheme is taken from
Paul Tol's Notes <https://personal.sron.nl/~pault/>
_.If you prefer other colors, you can use the
--color-palette
option to specify custom colors.Closes Use better default colors for
pyreverse
#8251Everything related to the
__implements__
construct was removed. It was based on PEP245that was proposed in 2001 and rejected in 2006.
The capability from pyreverse to take
__implements__
into account when generating diagramswas also removed.
Refs [__implements__] Remove everything related to the rejected PEP245 #8404
pyreverse
: Support for the.vcg
output format (Visualization of Compiler Graphs) has been dropped.Closes Deprecate / remove support for
.vcg
files inpyreverse
#8416The warning when the now useless old pylint cache directory (pylint.d) was
found was removed. The cache dir is documented in
the FAQ <https://pylint.readthedocs.io/en/latest/faq.html#where-is-the-persistent-data-stored-to-compare-between-successive-runs>
_.Refs [deprecation] Remove the warning about the old pylint home #8462
Following a deprecation period,
pylint.config.PYLINTRC
was removed.Use the
pylint.config.find_default_config_files
generator instead.Closes Preferred way to find pylintrc in pylint 3 #8862
Changes requiring user actions
The
invalid-name
message no longer checks for a minimum length of 3 characters by default.(This was an unadvertised commingling of concerns between casing
and name length, and users regularly reported this to be surprising.)
If checking for a minimum length is still desired, it can be regained in two ways:
If you are content with a
disallowed-name
message (instead ofinvalid-name
), then simply add the optionbad-names-rgxs="^..?$"
,which will fail 1-2 character-long names. (Ensure you enable
disallowed-name
.)If you would prefer an
invalid-name
message to be emitted, or wouldprefer finer-grained control over the circumstances in which messages are
emitted (classes vs. methods, etc.), then avail yourself of the regex
options described
here <https://pylint.readthedocs.io/en/stable/user_guide/configuration/all-options.html#main-checker>
.(In particular, take note of the commented out options in the "example
configuration" given at the bottom of the section.) The prior regexes can
be found in the
pull request <https://github.com/pylint-dev/pylint/pull/8813>
that removed the length requirements.
Closes Show why snake_case errors is emitted on single word variables (might be too small) #2018
The compare to empty string checker (
pylint.extensions.emptystring
) and the compare tozero checker (
pylint.extensions.compare-to-zero
) have been removed and their checks arenow part of the implicit booleaness checker:
compare-to-zero
was renameduse-implicit-booleaness-not-comparison-to-zero
andcompare-to-empty-string
was renameduse-implicit-booleaness-not-comparison-to-string
and they now need to be enabled explicitly.
The
pylint.extensions.emptystring
andpylint.extensions.compare-to-zero
extensionsno longer exist and need to be removed from the
load-plugins
option.Messages related to implicit booleaness were made more explicit and actionable.
This permits to make their likeness explicit and will provide better performance as they
share most of their conditions to be raised.
Closes Uniformize
compare-to-zero
,compare-to-empty-string
with theuse-implicit-booleaness-x
checks #6871epylint was removed. It now lives at: https://github.com/emacsorphanage/pylint.
Refs Please consider maintaining the Emacs-Lisp files in a separate repository #7737
The
overgeneral-exceptions
option now only takes fully qualified namesinto account (
builtins.Exception
notException
). If you overrodethis option, you need to use the fully qualified name now.
There's still a warning, but it will be removed in 3.1.0.
Refs [overgeneral-exceptions] Only handle qualified names #8411
Following a deprecation period, it's no longer possible to use
MASTER
or
master
as configuration section insetup.cfg
ortox.ini
. It's bad practiceto not start a section title with the tool name. Please use
pylint.main
instead.Refs [deprecation]
setup.cfg
andtox.ini
sections need to start by 'pylint' #8465Package stats are now printed when running Pyreverse and a
--verbose
flag was added to get the original output with parsed modules. You might need to activate the verbose option if you want to keep the old output.Closes More useful printing for Pyreverse #8973
New Features
A new
json2
reporter has been added. It features a more enriched output that iseasier to parse and provides more info.
Compared to
json
the only changes are that messages are now under the"messages"
key and that
"message-id"
now follows the camelCase convention and is renamed to"messageId"
.The new reporter also reports the "score" of the modules you linted as defined by the
evaluation
option and provides statistics about the modules you linted.We encourage users to use the new reporter as the
json
reporter will no longerbe maintained.
Closes Improve JSON output format with score #4741
In Pyreverse package dependency diagrams, show when a module imports another only for type-checking.
Closes Idea: Pyreverse should distinguish between functional imports and type checking imports #8112
Add new option (
--show-stdlib
,-L
) topyreverse
.This is similar to the behavior of
--show-builtin
in that standard librarymodules are now not included by default, and this option will include them.
Closes pyreverse: Add option to exclude standard library #8181
Add Pyreverse option to exclude standalone nodes from diagrams with
--no-standalone
.Closes Pyreverse: Add option to ignore classes without relationships #8476
New Checks
Added
DataclassChecker
module andinvalid-field-call
checker to check for invalid dataclasses.field() usage.Refs Add dataclass tests #5159
Add
return-in-finally
to emit a message if a return statement was found in a finally clause.Closes Prevent usage of
return
,yield
intry/finally
#8260Add a new checker
kwarg-superseded-by-positional-arg
to warn when a function is called with a keyword argument which shares a name with a positional-only parameter and the function contains a keyword variadic parameter dictionary. It may be surprising behaviour when the keyword argument is added to the keyword variadic parameter dictionary.Closes Lower severity message than
redundant-keyword-arg
for calling distinct positional-only arg and variadic keyword arg with same name #8558Extensions
Add new
prefer-typing-namedtuple
message to theCodeStyleChecker
to suggestrewriting calls to
collections.namedtuple
as classes inheriting fromtyping.NamedTuple
on Python 3.6+.
Requires
load-plugins=pylint.extensions.code_style
andenable=prefer-typing-namedtuple
to be raised.Closes Discourage collections.namedtuple in favor of typing.NamedTuple #8660
False Positives Fixed
Extend concept of "function ambiguity" in
safe_infer()
fromdiffering number of function arguments to differing set of argument names.
Solves false positives in
tensorflow
.Closes Pylint gets TensorFlow's tf.split all wrong #3613
Fix
unused-argument
false positive when__new__
does not use all the arguments of__init__
.Closes unused-argument for required argument in __new__ #3670
Fix a false positive for
invalid-name
when a type-annotated class variable in anenum.Enum
class has no assigned value.Refs false positive for type-hinted Enum class instance variable #7402
Fix
unused-import
false positive for usage ofsix.with_metaclass
.Closes False positive of unused-import since v2.15.0 #7506
Fix false negatives and false positives for
too-many-try-statements
,too-complex
, andtoo-many-branches
by correctly counting statementsunder a
try
.Refs Use
Try
node #7767When checking for unbalanced dict unpacking in for-loops, Pylint will now test whether the length of each value to be
unpacked matches the number of unpacking targets. Previously, Pylint would test the number of values for the loop
iteration, which would produce a false unbalanced-dict-unpacking warning.
Closes False reports on W0644 unbalanced-dict-unpacking in pylint 2.16.0 #8156
Fix false positive for
used-before-assignment
when usage and assignmentare guarded by the same test in different statements.
Closes False positive
used-before-assignment
when usage and assignment guarded by the same test in different statements #8167Adds
asyncSetUp
to the defaultdefining-attr-methods
list to silenceattribute-defined-outside-init
warning when usingunittest.IsolatedAsyncioTestCase
.Refs Add Python 3.8+
asyncSetUp
to "defining-attr-methods" list #8403logging-not-lazy
is not longer emitted for explicitly concatenated string arguments.Closes Pylint should not emit
logging-not-lazy
when using explicit string concatenation for the message #8410Fix false positive for isinstance-second-argument-not-valid-type when union types contains None.
Closes
isinstance-second-argument-not-valid-type
false positive for union types withNone
#8424invalid-name
now allows for integers intypealias
names:Good2Name
,GoodName2
._1BadName
.Closes invalid-name check for TypeAlias should allow for digits in names #8485
No longer consider
Union
as type annotation as type alias for naming checks.Closes
invalid-name
type alias false-positive for union values #8487unnecessary-lambda
no longer warns on lambdas which use its parameters intheir body (other than the final arguments), e.g.
lambda foo: (bar if foo else baz)(foo)
.Closes
unnecessary-lambda
false positive if parameter is used in lambda body #8496Fixed
unused-import
so that it observes thedummy-variables-rgx
option.Closes
unused-import
should observedummy-variables-rgx
setting #8500Union
typed variables without assignment are no longer treated asTypeAlias
.Closes
invalid-name
type alias false-positive for union variables without assignment values #8540Allow parenthesized implicitly concatenated strings when
check-str-concat-over-line-jumps
is enabled.Closes
implicit-str-concat
: allow wrapping implicitly concatenated strings in parenthesis. #8552.Fix false positive for
positional-only-arguments-expected
when a function contains both a positional-only parameter that has a default value, and**kwargs
.Closes False positive for
positional-only-arguments-expected
#8555Fix false positive for
keyword-arg-before-vararg
when a positional-only parameter with a default value precedes*args
.Closes False positive for
keyword-arg-before-vararg
withpositional-only
parameter #8570Fix false positive for
arguments-differ
when overriding__init_subclass__
.Closes False positive: arguments-differ for __init_subclass__ in generic #8919
Fix a false positive for
no-value-for-parameter
when a staticmethod is called in a class body.Closes False positive E1120:no-value-for-parameter #9036
False Negatives Fixed
Emit
used-before-assignment
when calling module-level functions before definition.Closes Fail to find NameError for undefined functions #1144
Apply
infer_kwarg_from_call()
to more checksThese mostly solve false negatives for various checks,
save for one false positive for
use-maxsplit-arg
.Closes
get_argument_from_call
doesn't account for **kwargs #7761TypeAlias
variables defined in functions are now checked forinvalid-name
errors.Closes TypeAlias defined inside functions doesn't respect the typealias naming style. #8536
Fix false negative for
no-value-for-parameter
when a function, whose signature contains both a positional-only parametername
and also*kwargs
, is called with a keyword-argument forname
.Closes False negative
no-value-for-parameter
when positional-only argument name consumed by **kwargs #8559Fix a false negative for
too-many-arguments
by considering positional-only and keyword-only parameters.Closes R0913 excludes keyword- and positional-only arguments #8667
Emit
assignment-from-no-return
for calls to builtin methods likedict.update()
.Calls to
list.sort()
now raiseassignment-from-no-return
rather than
assignment-from-none
for consistency.Closes False negative
assigned-from-none
forvalue = dict.update({}, {})
#8714Closes Emit
assignment-from-no-return
instead ofassignment-from-none
for implicitly returning stdlib calls #8810consider-using-augmented-assign
is now applied to dicts and lists as well.Closes False negative for consider-using-augmented-assign for nested dicts #8959
Other Bug Fixes
Support
duplicate-code
message when parallelizing with--jobs
.Closes Different output with --jobs=1 and --jobs=2 #374
Support
cyclic-import
message when parallelizing with--jobs
.Closes No cyclic-import messages with jobs=0 #4171
--jobs
can now be used with--load-plugins
.This had regressed in astroid 2.5.0.
Closes Transform plugin not called when running with multiple jobs #4874
docparams extension considers type comments as type documentation.
Closes docparams should support missing type documentation when type comments are used #6287
When parsing comma-separated lists of regular expressions in the config, ignore
commas that are inside braces since those indicate quantifiers, not delineation
between expressions.
Closes bad-names-rgxs mangles regular expressions with commas #7229
The
ignored-modules
option will now be correctly taken into account forno-name-in-module
.Closes no-name-in-module does not respect patterns in ignored-modules #7578
sys.argv
is now always correctly considered as impossible to infer (instead ofusing the actual values given to pylint).
Closes
sys.argv
is inferred wrongly as pylint's own values forsys.argv
instead ofUninferrable
#7710Avoid duplicative warnings for unqualified exception names in the
overgeneral-exceptions
setting when running with
--jobs
.Closes With
--jobs 2
, theopen()
call is executed for each opened file #7774Don't show class fields more than once in Pyreverse diagrams.
Closes
pyreverse
should ignore class level attribute declarations #8189Fix
used-before-assignment
false negative when TYPE_CHECKING importsare used in multiple scopes.
Closes
used-before-assignment
false negative withTYPE_CHECKING
#8198--clear-cache-post-run
now also clears LRU caches for pylint utilitiesholding references to AST nodes.
Closes Clear pylint's LRU caches when using
--clear-cache-post-run
#8361Fix a crash when
TYPE_CHECKING
is used without importing it.Closes
in_type_checking_block
can crash if you haven't importedTYPE_CHECKING
#8434Fix a
used-before-assignment
false positive when importsare made under the
TYPE_CHECKING
else if branch.Closes
used-before-assignment
false positive for import nodes underelif
afterTYPE_CHECKING
#8437Fix a regression of
preferred-modules
where a partial match was used instead of the required full match.Closes v2.17.0 regression related to W0407: preferred-modules #8453
Fix a crash in pyreverse when "/" characters are used in the output filename e.g pyreverse -o png -p name/ path/to/project.
Closes [pyreverse] Setting the project name with a "/" at the end crashes pyreverse #8504
Don't show arrows more than once in Pyreverse diagrams.
Closes Pyreverse duplicate arrows #8522
Improve output of
consider-using-generator
message formin()
calls withdefault
keyword.Closes consider-using-generator error message ignores default arguments #8563
Fixed a crash when generating a configuration file:
tomlkit.exceptions.TOMLKitError: Can't add a table to a dotted key
caused by tomlkit
v0.11.8
.Closes TOMLKitError when generating TOML config with tomlkit 0.11.8 #8632
Fix a line break error in Pyreverse dot output.
Closes type hints in methods using PEP 604 result in horizontal line #8671
Fix a false positive for
method-hidden
when usingcached_property
decorator.Closes False Positive: method-hidden with @functools.cached_property #8753
Dunder methods defined in lambda do not trigger
unnecessary-dunder-call
anymore, if they cannot be replaced by the non-dunder call.Closes C2801 False positive when
__setitem__
appears in a lambda #8769Don't show duplicate type annotations in Pyreverse diagrams.
Closes Incorrect type reported by pyreverse for unions and generics #8888
Fixing inconsistent hashing issue in
BaseChecker
causing some reports not being exported.Closes Dependency graphs are not exported to files #9001
Don't add
Optional
to|
annotations withNone
in Pyreverse diagrams.Closes Redundant Optional in Pyreverse #9014
Pyreverse doesn't show multiple class association arrows anymore, but only the strongest one.
Refs Pyreverse: composition / aggregation arrow strange behavior (and field annotation bug) #9045
Prevented data loss in the linter stats for messages relating
to the linter itself (e.g.
unknown-option-value
), fixingproblems with score, fail-on, etc.
Closes Score, fail-on, fail-under, etc ignores messages emitted by PyLinter itself #9059
Fix crash in refactoring checker when unary operand used with variable in for loop.
Closes Refactoring checker crashes when unary operator used with variable #9074
Other Changes
Pylint now exposes its type annotations.
Closes Expose types #5488 and Annotate pylint code with type annotations #2079
Search for
pyproject.toml
recursively in parent directories up to a project or file system root.Refs Search for pyproject.toml config file in parent dirs #7163, Closes Looking for configuration files like
pylintrc
orpyproject.toml
in parent directories likeblack
orisort
#3289All code related to the optparse config parsing has been removed.
Refs Remove all old code related to
optparse
config parsing. #8405Pylint now supports python 3.12.
Refs [ci] Add jobs for python 3.12-beta following its release #8718
Add a CITATION.cff file to the root of the repository containing the necessary metadata to cite Pylint.
Closes Add CITATION.cff #8760
Renamed the "unneeded-not" error into "unnecessary_negation" to be clearer.
Closes Refactor
unneeded-not
checker #8789Internal Changes
get_message_definition
was removed from the base checker API. You can accessmessage definitions through the
MessageStore
.Refs [deprecation] Remove
get_message_definitions
fromBaseChecker
#8401Everything related to the
__implements__
construct was removed. It was based on PEP245that was proposed in 2001 and rejected in 2006.
All the classes inheriting
Interface
inpylint.interfaces
were removed.Checker
should only inheritBaseChecker
or any of the other checker typesfrom
pylint.checkers
.Reporter
should only inheritBaseReporter
.Refs [__implements__] Remove everything related to the rejected PEP245 #8404
modname
andmsg_store
are now required to be given inFileState
.collect_block_lines
has also been removed.Pylinter.current_name
cannot be null anymore.
Refs [FileState] Deprecation enactment for 3.0.0 #8407
Reporter.set_output
was removed in favor ofreporter.out = stream
.Refs [Reporter] Remove 'set_output' in favor of reporter.out #8408
A number of old utility functions and classes have been removed:
MapReduceMixin
: To make a checker reduce map data simply implementget_map_data
andreduce_map_data
.is_inside_lambda
: Useutils.get_node_first_ancestor_of_type(x, nodes.Lambda)
check_messages
: Useutils.only_required_for_messages
is_class_subscriptable_pep585_with_postponed_evaluation_enabled
: Useis_postponed_evaluation_enabled(node)
andis_node_in_type_annotation_context(node)
get_python_path
: assumption that there's always an init.py is not true sincepython 3.3 and is causing problems, particularly with PEP 420. Use
discover_package_path
and pass source root(s).
fix_import_path
: Useaugmented_sys_path
and pass additionalsys.path
entries as an argument obtained from
discover_package_path
.get_global_option
: Usechecker.linter.config
to get all global options.Related private objects have been removed as well.
Refs Remove deprecated functions and classes #8409
colorize_ansi
now only accepts aMessageStyle
object.Refs [colorize_ansi] Remove the possibility to use anything else than a MessageStyle #8412
Following a deprecation period,
Pylinter.check
now only works with sequences of strings, not strings.Refs [deprecation] 'Pylinter.check' now takes sequence of str only #8463
Following a deprecation period,
ColorizedTextReporter
only acceptsColorMappingDict
.Refs [deprecation] 'ColorizedTextReporter' only accepts 'ColorMappingDict' #8464
Following a deprecation period,
MessageTest
'send_line
andend_col_offset
must be accurate in functional tests (for python 3.8 or above on cpython, and for
python 3.9 or superior on pypy).
Refs [deprecation] end_line and end_col_offset required in functional tests #8466
Following a deprecation period, the
do_exit
argument of theRun
class (and of the_Run
class in testutils) were removed.
Refs [deprecation] Remove 'do_exit' from the 'Run' constructor #8472
Following a deprecation period, the
py_version
argument of theMessageDefinition.may_be_emitted
function is now required. The most likely solutionis to use 'linter.config.py_version' if you need to keep using this
function, or to use 'MessageDefinition.is_message_enabled' instead.
Refs [deprecation] Make 'py_version' required for 'MessageDefinition.may_be_emitted' #8473
Following a deprecation period, the
OutputLine
class now requiresthe right number of argument all the time. The functional output can be
regenerated automatically to achieve that easily.
Refs [deprecation] Make 'OutputLine' require a fixed number of args #8474
Following a deprecation period,
is_typing_guard
,is_node_in_typing_guarded_import_block
andis_node_in_guarded_import_block
frompylint.utils
were removed: use a combination ofis_sys_guard
andin_type_checking_block
instead.Refs [deprecation] Remove all duplicated typing guard check functions #8475
Following a deprecation period, the
location
argument of theMessage
class must now be aMessageLocationTuple
.Refs [deprecation] Message.location must be a 'MessageLocationTuple' #8477
Following a deprecation period, the
check_single_file
function of thePylinter
is replaced byPylinter.check_single_file_item
.Refs [deprecation] 'check_single_file' replaced by 'check_single_file_item' #8478
Performance Improvements
pylint
runs (at least) ~5% faster after improvements toastroid
that make better use of the inference cache.
Refs Improving inference caching (unnecessary context clones?) astroid#529
is_trailing_comma()
.class_is_abstract()
.Refs Performance Benchmarks / Integration tests #1954
Exit immediately if all messages are disabled.
Closes Short circuit if all checks disabled #8715
Closes #7607