Skip to content

Conversation

@renovate
Copy link
Contributor

@renovate renovate bot commented Mar 10, 2025

This PR contains the following updates:

Package Change Age Confidence
attrs (changelog) ==25.1.0 -> ==25.4.0 age confidence

Release Notes

python-attrs/attrs (attrs)

v25.4.0

Compare Source

Backwards-incompatible Changes
  • Class-level kw_only=True behavior is now consistent with dataclasses.

    Previously, a class that sets kw_only=True makes all attributes keyword-only, including those from base classes.
    If an attribute sets kw_only=False, that setting is ignored, and it is still made keyword-only.

    Now, only the attributes defined in that class that doesn't explicitly set kw_only=False are made keyword-only.

    This shouldn't be a problem for most users, unless you have a pattern like this:

    @​attrs.define(kw_only=True)
    class Base:
        a: int
        b: int = attrs.field(default=1, kw_only=False)
    
    @​attrs.define
    class Subclass(Base):
        c: int

    Here, we have a kw_only=True attrs class (Base) with an attribute that sets kw_only=False and has a default (Base.b), and then create a subclass (Subclass) with required arguments (Subclass.c).
    Previously this would work, since it would make Base.b keyword-only, but now this fails since Base.b is positional, and we have a required positional argument (Subclass.c) following another argument with defaults.
    #​1457

Changes
  • Values passed to the __init__() method of attrs classes are now correctly passed to __attrs_pre_init__() instead of their default values (in cases where kw_only was not specified).
    #​1427

  • Added support for Python 3.14 and PEP 749.
    #​1446,
    #​1451

  • attrs.validators.deep_mapping() now allows to leave out either key_validator xor value_validator.
    #​1448

  • attrs.validators.deep_iterator() and attrs.validators.deep_mapping() now accept lists and tuples for all validators and wrap them into a attrs.validators.and_().
    #​1449

  • Added a new experimental way to inspect classes:

    attrs.inspect(cls) returns the effective class-wide parameters that were used by attrs to construct the class.

    The returned class is the same data structure that attrs uses internally to decide how to construct the final class.
    #​1454

  • Fixed annotations for attrs.field(converter=...).
    Previously, a tuple of converters was only accepted if it had exactly one element.
    #​1461

  • The performance of attrs.asdict() has been improved by 45–260%.
    #​1463

  • The performance of attrs.astuple() has been improved by 49–270%.
    #​1469

  • The type annotation for attrs.validators.or_() now allows for different types of validators.

    This was only an issue on Pyright.
    #​1474

v25.3.0

Compare Source

Changes
  • Restore support for generator-based field_transformers.
    #​1417

v25.2.0

Compare Source

Changes
  • Checking mandatory vs non-mandatory attribute order is now performed after the field transformer, since the field transformer may change attributes and/or their order.
    #​1147
  • attrs.make_class() now allows for Unicode class names.
    #​1406
  • Speed up class creation by 30%-50% by compiling methods only once and using a variety of other techniques.
    #​1407
  • The error message if an attribute has both an annotation and a type argument will now disclose what attribute seems to be the problem.
    #​1410

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 was generated by Mend Renovate. View the repository job log.

@codecov
Copy link

codecov bot commented Mar 10, 2025

Codecov Report

✅ All modified and coverable lines are covered by tests.

📢 Thoughts on this report? Let us know!

@renovate renovate bot force-pushed the renovate/attrs-25.x branch 8 times, most recently from 2e545d4 to c3847b6 Compare March 11, 2025 02:29
@renovate renovate bot changed the title Update dependency attrs to v25 Update dependency attrs to v25 - autoclosed Mar 11, 2025
@renovate renovate bot closed this Mar 11, 2025
@renovate renovate bot deleted the renovate/attrs-25.x branch March 11, 2025 02:48
@renovate renovate bot changed the title Update dependency attrs to v25 - autoclosed Update dependency attrs to v25 Mar 12, 2025
@renovate renovate bot reopened this Mar 12, 2025
@renovate renovate bot force-pushed the renovate/attrs-25.x branch from 6843552 to c3847b6 Compare March 12, 2025 12:19
@renovate renovate bot changed the title Update dependency attrs to v25 Update dependency attrs to v25.2.0 Mar 12, 2025
@renovate renovate bot force-pushed the renovate/attrs-25.x branch from c3847b6 to b8ca032 Compare March 12, 2025 14:55
@renovate renovate bot changed the title Update dependency attrs to v25.2.0 Update dependency attrs to v25.3.0 Mar 13, 2025
@renovate renovate bot force-pushed the renovate/attrs-25.x branch from b8ca032 to 10177fe Compare March 13, 2025 11:45
@sonarqubecloud
Copy link

@renovate renovate bot force-pushed the renovate/attrs-25.x branch 2 times, most recently from 816263e to beeb683 Compare June 17, 2025 16:30
@renovate renovate bot force-pushed the renovate/attrs-25.x branch 2 times, most recently from 656e1c8 to bdb079c Compare June 30, 2025 15:30
@sonarqubecloud
Copy link

@renovate renovate bot changed the title Update dependency attrs to v25.3.0 Update dependency attrs to v25.4.0 Oct 6, 2025
@renovate renovate bot force-pushed the renovate/attrs-25.x branch from bdb079c to ebd0623 Compare October 6, 2025 14:33
@sonarqubecloud
Copy link

sonarqubecloud bot commented Oct 6, 2025

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant