Update dependency astroid to v3 #60

Merged
renovate[bot] merged 1 commits from renovate/astroid-3.x into main 2023-10-18 13:11:58 +02:00
renovate[bot] commented 2023-09-26 17:35:09 +02:00 (Migrated from github.com)

Mend Renovate

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
astroid ==2.15.8 -> ==3.0.1 age adoption passing confidence

Warning

Some dependencies could not be looked up. Check the Dependency Dashboard for more information.


Release Notes

pylint-dev/astroid (astroid)

v3.0.1

Compare Source

============================
Release date: 2023-10-15

v3.0.0

Compare Source

=============================
Release date: 2023-09-25

  • Add support for Python 3.12, including PEP 695 type parameter syntax.

    Closes #​2201

  • Remove support for Python 3.7.

    Refs #​2137

  • Use the global inference cache when inferring, even without an explicit
    InferenceContext. This is a significant performance improvement given how
    often methods default to None for the context argument. (Linting astroid
    itself now takes ~5% less time on Python 3.12; other projects requiring more
    complex inference calculations will see greater speedups.)

    Refs #​529

  • Following a deprecation period starting in astroid 2.7.0, the astroid.node_classes
    and astroid.scoped_nodes modules have been removed in favor of astroid.nodes.node_classes
    and astroid.nodes.scoped_nodes.

    Closes #​1072

  • Following a deprecation period starting in astroid 2.12.0, the astroid.mixins module
    has been removed in favor of astroid.nodes._base_nodes (private).

    Refs #​1633

  • Return all existing arguments when calling Arguments.arguments(). This also means find_argname will now
    use the whole list of arguments for its search.

    Closes #​2213

  • Exclude class attributes from the __members__ container of an Enum class when they are
    nodes.AnnAssign nodes with no assigned value.

    Refs pylint-dev/pylint#7402

  • Remove @cached and @cachedproperty decorator (just use @cached_property from the stdlib).

    Closes #​1780
    Refs #​2140

  • Remove the inference module. Node inference methods are now in the module
    defining the node, rather than being associated to the node afterward.

    Closes #​679

  • Move LookupMixIn to astroid.nodes._base_nodes and make it private.

  • Remove the shims for OperationError, BinaryOperationError, and UnaryOperationError
    in exceptions. They were moved to util in astroid 1.5.0.

  • Move safe_infer() from helpers to util. This avoids some circular imports.

  • Reduce file system access in ast_from_file().

  • Reduce time to import astroid by delaying astroid_bootstrapping() until
    the first instantiation of AstroidBuilder.

    Closes #​2161

  • Make igetattr() idempotent. This addresses some reports of varying results
    when running pylint with --jobs.

    Closes pylint-dev/pylint#4356
    Refs #​7

  • Fix incorrect cache keys for inference results, thereby correctly inferring types
    for calls instantiating types dynamically.

    Closes #​1828
    Closes pylint-dev/pylint#7464
    Closes pylint-dev/pylint#8074

  • Fix interrupted InferenceContext call chains, thereby addressing performance
    problems when linting sqlalchemy.

    Closes pylint-dev/pylint#8150

  • nodes.FunctionDef no longer inherits from nodes.Lambda.
    This is a breaking change but considered a bug fix as the nodes did not share the same
    API and were not interchangeable.

    We have tried to minimize the amount of breaking changes caused by this change
    but some are unavoidable.

  • infer_call_result now shares the same interface across all implementations. Namely:

    def infer_call_result(
                  self,
                  caller: SuccessfulInferenceResult | None,
                  context: InferenceContext | None = None,
              ) -> Iterator[InferenceResult]:
    

    This is a breaking change for nodes.FunctionDef where previously caller had a default of
    None. Passing None again will not create a behaviour change.
    The breaking change allows us to better type and re-use the method within astroid.

  • Improved signature of the __init__ and __postinit__ methods of most nodes.
    This includes making lineno, col_offset, end_lineno, end_col_offset and parent
    required arguments for nodes.NodeNG and its subclasses.
    For most other nodes, arguments of their __postinit__ methods have been made required to better
    represent how they would normally be constructed by the standard library ast module.
    The following nodes were changed or updated:

    • nodes.AnnAssign
    • nodes.Arguments
    • nodes.Assign
    • nodes.AssignAttr
    • nodes.AssignName
    • nodes.Attribute
    • nodes.AugAssign
    • nodes.Await
    • nodes.BaseContainer
    • nodes.BinOp
    • nodes.Call
    • nodes.ClassDef
    • nodes.Compare
    • nodes.Comprehension
    • nodes.Decorators
    • nodes.Delete
    • nodes.DelAttr
    • nodes.DelName
    • nodes.Dict
    • nodes.DictComp
    • nodes.ExceptHandler
    • nodes.Expr
    • nodes.For
    • nodes.FunctionDef
    • nodes.GeneratorExp
    • nodes.If
    • nodes.IfExp
    • nodes.Keyword
    • nodes.Lambda
    • nodes.ListComp
    • nodes.Module
    • nodes.Name
    • nodes.NodeNG
    • nodes.Raise
    • nodes.Return
    • nodes.SetComp
    • nodes.Slice
    • nodes.Starred
    • objects.Super, we also added the call parameter to its __init__ method.
    • nodes.Subscript
    • nodes.UnaryOp
    • nodes.While
    • nodes.Yield

    These changes involve breaking changes to their API but should be considered bug fixes. We
    now make arguments required when they are instead of always providing defaults.

  • nodes.If.self.is_orelse has been removed as it was never set correctly and therefore
    provided a false value.

  • Remove dependency on wrapt.

  • Remove dependency on lazy_object_proxy. This includes the removal
    of the associated lazy_import, lazy_descriptor and proxy_alias utility functions.

  • CallSite._unpack_args and CallSite._unpack_keywords now use safe_infer() for
    better inference and fewer false positives.

    Closes pylint-dev/pylint#8544

  • Add attr.Factory to the recognized class attributes for classes decorated with attrs.

    Closes pylint-dev/pylint#4341

  • infer_property() now observes the same property-specific workaround as infer_functiondef.

    Refs #​1490

  • Remove unused and / or deprecated constants:

    • astroid.bases.BOOL_SPECIAL_METHOD
    • astroid.bases.BUILTINS
    • astroid.const.BUILTINS
    • astroid.const.PY38_PLUS
    • astroid.const.Load
    • astroid.const.Store
    • astroid.const.Del

    Refs #​2141

  • frame() raises ParentMissingError and statement() raises StatementMissing for
    missing parents regardless of the value of the future argument (which gave this behavior
    already).

    The future argument to each method is deprecated and will be removed in astroid 4.0.

    Refs #​1217

  • Remove deprecated Ellipsis, ExtSlice, Index nodes.

    Refs #​2152

  • Remove deprecated is_sys_guard and is_typing_guard methods.

    Refs #​2153

  • Remove deprecated doc attribute for Module, ClassDef, and FunctionDef.
    Use the doc_node attribute instead.

    Refs #​2154

  • Add new nodes.Try to better match Python AST. Replaces the TryExcept
    and TryFinally nodes which have been removed.

  • Publicize NodeNG.repr_name() to facilitate finding a node's nice name.

    Refs pylint-dev/pylint#8598

  • Fix false positives for no-member and invalid-name when using the _name_, _value_ and _ignore_ sunders in Enums.

    Closes pylint-dev/pylint#9015


Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR has been generated by Mend Renovate. View repository job log here.

[![Mend Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com) This PR contains the following updates: | Package | Change | Age | Adoption | Passing | Confidence | |---|---|---|---|---|---| | [astroid](https://togithub.com/pylint-dev/astroid) | `==2.15.8` -> `==3.0.1` | [![age](https://developer.mend.io/api/mc/badges/age/pypi/astroid/3.0.1?slim=true)](https://docs.renovatebot.com/merge-confidence/) | [![adoption](https://developer.mend.io/api/mc/badges/adoption/pypi/astroid/3.0.1?slim=true)](https://docs.renovatebot.com/merge-confidence/) | [![passing](https://developer.mend.io/api/mc/badges/compatibility/pypi/astroid/2.15.8/3.0.1?slim=true)](https://docs.renovatebot.com/merge-confidence/) | [![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/astroid/2.15.8/3.0.1?slim=true)](https://docs.renovatebot.com/merge-confidence/) | --- > [!WARNING] > Some dependencies could not be looked up. Check the Dependency Dashboard for more information. --- ### Release Notes <details> <summary>pylint-dev/astroid (astroid)</summary> ### [`v3.0.1`](https://togithub.com/pylint-dev/astroid/blob/HEAD/ChangeLog#Whats-New-in-astroid-301) [Compare Source](https://togithub.com/pylint-dev/astroid/compare/v3.0.0...v3.0.1) \============================ Release date: 2023-10-15 - Fix crashes linting code using PEP 695 (Python 3.12) generic type syntax. Closes [pylint-dev/pylint#9098](https://togithub.com/pylint-dev/pylint/issues/9098) ### [`v3.0.0`](https://togithub.com/pylint-dev/astroid/blob/HEAD/ChangeLog#Whats-New-in-astroid-300) [Compare Source](https://togithub.com/pylint-dev/astroid/compare/v2.15.8...v3.0.0) \============================= Release date: 2023-09-25 - Add support for Python 3.12, including PEP 695 type parameter syntax. Closes [#&#8203;2201](https://togithub.com/pylint-dev/astroid/issues/2201) - Remove support for Python 3.7. Refs [#&#8203;2137](https://togithub.com/pylint-dev/astroid/issues/2137) - Use the global inference cache when inferring, even without an explicit `InferenceContext`. This is a significant performance improvement given how often methods default to `None` for the context argument. (Linting `astroid` itself now takes ~5% less time on Python 3.12; other projects requiring more complex inference calculations will see greater speedups.) Refs [#&#8203;529](https://togithub.com/pylint-dev/astroid/issues/529) - Following a deprecation period starting in astroid 2.7.0, the `astroid.node_classes` and `astroid.scoped_nodes` modules have been removed in favor of `astroid.nodes.node_classes` and `astroid.nodes.scoped_nodes`. Closes [#&#8203;1072](https://togithub.com/pylint-dev/astroid/issues/1072) - Following a deprecation period starting in astroid 2.12.0, the `astroid.mixins` module has been removed in favor of `astroid.nodes._base_nodes` (private). Refs [#&#8203;1633](https://togithub.com/pylint-dev/astroid/issues/1633) - Return all existing arguments when calling `Arguments.arguments()`. This also means `find_argname` will now use the whole list of arguments for its search. Closes [#&#8203;2213](https://togithub.com/pylint-dev/astroid/issues/2213) - Exclude class attributes from the `__members__` container of an `Enum` class when they are `nodes.AnnAssign` nodes with no assigned value. Refs [pylint-dev/pylint#7402](https://togithub.com/pylint-dev/pylint/issues/7402) - Remove `@cached` and `@cachedproperty` decorator (just use `@cached_property` from the stdlib). Closes [#&#8203;1780](https://togithub.com/pylint-dev/astroid/issues/1780) Refs [#&#8203;2140](https://togithub.com/pylint-dev/astroid/issues/2140) - Remove the `inference` module. Node inference methods are now in the module defining the node, rather than being associated to the node afterward. Closes [#&#8203;679](https://togithub.com/pylint-dev/astroid/issues/679) - Move `LookupMixIn` to `astroid.nodes._base_nodes` and make it private. - Remove the shims for `OperationError`, `BinaryOperationError`, and `UnaryOperationError` in `exceptions`. They were moved to `util` in astroid 1.5.0. - Move `safe_infer()` from `helpers` to `util`. This avoids some circular imports. - Reduce file system access in `ast_from_file()`. - Reduce time to `import astroid` by delaying `astroid_bootstrapping()` until the first instantiation of `AstroidBuilder`. Closes [#&#8203;2161](https://togithub.com/pylint-dev/astroid/issues/2161) - Make `igetattr()` idempotent. This addresses some reports of varying results when running pylint with `--jobs`. Closes [pylint-dev/pylint#4356](https://togithub.com/pylint-dev/pylint/issues/4356) Refs [#&#8203;7](https://togithub.com/pylint-dev/astroid/issues/7) - Fix incorrect cache keys for inference results, thereby correctly inferring types for calls instantiating types dynamically. Closes [#&#8203;1828](https://togithub.com/pylint-dev/astroid/issues/1828) Closes [pylint-dev/pylint#7464](https://togithub.com/pylint-dev/pylint/issues/7464) Closes [pylint-dev/pylint#8074](https://togithub.com/pylint-dev/pylint/issues/8074) - Fix interrupted `InferenceContext` call chains, thereby addressing performance problems when linting `sqlalchemy`. Closes [pylint-dev/pylint#8150](https://togithub.com/pylint-dev/pylint/issues/8150) - `nodes.FunctionDef` no longer inherits from `nodes.Lambda`. This is a breaking change but considered a bug fix as the nodes did not share the same API and were not interchangeable. We have tried to minimize the amount of breaking changes caused by this change but some are unavoidable. - `infer_call_result` now shares the same interface across all implementations. Namely: ```python def infer_call_result( self, caller: SuccessfulInferenceResult | None, context: InferenceContext | None = None, ) -> Iterator[InferenceResult]: ``` This is a breaking change for `nodes.FunctionDef` where previously `caller` had a default of `None`. Passing `None` again will not create a behaviour change. The breaking change allows us to better type and re-use the method within `astroid`. - Improved signature of the `__init__` and `__postinit__` methods of most nodes. This includes making `lineno`, `col_offset`, `end_lineno`, `end_col_offset` and `parent` required arguments for `nodes.NodeNG` and its subclasses. For most other nodes, arguments of their `__postinit__` methods have been made required to better represent how they would normally be constructed by the standard library `ast` module. The following nodes were changed or updated: - `nodes.AnnAssign` - `nodes.Arguments` - `nodes.Assign` - `nodes.AssignAttr` - `nodes.AssignName` - `nodes.Attribute` - `nodes.AugAssign` - `nodes.Await` - `nodes.BaseContainer` - `nodes.BinOp` - `nodes.Call` - `nodes.ClassDef` - `nodes.Compare` - `nodes.Comprehension` - `nodes.Decorators` - `nodes.Delete` - `nodes.DelAttr` - `nodes.DelName` - `nodes.Dict` - `nodes.DictComp` - `nodes.ExceptHandler` - `nodes.Expr` - `nodes.For` - `nodes.FunctionDef` - `nodes.GeneratorExp` - `nodes.If` - `nodes.IfExp` - `nodes.Keyword` - `nodes.Lambda` - `nodes.ListComp` - `nodes.Module` - `nodes.Name` - `nodes.NodeNG` - `nodes.Raise` - `nodes.Return` - `nodes.SetComp` - `nodes.Slice` - `nodes.Starred` - `objects.Super`, we also added the `call` parameter to its `__init__` method. - `nodes.Subscript` - `nodes.UnaryOp` - `nodes.While` - `nodes.Yield` These changes involve breaking changes to their API but should be considered bug fixes. We now make arguments required when they are instead of always providing defaults. - `nodes.If.self.is_orelse` has been removed as it was never set correctly and therefore provided a false value. - Remove dependency on `wrapt`. - Remove dependency on `lazy_object_proxy`. This includes the removal of the associated `lazy_import`, `lazy_descriptor` and `proxy_alias` utility functions. - `CallSite._unpack_args` and `CallSite._unpack_keywords` now use `safe_infer()` for better inference and fewer false positives. Closes [pylint-dev/pylint#8544](https://togithub.com/pylint-dev/pylint/issues/8544) - Add `attr.Factory` to the recognized class attributes for classes decorated with `attrs`. Closes [pylint-dev/pylint#4341](https://togithub.com/pylint-dev/pylint/issues/4341) - `infer_property()` now observes the same property-specific workaround as `infer_functiondef`. Refs [#&#8203;1490](https://togithub.com/pylint-dev/astroid/issues/1490) - Remove unused and / or deprecated constants: - `astroid.bases.BOOL_SPECIAL_METHOD` - `astroid.bases.BUILTINS` - `astroid.const.BUILTINS` - `astroid.const.PY38_PLUS` - `astroid.const.Load` - `astroid.const.Store` - `astroid.const.Del` Refs [#&#8203;2141](https://togithub.com/pylint-dev/astroid/issues/2141) - `frame()` raises `ParentMissingError` and `statement()` raises `StatementMissing` for missing parents regardless of the value of the `future` argument (which gave this behavior already). The `future` argument to each method is deprecated and will be removed in astroid 4.0. Refs [#&#8203;1217](https://togithub.com/pylint-dev/astroid/issues/1217) - Remove deprecated `Ellipsis`, `ExtSlice`, `Index` nodes. Refs [#&#8203;2152](https://togithub.com/pylint-dev/astroid/issues/2152) - Remove deprecated `is_sys_guard` and `is_typing_guard` methods. Refs [#&#8203;2153](https://togithub.com/pylint-dev/astroid/issues/2153) - Remove deprecated `doc` attribute for `Module`, `ClassDef`, and `FunctionDef`. Use the `doc_node` attribute instead. Refs [#&#8203;2154](https://togithub.com/pylint-dev/astroid/issues/2154) - Add new `nodes.Try` to better match Python AST. Replaces the `TryExcept` and `TryFinally` nodes which have been removed. - Publicize `NodeNG.repr_name()` to facilitate finding a node's nice name. Refs [pylint-dev/pylint#8598](https://togithub.com/pylint-dev/pylint/issues/8598) - Fix false positives for `no-member` and `invalid-name` when using the `_name_`, `_value_` and `_ignore_` sunders in Enums. Closes [pylint-dev/pylint#9015](https://togithub.com/pylint-dev/pylint/issues/9015) </details> --- ### Configuration 📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR has been generated by [Mend Renovate](https://www.mend.io/free-developer-tools/renovate/). View repository job log [here](https://developer.mend.io/github/luketainton/webexmemebot). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNi4xMDcuMiIsInVwZGF0ZWRJblZlciI6IjM3LjE5LjIiLCJ0YXJnZXRCcmFuY2giOiJtYWluIn0=-->
luketainton (Migrated from github.com) reviewed 2023-09-26 17:35:09 +02:00
sonarqubecloud[bot] commented 2023-10-18 13:09:35 +02:00 (Migrated from github.com)

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
No Duplication information No Duplication information

Kudos, SonarCloud Quality Gate passed!&nbsp; &nbsp; [![Quality Gate passed](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/QualityGateBadge/passed-16px.png 'Quality Gate passed')](https://sonarcloud.io/dashboard?id=luketainton_webexmemebot&pullRequest=60) [![Bug](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/common/bug-16px.png 'Bug')](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=BUG) [![A](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/RatingBadge/A-16px.png 'A')](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=BUG) [0 Bugs](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=BUG) [![Vulnerability](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/common/vulnerability-16px.png 'Vulnerability')](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=VULNERABILITY) [![A](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/RatingBadge/A-16px.png 'A')](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=VULNERABILITY) [0 Vulnerabilities](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=VULNERABILITY) [![Security Hotspot](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/common/security_hotspot-16px.png 'Security Hotspot')](https://sonarcloud.io/project/security_hotspots?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=SECURITY_HOTSPOT) [![A](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/RatingBadge/A-16px.png 'A')](https://sonarcloud.io/project/security_hotspots?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=SECURITY_HOTSPOT) [0 Security Hotspots](https://sonarcloud.io/project/security_hotspots?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=SECURITY_HOTSPOT) [![Code Smell](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/common/code_smell-16px.png 'Code Smell')](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=CODE_SMELL) [![A](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/RatingBadge/A-16px.png 'A')](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=CODE_SMELL) [0 Code Smells](https://sonarcloud.io/project/issues?id=luketainton_webexmemebot&pullRequest=60&resolved=false&types=CODE_SMELL) [![No Coverage information](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/CoverageChart/NoCoverageInfo-16px.png 'No Coverage information')](https://sonarcloud.io/component_measures?id=luketainton_webexmemebot&pullRequest=60) No Coverage information [![No Duplication information](https://sonarsource.github.io/sonarcloud-github-static-resources/v2/checks/Duplications/NoDuplicationInfo-16px.png 'No Duplication information')](https://sonarcloud.io/component_measures?id=luketainton_webexmemebot&pullRequest=60&metric=duplicated_lines_density&view=list) No Duplication information
Sign in to join this conversation.
No description provided.