-
-
Notifications
You must be signed in to change notification settings - Fork 278
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
_NonDeducibleTypeHierarchy exception on valid code #644
Closed
condemil opened this issue
Feb 15, 2019
· 2 comments
· Fixed by pythoninja/adarklib#30, plus3it/watchmaker#809, IOEPAS/zippy#40, vpoulailleau/simplelogging#32 or cfarvidson/understreck#37
Closed
_NonDeducibleTypeHierarchy exception on valid code #644
condemil opened this issue
Feb 15, 2019
· 2 comments
· Fixed by pythoninja/adarklib#30, plus3it/watchmaker#809, IOEPAS/zippy#40, vpoulailleau/simplelogging#32 or cfarvidson/understreck#37
Comments
@asvetlov FYI |
Thanks for reporting the issue! |
This was referenced Feb 27, 2019
This was referenced Jun 10, 2019
This was referenced Jun 25, 2019
This was referenced Jul 12, 2019
This was referenced Jul 26, 2019
This was referenced Aug 8, 2019
This was referenced Aug 27, 2019
wip-sync
pushed a commit
to NetBSD/pkgsrc-wip
that referenced
this issue
May 19, 2020
What's New in Pylint 2.5.2? =========================== Release date: 2020-05-05 * ``pylint.Run`` accepts ``do_exit`` as a deprecated parameter Close #3590 What's New in Pylint 2.5.1? =========================== Release date: 2020-05-05 * Fix a crash in `method-hidden` lookup for unknown base classes Close #3527 * Revert pylint.Run's `exit` parameter to ``do_exit`` This has been inadvertently changed several releases ago to ``do_exit``. Close #3533 * ``no-value-for-parameter`` variadic detection has improved for assign statements Close #3563 * Allow package files to be properly discovered with multiple jobs Close #3524 * Allow linting directories without `__init__.py` which was a regression in 2.5. Close #3528 What's New in Pylint 2.5.0? =========================== Release date: 2020-04-27 * Fix a false negative for ``undefined-variable`` when using class attribute in comprehension. Close #3494 * Fix a false positive for ``undefined-variable`` when using class attribute in decorator or as type hint. Close #511 Close #1976 * Remove HTML quoting of messages in JSON output. Close #2769 * Adjust the `invalid-name` rule to work with non-ASCII identifiers and add the `non-ascii-name` rule. Close #2725 * Positional-only arguments are taken in account for ``useless-super-delegation`` * ``unidiomatic-typecheck`` is no longer emitted for ``in`` and ``not in`` operators Close #3337 * Positional-only argument annotations are taken in account for ``unused-import`` Close #3462 * Add a command to list available extensions. * Allow used variables to be properly consumed when different checks are enabled / disabled Close #3445 * Fix dangerous-default-value rule to account for keyword argument defaults Close #3373 * Fix a false positive of ``self-assigning-variable`` on tuple unpacking. Close #3433 * ``no-self-use`` is no longer emitted for typing stubs. Close #3439 * Fix a false positive for ``undefined-variable`` when ``__class__`` is used Close #3090 * Emit ``invalid-name`` for variables defined in loops at module level. Close #2695 * Add a check for cases where the second argument to `isinstance` is not a type. Close #3308 * Add 'notes-rgx' option, to be used for fixme check. Close #2874 * ``function-redefined`` exempts function redefined on a condition. Close #2410 * ``typing.overload`` functions are exempted from docstring checks Close #3350 * Emit ``invalid-overridden-method`` for improper async def overrides. Close #3355 * Do not allow ``python -m pylint ...`` to import user code ``python -m pylint ...`` adds the current working directory as the first element of ``sys.path``. This opens up a potential security hole where ``pylint`` will import user level code as long as that code resides in modules having the same name as stdlib or pylint's own modules. Close #3386 * Add `dummy-variables-rgx` option for `_redeclared-assigned-name` check. Close #3341 * Fixed graph creation for relative paths * Add a check for asserts on string literals. Close #3284 * `not in` is considered iterating context for some of the Python 3 porting checkers. * A new check `inconsistent-quotes` was added. * Add a check for non string assignment to __name__ attribute. Close #583 * `__pow__`, `__imatmul__`, `__trunc__`, `__floor__`, and `__ceil__` are recognized as special method names. Close #3281 * Added errors for protocol functions when invalid return types are detected. E0304 (invalid-bool-returned): __bool__ did not return a bool E0305 (invalid-index-returned): __index__ did not return an integer E0306 (invalid-repr-returned): __repr__ did not return a string E0307 (invalid-str-returned): __str__ did not return a string E0308 (invalid-bytes-returned): __bytes__ did not return a string E0309 (invalid-hash-returned): __hash__ did not return an integer E0310 (invalid-length-hint-returned): __length_hint__ did not return a non-negative integer E0311 (invalid-format-returned): __format__ did not return a string E0312 (invalid-getnewargs-returned): __getnewargs__ did not return a tuple E0313 (invalid-getnewargs-ex-returned): __getnewargs_ex__ did not return a tuple of the form (tuple, dict) Close #560 * ``missing-*-docstring`` can look for ``__doc__`` assignments. Close #3301 * ``undefined-variable`` can now find undefined loop iterables Close #498 * ``safe_infer`` can infer a value as long as all the paths share the same type. Close #2503 * Add a --fail-under <score> flag, also configurable in a .pylintrc file. If the final score is more than the specified score, it's considered a success and pylint exits with exitcode 0. Otherwise, it's considered a failure and pylint exits with its current exitcode based on the messages issued. Close #2242 * Don't emit ``line-too-long`` for multilines when `disable=line-too-long` comment stands at their end Close #2957 * Fixed an ``AttributeError`` caused by improper handling of ``dataclasses`` inference in ``pyreverse`` Close #3256 * Do not exempt bare except from ``undefined-variable`` and similar checks If a node was wrapped in a ``TryExcept``, ``pylint`` was taking a hint from the except handler when deciding to emit or not a message. We were treating bare except as a fully fledged ignore but only the corresponding exceptions should be handled that way (e.g. ``NameError`` or ``ImportError``) Close #3235 * No longer emit ``assignment-from-no-return`` when a function only raises an exception Close #3218 * Allow import aliases to exempt ``import-error`` when used in type annotations. Close #3178 * ``Ellipsis` is exempted from ``multiple-statements`` for function overloads. Close #3224 * No longer emit ``invalid-name`` for non-constants found at module level. Pylint was taking the following statement from PEP-8 too far, considering all module level variables as constants, which is not what the statement is saying: `Constants are usually defined on a module level and written in all capital letters with underscores separating words.` Close #3111 Close #3132 * Allow ``implicit-str-concat-in-sequence`` to be emitted for string juxtaposition Close #3030 * ``implicit-str-concat-in-sequence`` was renamed ``implicit-str-concat`` * The ``json`` reporter no longer bypasses ``redirect_stdout``. Close #3227 * Move ``NoFileError``, ``OutputLine``, ``FunctionalTestReporter``, ``FunctionalTestFile``, ``LintModuleTest`` and related methods from ``test_functional.py`` to ``pylint.testutils`` to help testing for 3rd party pylint plugins. * Can read config from a setup.cfg or pyproject.toml file. Close #617 * Fix exception-escape false positive with generators Close #3128 * ``inspect.getargvalues`` is no longer marked as deprecated. * A new check ``f-string-without-interpolation`` was added Close #3190 * Flag mutable ``collections.*`` utilities as dangerous defaults Close #3183 * ``docparams`` extension supports multiple types in raises sections. Multiple types can also be separated by commas in all valid sections. Closes #2729 * Allow parallel linting when run under Prospector * Fixed false positives of ``method-hidden`` when a subclass defines the method that is being hidden. Closes #414 * Python 3 porting mode is 30-50% faster on most codebases * Python 3 porting mode no longer swallows syntax errors Closes #2956 * Pass the actual PyLinter object to sub processes to allow using custom PyLinter classes. PyLinter object (and all its members except reporter) needs to support pickling so the PyLinter object can be passed to worker processes. * Clean up setup.py Make pytest-runner a requirement only if running tests, similar to McCabe. Clean up the setup.py file, resolving a number of warnings around it. * Handle SyntaxError in files passed via ``--from-stdin`` option Pylint no longer outputs a traceback, if a file, read from stdin, contains a syntaxerror. * Fix uppercase style to disallow 3+ uppercase followed by lowercase. * Fixed ``undefined-variable`` and ``unused-import`` false positives when using a metaclass via an attribute. Close #1603 * Emit ``unused-argument`` for functions that partially uses their argument list before raising an exception. Close #3246 * Fixed ``broad_try_clause`` extension to check try/finally statements and to check for nested statements (e.g., inside of an ``if`` statement). * Recognize classes explicitly inheriting from ``abc.ABC`` or having an ``abc.ABCMeta`` metaclass as abstract. This makes them not trigger W0223. Closes #3098 * Fix overzealous `arguments-differ` when overridden function uses variadics No message is emitted if the overriding function provides positional or keyword variadics in its signature that can feasibly accept and pass on all parameters given by the overridden function. Close #1482 Close #1553 * Multiple types of string formatting are allowed in logging functions. The `logging-fstring-interpolation` message has been brought back to allow multiple types of string formatting to be used. Close #3361 What's New in Pylint 2.4.4? =========================== Release date: 2019-11-13 * Exempt all the names found in type annotations from ``unused-import`` The previous code was assuming that only ``typing`` names need to be exempted, but we need to do that for the rest of the type comment names as well. Close #3112 * Relax type import detection for names that do not come from the ``typing`` module Close #3191 What's New in Pylint 2.4.3? =========================== Release date: 2019-10-18 * Fix an issue with ``unnecessary-comprehension`` in comprehensions with additional repacking of elements. Close #3148 * ``import-outside-toplevel`` is emitted for ``ImportFrom`` nodes as well. Close #3175 * Do not emit ``no-method-argument`` for functions using positional only args. Close #3161 * ``consider-using-sys-exit`` is no longer emitted when `exit` is imported in the local scope. Close #3147 * `invalid-overridden-method` takes `abc.abstractproperty` in account Close #3150 * Fixed ``missing-yield-type-doc`` getting incorrectly raised when a generator does not document a yield type but has a type annotation. Closes #3185 * ``typing.overload`` functions are exempted from ``too-many-function-args`` Close #3170 What's New in Pylint 2.4.2? =========================== Release date: 2019-09-30 * ``ignored-modules`` can skip submodules. Close #3135 * ``self-assigning-variable`` skips class level assignments. Close #2930 * ``consider-using-sys-exit`` is exempted when `exit()` is imported from `sys` Close #3145 * Exempt annotated assignments without variable from ``class-variable-slots-conflict`` Close #3141 * Fix ``utils.is_error`` to account for functions returning early. This fixes a false negative with ``unused-variable`` which was no longer triggered when a function raised an exception as the last instruction, but the body of the function still had unused variables. Close #3028 What's New in Pylint 2.4.1? =========================== Release date: 2019-09-25 * Exempt type checking definitions defined in both clauses of a type checking guard Close #3127 * Exempt type checking definitions inside the type check guard In a7f236528bb3758886b97285a56f3f9ce5b13a99 we added basic support for emitting `used-before-assignment` if a variable was only defined inside a type checking guard (using `TYPE_CHECKING` variable from `typing`) Unfortunately that missed the case of using those type checking imports inside the guard itself, which triggered spurious used-before-assignment errors. Close #3119 * Require astroid >= 2.3 to avoid any compatibility issues. What's New in Pylint 2.4.0? =========================== Release date: 2019-09-24 * New check: ``import-outside-toplevel`` This check warns when modules are imported from places other than a module toplevel, e.g. inside a function or a class. * Handle inference ambiguity for ``invalid-format-index`` Close #2752 * Removed Python 2 specific checks such as ``relative-import``, ``invalid-encoded-data``, ``missing-super-argument``. * Support forward references for ``function-redefined`` check. Close #2540 * Handle redefinitions in case of type checking imports. Close #2834 * Added a new check, ``consider-using-sys-exit`` This check is emitted when we detect that a quit() or exit() is invoked instead of sys.exit(), which is the preferred way of exiting in program. Close #2925 * ``useless-suppression`` check now ignores ``cyclic-import`` suppressions, which could lead to false postiives due to incomplete context at the time of the check. Close #3064 * Added new checks, ``no-else-break`` and ``no-else-continue`` These checks highlight unnecessary ``else`` and ``elif`` blocks after ``break`` and ``continue`` statements. Close #2327 * Don't emit ``protected-access`` when a single underscore prefixed attribute is used inside a special method Close #1802 * Fix the "statement" values in the PyLinter's stats reports by module. * Added a new check, ``invalid-overridden-method`` This check is emitted when we detect that a method is overridden as a property or a property is overridden as a method. This can indicate a bug in the application code that will trigger a runtime error. Close #2670 * Added a new check, ``arguments-out-of-order`` This check warns if you have arguments with names that match those in a function's signature but you are passing them in to the function in a different order. Close #2975 * Added a new check, ``redeclared-assigned-name`` This check is emitted when ``pylint`` detects that a name was assigned one or multiple times in the same assignment, which indicate a potential bug. Close #2898 * Ignore lambda calls with variadic arguments without a context. Inferring variadic positional arguments and keyword arguments will result into empty Tuples and Dicts, which can lead in some cases to false positives with regard to no-value-for-parameter. In order to avoid this, until we'll have support for call context propagation, we're ignoring such cases if detected. We already did that for function calls, but the previous fix was not taking in consideration ``lambdas`` Close #2918 * Added a new check, ``self-assigning-variable`` This check is emitted when we detect that a variable is assigned to itself, which might indicate a potential bug in the code application. Close #2930 * Added a new check, ``property-with-parameters``. This check is emitted when we detect that a defined property also has parameters, which are useless. Close #3006 * Excluded protocol classes from a couple of checks. Close #3002. * Add a check `unnecessary-comprehension` that detects unnecessary comprehensions. This check is emitted when ``pylint`` finds list-, set- or dict-comprehensions, that are unnecessary and can be rewritten with the list-, set- or dict-constructors. Close #2905 * Excluded PEP 526 instance and class variables from ``no-member``. Close #2945 * Excluded `attrs` from `too-few-public-methods` check. Close #2988. * ``unused-import`` emitted for the right import names in function scopes. Close #2928 * Dropped support for Python 3.4. * ``assignment-from-no-return`` not triggered for async methods. Close #2902 * Don't emit ``attribute-defined-outside-init`` for variables defined in setters. Close #409 * Syntax errors report the column number. Close #2914 * Support fully qualified typing imports for type annotations. Close #2915 * Exclude ``__dict__`` from ``attribute-defined-outside-init`` * Fix pointer on spelling check when the error are more than one time in the same line. Close #2895 * Fix crash happening when parent of called object cannot be determined * Allow of in `GoogleDocstring.re_multiple_type` * Added `subprocess-run-check` to handle subrocess.run without explicitly set `check` keyword. Close #2848 * When we can't infer bare except handlers, skip ``try-except-raise`` Close #2853 * Handle more `unnecessary-lambda` cases when dealing with additional kwargs in wrapped calls Close #2845 * Better postponed evaluation of annotations handling Close #2847 * Support postponed evaluation of annotations for variable annotations. Close #2838 * ``epylint.py_run`` defaults to ``python`` in case the current executable is not a Python one. Close #2837 * Ignore raw docstrings when running Similarities checker with `ignore-docstrings=yes` option * Fix crash when calling ``inherit_from_std_ex`` on a class which is its own ancestor Close #2680 * Added a new check that warns the user if a function call is used inside a test but parentheses are missing. Close #2658 * ``len-as-condition`` now only fires when a ``len(x)`` call is made without an explicit comparison The message and description accompanying this checker has been changed reflect this new behavior, by explicitly asking to either rely on the fact that empty sequence are false or to compare the length with a scalar. Close #2684 * Add ``preferred-module`` checker that notify if an import has a replacement module that should be used. This check is emitted when ``pylint`` finds an imported module that has a preferred replacement listed in ``preferred-modules``. * ``assigning-non-slot`` not emitted for classes with unknown base classes. Close #2807 * ``old-division`` is not emitted for non-Const nodes. Close #2808 * Added method arguments to the dot writer for pyreverse. Close #2139 * Support for linting file from stdin. IDEs may benefit from the support for linting from an in-memory file. Close #1187 * Added a new check `class-variable-slots-conflict` This check is emitted when ``pylint`` finds a class variable that conflicts with a slot name, which would raise a ``ValueError`` at runtime. * Added new check: dict-iter-missing-items (E1141) Close #2761 * Fix issue with pylint name in output of python -m pylint --version Close #2764 * Relicense logo material under the CC BY-SA 4.0 license. * Skip `if` expressions from f-strings for the `check_elif` checker Close #2816 * C0412 (ungrouped-import) is now compatible with isort. Close #2806 * Added new extension to detect too much code in a try clause Close #2877 * ``signature-mutators`` option was added With this option, users can choose to ignore `too-many-function-args`, `unexpected-keyword-arg`, and `no-value-for-parameter` for functions decorated with decorators that change the signature of a decorated function. Close #259 * Fixed a pragma comment on its own physical line being ignored when part of a logical line with the previous physical line. Close #199 * Fixed false `undefined-loop-variable` for a function defined in the loop, that uses the variable defined in that loop. Close #202 * Fixed `unused-argument` and `function-redefined` getting raised for functions decorated with `typing.overload`. Close #1581 * Fixed a false positive with ``consider-using-dict-comprehension`` for constructions that can't be converted to a comprehension Close #2963 * Added ``__post_init__`` to ``defining-attr-methods`` in order to avoid ``attribute-defined-outside-init`` in dataclasses. Close #2581 * Changed description of W0199 to use the term 2-item-tuple instead of 2-uple. * Allow a `.` as a prefix for Sphinx name resolution. * Checkers must now keep a 1 to 1 relationship between "msgid" (ie: C1234) and "symbol" (ie : human-readable-symbol) * In checkers, an old_names can now be used for multiple new messages and pylint is now a little faster Caused by #1164. It means if you do a partial old_names for a message definition an exception will tell you that you must rename the associated identification. * Allow the choice of f-strings as a valid way of formatting logging strings. Closes #2395 * Added ``--list-msgs-enabled`` command to list all enabled and disabled messages given the current RC file and command line arguments. What's New in Pylint 2.3.0? =========================== Release date: 2019-02-27 * Protect against `NonDeducibleTypeHierarchy` when calling semi-private `is_subtype` `astroid.helpers.is_subtype` raises `NonDeducibleTypeHierarchy` when it cannot infer the base classes of the given types, but that makes sense in its context given that the method is mostly used to inform the inference process about the hierarchy of classes. Doesn't make that much sense for ``pylint`` itself, which is why we're handling the exception here, rather than in ``astroid`` Close pylint-dev/astroid#644 * Added a new command line option ``list-groups`` for listing all the check groups ``pylint`` knows about. * Allow ``BaseException`` for emitting ``broad-except``, just like ``Exception``. Close #2741 * Fixed a crash that occurred for ``bad-str-strip-call`` when ``strip()`` received ``None`` Close #2743 * Don't emit ``*-not-iterating`` checks for builtins consumed by ``itertools`` Close #2731 * Fix a crash caused by iterating over ``Uninferable`` in a string formatting check. Close #2727 * Fixed false positives for ``no-self-argument`` and ``unsubscriptable-object`` when using ``__class_getitem__`` (new in Python 3.7) Close #2416 * Support ``Ellipsis`` as a synonym for ``pass`` statements. Close #2718 * ``fixme`` gets triggered only on comments. Close #2321 * Fixed a false positive for ``unused-variable`` and ``nonlocal`` assignments Close #2671 * Added ``load_configuration()`` hook for plugins New optional hook for plugins is added: ``load_configuration()``. This hook is executed after configuration is loaded to prevent overwriting plugin specific configuration via user-based configuration. Close #2635 * Fix missing-raises-doc false positive (W9006) Close #1502 * Exempt starred unpacking from ``*-not-iterating`` Python 3 checks Close #2651 * Make ``compare-to-zero`` less zealous by checking against equality and identity Close #2645 * Add ``no-else-raise`` warning (R1720) Close #2558 * Exempt ``yield from`` from ``*-not-iterating`` Python 3 checks. Close #2643 * Fix incorrect generation of ``no-else-return`` warnings (R1705) Fixed issue where ``if`` statements with nested ``if`` statements were incorrectly being flagged as ``no-else-return`` in some cases and not being flagged as ``no-else-return`` in other cases. Added tests for verification and updated pylint source files to eliminate newly exposed warnings. * Fix false positive with `not-async-context-manager` caused by not understanding `contextlib.asynccontextmanager` Close #2440 * Refactor ``bad-reversed-sequence`` to account for more objects that can define ``__reversed__`` One such object would be an enum class, for which ``__reversed__`` yields each individual enum. As such, the check for ``bad-reversed-sequence`` needs to not differentiate between classes and instances when it comes for checking of ``__reversed__`` presence. Close #2598 * Added ``wrong-exception-operation`` Used when an operation is done against an exception, but the operation is not valid for the exception in question. Usually emitted when having binary operations between exceptions in except handlers. Close #2494 * ``no-member`` is emitted for enums when they lack a member Previously we weren't doing this because we detected a ``__getattr__`` implementation on the ``Enum`` class (and this check is skipped for classes with ``__getattr__``), but that is fine for Enums, given that they are inferred in a customised way in astroid. Close #2565 * Generalize ``chained-comparison`` Previous version incorrectly detects `a < b < c and b < d` and fails to detect `a < b < c and c < d`. * Avoid popping __main__ when using multiple jobs Close #2689 * Add a new option 'check-str-concat-over-line-jumps' to check 'implicit-str-concat-in-sequence' * Fixes for the new style logging format linter. The number of arguments was not handled properly, leading to an always successful check. * Fix false positive ``not-callable`` for uninferable properties. * Fix false positive ``useless-else-on-loop`` if the break is deep in the else of an inner loop. * Minor improvements to the help text for a few options. What's New in Pylint 2.2.2? =========================== Release date: 2018-11-28 * Change the ``logging-format-style`` to use name identifier instead of their corresponding Python identifiers This is to prevent users having to think about escaping the default value for ``logging-format-style`` in the generated config file. Also our config parsing utilities don't quite support escaped values when it comes to ``choices`` detection, so this would have needed various hacks around that. Closes #2614 What's New in Pylint 2.2.1? =========================== Release date: 2018-11-27 * Fix a crash caused by `implicit-str-concat-in-sequence` and multi-bytes characters. Closes #2610 What's New in Pylint 2.2? ========================= Release date: 2018-11-25 * Consider ``range()`` objects for ``undefined-loop-variable`` leaking from iteration. Close #2533 * ``deprecated-method`` can use the attribute name for identifying a deprecated method Previously we were using the fully qualified name, which we still do, but the fully qualified name for some ``unittest`` deprecated aliases leads to a generic deprecation function. Instead on relying on that, we now also rely on the attribute name, which should solve some false positives. Close #1653 Close #1946 * Fix compatibility with changes to stdlib tokenizer. * ``pylint`` is less eager to consume the whole line for pragmas Close #2485 * Obtain the correct number of CPUs for virtualized or containerized environments. Close #2519 * Change ``unbalanced-tuple-unpacking`` back to a warning. It used to be a warning until a couple of years ago, after it was promoted to an error. But the check might be suggesting the wrong thing in some cases, for instance when checking against ``sys.argv`` which cannot be known at static analysis time. Given it might rely on potential unknown data, it's best to have it as a warning. Close #2522 * Remove ``enumerate`` usage suggestion when defining ``__iter__`` (C0200) Close #2477 * Emit ``too-many-starred-assignment`` only when the number of Starred nodes is per assignment elements Close #2513 * `try-except-raise` checker now handles multilevel inheritance hirerachy for exceptions correctly. Close #2484 * Add a new check, ``simplifiable-if-expression`` for expressions like ``True if cond else False``. Close #2487 * ``too-few-public-methods`` is not reported for ``typing.NamedTuple`` Close #2459 * ```too-few-public-methods`` is not reported for dataclasses created with options. Close #2488 * Remove wrong modules from 'bad-python3-import'. Close #2453 * The ``json`` reporter prints an empty list when no messages are emitted Close #2446 * Add a new check, ``duplicate-string-formatting-argument`` This new check is emitted whenever a duplicate string formatting argument is found. Close #497 * ``assignment-from-no-return`` is not emitted for coroutines. Close #1715 * Report format string type mismatches. * ``consider-using-ternary`` and ``simplified-boolean-expression`` no longer emit for sequence based checks Close #2473 * Handle ``AstroidSyntaxError`` when trying to import a module. Close #2313 * Allow ``__module__`` to be redefined at a class level. Close #2451 * ``pylint`` used to emit a ``unused-variable`` error if unused import was found in the function. Now instead of ``unused-variable``, ``unused-import`` is emitted. Close #2421 * Handle asyncio.coroutine when looking for ``not-an-iterable`` check. Close #996 * The ``locally-enabled`` check is gone. Close #2442 * Infer decorated methods when looking for method-hidden Close #2369 * Pick the latest value from the inferred values when looking for ``raising-non-exception`` Close #2431 * Extend the TYPE_CHECKING guard to TYPE_CHECKING name as well, not just the attribute Close #2411 * Ignore import x.y.z as z cases for checker `useless-import-alias`. Close #2309 * Fix false positive ``undefined-variable`` and ``used-before-assignment`` with nonlocal keyword usage. Close #2049 * Stop ``protected-access`` exception for missing class attributes * Don't emit `assignment-from-no-return` for decorated function nodes Close #2385 * `unnecessary-pass` is now also emitted when a function or class contains only docstring and pass statement. In Python, stubbed functions often have a body that contains just a single `pass` statement, indicating that the function doesn't do anything. However, a stubbed function can also have just a docstring, and function with a docstring and no body also does nothing. Close #2208 * ``duplicate-argument-name`` is emitted for more than one duplicate argument per function Close #1712 * Allow double indentation levels for more distinguishable indentations Close #741 * Consider tuples in exception handler for ``try-except-raise``. Close #2389 * Fix astroid.ClassDef check in checkers.utils.is_subclass_of * Fix wildcard imports being ignored by the import checker * Fix external/internal distinction being broken in the import graph * Fix wildcard import check not skipping `__init__.py` Close #2430 * Add new option to logging checker, ``logging_format_style`` * Fix --ignore-imports to understand multi-line imports Close #1422 Close #2019 * Add a new check 'implicit-str-concat-in-sequence' to spot string concatenation inside lists, sets & tuples. * ``literal-comparison`` is now emitted for 0 and 1 literals. What's New in Pylint 2.1.1? =========================== Release date: 2018-08-07 * fix pylint crash due to ``misplaced-format-function`` not correctly handling class attribute. Close #2384 * Do not emit \*-builtin for Python 3 builtin checks when the builtin is used inside a try-except Close pylint-dev/pylint#2228 * ``simplifiable-if-statement`` not emitted when dealing with subscripts What's New in Pylint 2.1? ========================= Release date: 2018-08-01 * `trailing-comma-tuple` gets emitted for ``yield`` statements as well. Close #2363 * Get only the arguments of the scope function for `redefined-argument-from-local` Close #2364 * Add a check `misplaced-format-function` which is emitted if format function is used on non str object. Close #2200 * `chain.from_iterable` no longer emits `dict-{}-not-iterating` when dealing with dict values and keys * Demote the `try-except-raise` message from an error to a warning (E0705 -> W0706) Close #2323 * Correctly handle the new name of the Python implementation of the `abc` module. Close pylint-dev/astroid#2288 * Modules with `__getattr__` are exempted by default from `no-member` There's no easy way to figure out if a module has a particular member when the said module uses `__getattr__`, which is a new addition to Python 3.7. Instead we assume the safe thing to do, in the same way we do for classes, and skip those modules from checking. Close #2331 * Fix a false positive `invalid name` message when method or attribute name is longer then 30 characters. Close #2047 * Include the type of the next branch in `no-else-return` Close #2295 * Fix inconsistent behaviour for bad-continuation on first line of file Close #2281 * Fix not being able to disable certain messages on the last line through the global disable option Close #2278 * Don't emit `useless-return` when we have a single statement that is the return itself We still want to be explicit when a function is supposed to return an optional value; even though `pass` could still work, it's not explicit enough and the function might look like it's missing an implementation. Close #2300 * Fix false-positive undefined-variable for self referential class name in lamdbas Close #704 * Don't crash when `pylint` is unable to infer the value of an argument to `next()` Close #2316 * Don't emit `not-an-iterable` when dealing with async iterators. But do emit it when using the usual iteration protocol against async iterators. Close #2311 * Can specify a default docstring type for when the check cannot guess the type Close #1169 What's New in Pylint 2.0? ========================= Release date: 2018-07-15 * `try-except-raise` should not be emitted if there are any parent exception class handlers. Close #2284 * `trailing-comma-tuple` can be emitted for `return` statements as well. Close #2269 * Fix a false positive ``inconsistent-return-statements`` message when exception is raised inside an else statement. Close #1782 * `ImportFrom` nodes correctly use the full name for the import sorting checks. Close #2181 * [].extend and similar builtin operations don't emit `dict-*-not-iterating` with the Python 3 porting checker Close #2187 * Add a check `consider-using-dict-comprehension` which is emitted if for dict initialization the old style with list comprehensions is used. * Add a check `consider-using-set-comprehension` which is emitted if for set initialization the old style with list comprehensions is used. * `logging-not-lazy` is emitted whenever pylint infers that a string is built with addition Close #2193 * Add a check `chained-comparison` which is emitted if a boolean operation can be simplified by chaining some of its operations. e.g "a < b and b < c", can be simplified as "a < b < c". Close #2032 * Add a check `consider-using-in` for comparisons of a variable against multiple values with "==" and "or"s instead of checking if the variable is contained "in" a tuple of those values. * `in` is considered iterating context for some of the Python 3 porting checkers Close #2186 * Add `--ignore-none` flag to control if pylint should warn about `no-member` where the owner is None * Fix a false positive related to `too-many-arguments` and bounded `__get__` methods Close #2172 * `mcs` as the first parameter of metaclass's `__new__` method was replaced by `cls` Close #2028 * `assignment-from-no-return` considers methods as well. Close #2081 * Support typing.TYPE_CHECKING for *unused-import* errors Close #1948 * Inferred classes at a function level no longer emit `invalid-name` when they don't respect the variable regular expression Close #1049 * Added basic support for postponed evaluation of function annotations. Close #2069 * Fix a bug with `missing-kwoa` and variadics parameters Close #1111 * `simplifiable-if-statement` takes in account only when assigning to same targets Close #1984 * Make ``len-as-condition`` test more cases, such as ``len() < 1`` or ``len <= 0`` * Fix false-positive ``line-too-long`` message emission for commented line at the end of a module Close #1950 * Fix false-positive ``bad-continuation`` for with statements Close #461 * Don't warn about `stop-iteration-return` when using `next()` over `itertools.count` Close #2158 * Add a check `consider-using-get` for unidiomatic usage of value/default-retrieval for a key from a dictionary Close #2076 * invalid-slice-index is not emitted when the slice is used as index for a complex object. We only use a handful of known objects (list, set and friends) to figure out if we should emit invalid-slice-index when the slice is used to subscript an object. * Don't emit `unused-import` anymore for typing imports used in type comments. * Add a new check 'useless-import-alias'. Close #2052 * Add `comparison-with-callable` to warn for comparison with bare callable, without calling it. Close #2082 * Don't warn for ``missing-type-doc`` and/or ``missing-return-type-doc``, if type annotations exist on the function signature for a parameter and/or return type. Close #2083 * Add `--exit-zero` option for continuous integration scripts to more easily call Pylint in environments that abort when a program returns a non-zero (error) status code. Close #2042 * Warn if the first argument of an instance/ class method gets assigned Close #977 * New check `comparison-with-itself` to check comparison between same value. Close #2051 * Add a new warning, 'logging-fstring-interpolation', emitted when f-string is used within logging function calls. Close #1998 * Don't show 'useless-super-delegation' if the subclass method has different type annotations. Close #1923 * Add `unhashable-dict-key` check. Closes #586 * Don't warn that a global variable is unused if it is defined by an import Close #1453 * Skip wildcard import check for `__init__.py`. Close #2026 * The Python 3 porting mode can now run with Python 3 as well. * `too-few-public-methods` is not emitted for dataclasses. Close #1793 * New verbose mode option, enabled with `--verbose` command line flag, to display of extra non-checker-related output. It is disabled by default. Close #1863 * `undefined-loop-variable` takes in consideration non-empty iterred objects before emitting Close #2039 * Add support for numpydoc optional return value names. Close #2030 * `singleton-comparison` accounts for negative checks Close #2037 * Add a check `consider-using-in` for comparisons of a variable against multiple values with "==" and "or"s instead of checking if the variable is contained "in" a tuple of those values. Close #1977 * defaultdict and subclasses of dict are now handled for dict-iter-* checks Close #2005 * `logging-format-interpolation` also emits when f-strings are used instead of % syntax. Close #1788 * Don't trigger misplaced-bare-raise when the raise is in a finally clause Close #1924 * Add a new check, `possibly-unused-variable`. This is similar to `unused-variable`, the only difference is that it is emitted when we detect a locals() call in the scope of the unused variable. The `locals()` call could potentially use the said variable, by consuming all values that are present up to the point of the call. This new check allows to disable this error when the user intentionally uses `locals()` to consume everything. Close #1909. * `no-else-return` accounts for multiple cases The check was a bit overrestrictive because we were checking for return nodes in the .orelse node. At that point though the if statement can be refactored to not have the orelse. This improves the detection of other cases, for instance it now detects TryExcept nodes that are part of the .else branch. Close #1852 * Added two new checks, `invalid-envvar-value` and `invalid-envvar-default`. The former is trigger whenever pylint detects that environment variable manipulation functions uses a different type than strings, while the latter is emitted whenever the said functions are using a default variable of different type than expected. * Add a check `consider-using-join` for concatenation of strings using str.join(sequence) Close #1952 * Add a check `consider-swap-variables` for swapping variables with tuple unpacking Close #1922 * Add new checker `try-except-raise` that warns the user if an except handler block has a ``raise`` statement as its first operator. The warning is shown when there is a bare raise statement, effectively re-raising the exception that was caught or the type of the exception being raised is the same as the one being handled. * Don't crash on invalid strings when checking for `logging-format-interpolation` Close #1944 * Exempt `__doc__` from triggering a `redefined-builtin` `__doc__` can be used to specify a docstring for a module without passing it as a first-statement string. * Fix false positive bad-whitespace from function arguments with default values and annotations Close #1831 * Fix stop-iteration-return false positive when next builtin has a default value in a generator Close #1830 * Fix emission of false positive ``no-member`` message for class with "private" attributes whose name is mangled. Close #1643 * Fixed a crash which occurred when `Uninferable` wasn't properly handled in `stop-iteration-return` Close #1779 * Use the proper node to get the name for redefined functions (#1792) Close #1774 * Don't crash when encountering bare raises while checking inconsistent returns Close #1773 * Fix a false positive ``inconsistent-return-statements`` message when if statement is inside try/except. Close #1770 * Fix a false positive ``inconsistent-return-statements`` message when while loop are used. Close #1772 * Correct column number for whitespace conventions. Previously the column was stuck at 0 Close #1649 * Fix ``unused-argument`` false positives with overshadowed variable in dictionary comprehension. Close #1731 * Fix false positive ``inconsistent-return-statements`` message when never returning functions are used (i.e sys.exit for example). Close #1771 * Fix error when checking if function is exception, as in ``bad-exception-context``. * Fix false positive ``inconsistent-return-statements`` message when a function is defined under an if statement. Close #1794 * New ``useless-return`` message when function or method ends with a "return" or "return None" statement and this is the only return statement in the body. * Fix false positive ``inconsistent-return-statements`` message by avoiding useless exception inference if the exception is not handled. Close #1794 (second part) * Fix bad thread instantiation check when target function is provided in args. Close #1840 * Fixed false positive when a numpy Attributes section follows a Parameters section Close #1867 * Fix incorrect file path when file absolute path contains multiple ``path_strip_prefix`` strings. Close #1120 * Fix false positive undefined-variable for lambda argument in class definitions Close #1824 * Add of a new checker that warns the user if some messages are enabled or disabled by id instead of symbol. Close #1599 * Suppress false-positive ``not-callable`` messages from certain staticmethod descriptors Close #1699 * Fix indentation handling with tabs Close #1148 * Fix false-positive ``bad-continuation`` error Close #638 * Fix false positive unused-variable in lambda default arguments Close #1921 Close #1552 Close #1099 Close #210 * Updated the default report format to include paths that can be clicked on in some terminals (e.g. iTerm). * Fix inline def behavior with ``too-many-statements`` checker Close #1978 * Fix `KeyError` raised when using docparams and NotImplementedError is documented. Close #2102 * Fix 'method-hidden' raised when assigning to a property or data descriptor. * Fix emitting ``useless-super-delegation`` when changing the default value of keyword arguments. Close #2022 * Expand ignored-argument-names include starred arguments and keyword arguments Close #2214 * Fix false-positive undefined-variable in nested lambda Close #760 * Fix false-positive ``bad-whitespace`` message for typing annoatations with ellipses in them Close 1992 * Broke down "missing-docstrings" between "module", "class" and "function" For this to work we had to make multiple messages with the same old name possible. Closes #1164
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Steps to reproduce
test.py
with the following content:pylint test.py
astroid.exceptions._NonDeducibleTypeHierarchy
errorCurrent behavior
astroid.exceptions._NonDeducibleTypeHierarchy raised
Expected behavior
no error
python -c "from astroid import __pkginfo__; print(__pkginfo__.version)"
output2.1.0
The text was updated successfully, but these errors were encountered: