-
Notifications
You must be signed in to change notification settings - Fork 1
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
⬆️ 🛠️(deps): update dependency ruff to ^0.9.0 #416
base: dev
Are you sure you want to change the base?
Conversation
Reviewer's Guide by SourceryThis PR updates the Ruff linter dependency from version 0.7.0 to 0.8.0 in the development dependencies. The update includes several breaking changes, rule removals, and new features as detailed in Ruff's changelog. No diagrams generated as the changes look simple and do not need a visual representation. File-Level Changes
Tips and commandsInteracting with Sourcery
Customizing Your ExperienceAccess your dashboard to:
Getting Help
|
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.
We have skipped reviewing this pull request. Here's why:
- It seems to have been created by a bot (hey, renovate[bot]!). We assume it knows what it's doing!
- We don't review packaging changes - Let us know if you'd like us to change this.
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.
Auto Pull Request Review from LlamaPReview
1. Change Overview
1.1 Core Changes
- Primary purpose and scope: This PR updates the
ruff
dependency from version^0.7.0
to^0.8.0
. - Key components modified: The
pyproject.toml
file. - Cross-component impacts: The update may affect linting rules and configurations used throughout the project, potentially requiring adjustments to existing code.
- Business value alignment: Ensures the project uses the latest version of the Ruff linter, which includes new features, bug fixes, and deprecations.
1.2 Technical Architecture
- System design modifications: None.
- Component interaction changes: None.
- Integration points impact: None.
- Dependency changes and implications: The primary dependency change affects the linting process. Developers need to be aware of the new linting rules and adjustments.
2. Deep Technical Analysis
2.1 Code Logic Analysis
pyproject.toml
- Submitted PR Code:
[tool.poetry.group.dev.dependencies] python-semantic-release = ">=8.0.8" -ruff = "^0.7.0" +ruff = "^0.8.0" pre-commit = "^3.3.1"
- Analysis:
- Current logic and potential issues: The change updates the
ruff
dependency to version^0.8.0
. This update includes several breaking changes, such as defaulting to Python 3.9, changes to the line width calculation, and the removal of deprecated rules. - Edge cases and error handling: Developers need to review the changes to ensure compatibility with existing code. For example, the new default Python version may require updates to the codebase to be compliant with Python 3.9.
- Cross-component impact : The update may affect how linting is performed, potentially requiring adjustments to existing configuration files or code.
- Business logic considerations : None.
- Current logic and potential issues: The change updates the
- LlamaPReview Suggested Improvements:
[tool.poetry.group.dev.dependencies] python-semantic-release = ">=8.0.8" ruff = "^0.8.0" pre-commit = "^3.3.1"
- Improvement rationale :
- Technical benefits: Ensures the project uses the latest version of the Ruff linter, which includes new features, bug fixes, and deprecations.
- Business value: Keeps the project up-to-date with the latest tools and practices.
- Risk assessment: Requires careful review and potential adjustments to existing code to ensure compatibility with the new linting rules.
2.2 Implementation Quality
-
Code Structure:
- Organization and modularity: The change is well-organized and modular, affecting only the relevant section of the
pyproject.toml
file. - Design pattern adherence: N/A.
- Reusability aspects: N/A.
- Maintainability factors: The change is straightforward and easy to maintain.
- Organization and modularity: The change is well-organized and modular, affecting only the relevant section of the
-
Error Handling:
- Exception scenarios coverage: N/A.
- Recovery mechanisms: N/A.
- Logging and monitoring: N/A.
- User experience impact: N/A.
-
Performance Considerations:
- Resource utilization: N/A.
- Scalability aspects: N/A.
- Bottleneck analysis: N/A.
- Optimization opportunities: N/A.
3. Risk Assessment
3.1 Critical Issues
🔴 P0 (Must Fix):
- Issue: None.
- Impact: None.
- Resolution: None.
3.2 Important Improvements
🟡 P1 (Should Fix):
- Issue: The update to Ruff
^0.8.0
includes breaking changes that may affect existing code. - Current Impact:
- Performance implications: None.
- Maintenance overhead: Requires review and potential adjustments to existing code.
- Future scalability: None.
- Suggested Solution:
- Implementation approach: Review the Ruff changelog and update existing code as necessary to comply with the new linting rules.
- Migration strategy: Test the updated codebase thoroughly to ensure compatibility.
- Testing considerations: Ensure comprehensive test coverage to catch any issues introduced by the update.
3.3 Minor Suggestions
🟢 P2 (Consider):
- Area: Documentation.
- Improvement Opportunity:
- Code quality enhancement: Document the changes and any necessary adjustments in the project's documentation.
- Best practice alignment: Ensure that the project's documentation reflects the latest practices and tools used.
- Documentation updates: Update the project's documentation to reflect the changes introduced by the Ruff update.
4. Requirements Analysis
4.1 Functional Coverage
- Requirements mapping:
- Implemented features: The update to Ruff
^0.8.0
ensures the project uses the latest linting tools and practices. - Missing elements: None.
- Edge cases handling: None.
- Implemented features: The update to Ruff
- Business Logic:
- Use case coverage: N/A.
- Business rule implementation: N/A.
- Data flow correctness: N/A.
4.2 Non-functional Aspects
- Performance metrics: N/A.
- Security considerations: N/A.
- Scalability factors: N/A.
- Maintainability aspects: The change is straightforward and easy to maintain.
5. Testing Strategy
- Test Coverage:
- Unit test requirements: Ensure comprehensive test coverage to catch any issues introduced by the Ruff update.
- Integration test scenarios: Test the updated codebase thoroughly to ensure compatibility.
- Edge case validation: Validate edge cases that may be affected by the new linting rules.
- Quality Metrics:
- Current coverage: N/A.
- Critical paths: N/A.
- Performance benchmarks: N/A.
6. Final Assessment
6.1 Key Action Items
-
Critical Changes (P0):
[None] -
Important Improvements (P1):
- Review the Ruff changelog and update existing code as necessary to comply with the new linting rules.
- Test the updated codebase thoroughly to ensure compatibility.
- Ensure comprehensive test coverage to catch any issues introduced by the Ruff update.
-
Suggested Enhancements (P2):
- Document the changes and any necessary adjustments in the project's documentation.
- Ensure that the project's documentation reflects the latest practices and tools used.
- Update the project's documentation to reflect the changes introduced by the Ruff update.
6.2 Overall Evaluation
- Technical assessment: The update to Ruff
^0.8.0
is straightforward but requires careful review and potential adjustments to existing code to ensure compatibility with the new linting rules. - Business impact: Keeps the project up-to-date with the latest linting tools and practices.
- Risk evaluation: Requires careful review and potential adjustments to existing code to ensure compatibility with the new linting rules.
- Implementation quality: The change is well-organized, modular, and easy to maintain.
💡 LlamaPReview Community
Have feedback on this AI Code review tool? Join our GitHub Discussions to share your thoughts and help shape the future of LlamaPReview.
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## dev #416 +/- ##
=========================================
Coverage 100.00% 100.00%
=========================================
Files 6 6
Lines 142 142
=========================================
Hits 142 142 ☔ View full report in Codecov by Sentry. |
772588e
to
d2a4e91
Compare
This PR contains the following updates:
^0.7.0
->^0.9.0
Release Notes
astral-sh/ruff (ruff)
v0.9.0
Compare Source
Check out the blog post for a migration guide and overview of the changes!
Breaking changes
Ruff now formats your code according to the 2025 style guide. As a result, your code might now get formatted differently. See the formatter section for a detailed list of changes.
This release doesn’t remove or remap any existing stable rules.
Stabilization
The following rules have been stabilized and are no longer in preview:
stdlib-module-shadowing
(A005
).This rule has also been renamed: previously, it was called
builtin-module-shadowing
.builtin-lambda-argument-shadowing
(A006
)slice-to-remove-prefix-or-suffix
(FURB188
)boolean-chained-comparison
(PLR1716
)decimal-from-float-literal
(RUF032
)post-init-default
(RUF033
)useless-if-else
(RUF034
)The following behaviors have been stabilized:
pytest-parametrize-names-wrong-type
(PT006
): Detectpytest.parametrize
calls outside decorators and calls with keyword arguments.module-import-not-at-top-of-file
(E402
): Ignorepytest.importorskip
calls between import statements.mutable-dataclass-default
(RUF008
) andfunction-call-in-dataclass-default-argument
(RUF009
): Add support forattrs
.bad-version-info-comparison
(PYI006
): Extend the rule to check non-stub files.The following fixes or improvements to fixes have been stabilized:
redundant-numeric-union
(PYI041
)duplicate-union-members
(PYI016
)Formatter
This release introduces the new 2025 stable style (#13371), stabilizing the following changes:
ISC001
incompatibility warning (#15123)assert
message over breaking the assertion expression (#9457)if
guards inmatch
case
clauses (#13513)match
case
patterns (#6933)if
keyword for comprehensions where the condition has a leading comment (#12282)with
statements with a single context manager for Python 3.8 or older (#10276)max-doc-code-line-length = "dynamic"
(#13523)Preview features
flake8-bugbear
] Implementclass-as-data-structure
(B903
) (#9601)flake8-type-checking
] Applyquoted-type-alias
more eagerly inTYPE_CHECKING
blocks and ignore it in stubs (TC008
) (#15180)pylint
] Ignoreeq-without-hash
in stub files (PLW1641
) (#15310)pyupgrade
] SplitUP007
into two individual rules:UP007
forUnion
andUP045
forOptional
(UP007
,UP045
) (#15313)ruff
] New rule that detects classes that are both an enum and adataclass
(RUF049
) (#15299)ruff
] RecodeRUF025
toRUF037
(RUF037
) (#15258)Rule changes
flake8-builtins
] Ignorestdlib-module-shadowing
in stub files(A005
) (#15350)flake8-return
] Add support for functions returningtyping.Never
(RET503
) (#15298)Server
logLevel
server settingwhich defaults to
info
. This addresses the issue where users were notified about an error and told to consult the log, but it didn’t contain any messages. (#15232)CLI
--config key=value
when thekey
is for a table and it’s a simplevalue
Bug fixes
eradicate
] Ignore metadata blocks directly followed by normal blocks (ERA001
) (#15330)flake8-django
] Recognize other magic methods (DJ012
) (#15365)pycodestyle
] Avoid false positives related to type aliases (E252
) (#15356)pydocstyle
] Avoid treating newline-separated sections as sub-sections (D405
) (#15311)pyflakes
] Remove call when removing final argument fromformat
(F523
) (#15309)refurb
] Mark fix as unsafe when the right-hand side is a string (FURB171
) (#15273)ruff
] Treat)
as a regex metacharacter (RUF043
,RUF055
) (#15318)ruff
] Parenthesize theint
-call argument when removing theint
call would change semantics (RUF046
) (#15277)v0.8.6
Compare Source
Preview features
format
]: Preserve multiline implicit concatenated strings in docstring positions (#15126)ruff
] Add rule to detect empty literal in deque call (RUF025
) (#15104)ruff
] Avoid reporting whenndigits
is possibly negative (RUF057
) (#15234)Rule changes
flake8-todos
] remove issue code length restriction (TD003
) (#15175)pyflakes
] Ignore errors in@no_type_check
string annotations (F722
,F821
) (#15215)CLI
--verbose
(#15237)Bug fixes
ruff
] Avoid syntax error when removing int over multiple lines (RUF046
) (#15230)pyupgrade
] Revert "Add all PEP-585 names toUP006
rule" (#15250)v0.8.5
Compare Source
Preview features
airflow
] Extend names moved from core to provider (AIR303
) (#15145, #15159, #15196, #15216)airflow
] Extend rule to check class attributes, methods, arguments (AIR302
) (#15054, #15083)fastapi
] UpdateFAST002
to check keyword-only arguments (#15119)flake8-type-checking
] DisableTC006
andTC007
in stub files (#15179)pylint
] Detect nested methods correctly (PLW1641
) (#15032)ruff
] Detect more strict-integer expressions (RUF046
) (#14833)ruff
] Implementfalsy-dict-get-fallback
(RUF056
) (#15160)ruff
] Implementunnecessary-round
(RUF057
) (#14828)Rule changes
TypedDict
keys as non-type-expressions (#15073)flake8-comprehensions
] SkipC416
if comprehension contains unpacking (#14909)flake8-pie
] Allowcast(SomeType, ...)
(PIE796
) (#15141)flake8-simplify
] More precise inference for dictionaries (SIM300
) (#15164)flake8-use-pathlib
] Catch redundant joins inPTH201
and avoid syntax errors (#15177)pycodestyle
] Preserve original value format (E731
) (#15097)pydocstyle
] Split on first whitespace character (D403
) (#15082)pyupgrade
] Add all PEP-585 names toUP006
rule (#5454)Configuration
flake8-type-checking
] Improve flexibility ofruntime-evaluated-decorators
(#15204)pydocstyle
] Add setting to ignore missing documentation for*args
and**kwargs
parameters (D417
) (#15210)ruff
] Add an allowlist forunsafe-markup-use
(RUF035
) (#15076)Bug fixes
TypeChecker
for detectingfastapi
routes (#15093)pycodestyle
] Avoid false positives and negatives related to type parameter default syntax (E225
,E251
) (#15214)Documentation
shebang-not-executable
(EXE001
) and add git+windows solution to executable bit (#15208)v0.8.4
Compare Source
Preview features
airflow
] ExtendAIR302
with additional functions and classes (#15015)airflow
] Implementmoved-to-provider-in-3
for modules that has been moved to Airflow providers (AIR303
) (#14764)flake8-use-pathlib
] Extend check for invalid path suffix to include the case"."
(PTH210
) (#14902)perflint
] Fix panic inPERF401
when list variable is after thefor
loop (#14971)perflint
] Simplify finding the loop target inPERF401
(#15025)pylint
] Preserve original value format (PLR6104
) (#14978)ruff
] Avoid false positives forRUF027
for typing context bindings (#15037)ruff
] Check for ambiguous pattern passed topytest.raises()
(RUF043
) (#14966)Rule changes
flake8-bandit
] CheckS105
for annotated assignment (#15059)flake8-pyi
] More autofixes forredundant-none-literal
(PYI061
) (#14872)pydocstyle
] Skip leading whitespace forD403
(#14963)ruff
] SkipSQLModel
base classes formutable-class-default
(RUF012
) (#14949)Bug
perflint
] Parenthesize walrus expressions in autofix formanual-list-comprehension
(PERF401
) (#15050)Server
v0.8.3
Compare Source
Preview features
airflow
] Add fix to remove deprecated keyword arguments (AIR302
) (#14887)airflow
]: Extend rule to include deprecated names for Airflow 3.0 (AIR302
) (#14765 and #14804)flake8-bugbear
] Improve error messages forexcept*
(B025
,B029
,B030
,B904
) (#14815)flake8-bugbear
]itertools.batched()
without explicitstrict
(B911
) (#14408)flake8-use-pathlib
] Dotless suffix passed toPath.with_suffix()
(PTH210
) (#14779)pylint
] Include parentheses and multiple comparators in check forboolean-chained-comparison
(PLR1716
) (#14781)ruff
] Do not simplifyround()
calls (RUF046
) (#14832)ruff
] Don't emitused-dummy-variable
on function parameters (RUF052
) (#14818)ruff
] Implementif-key-in-dict-del
(RUF051
) (#14553)ruff
] Mark autofix forRUF052
as always unsafe (#14824)ruff
] Teach autofix forused-dummy-variable
about TypeVars etc. (RUF052
) (#14819)Rule changes
flake8-bugbear
] Offer unsafe autofix forno-explicit-stacklevel
(B028
) (#14829)flake8-pyi
] Skip all type definitions instring-or-bytes-too-long
(PYI053
) (#14797)pyupgrade
] Do not report when a UTF-8 comment is followed by a non-UTF-8 one (UP009
) (#14728)pyupgrade
] Mark fixes forconvert-typed-dict-functional-to-class
andconvert-named-tuple-functional-to-class
as unsafe if they will remove comments (UP013
,UP014
) (#14842)Bug fixes
except
andexcept*
(#14895)flake8-bugbear
] FixB028
to allowstacklevel
to be explicitly assigned as a positional argument (#14868)flake8-bugbear
] SkipB028
ifwarnings.warn
is called with*args
or**kwargs
(#14870)flake8-comprehensions
] Skip iterables with named expressions inunnecessary-map
(C417
) (#14827)flake8-pyi
] Also removeself
andcls
's annotation (PYI034
) (#14801)flake8-pytest-style
] Fixpytest-parametrize-names-wrong-type
(PT006
) to edit bothargnames
andargvalues
if both of them are single-element tuples/lists (#14699)perflint
] Improve autofix forPERF401
(#14369)pylint
] FixPLW1508
false positive for default string created via a mult operation (#14841)v0.8.2
Compare Source
Preview features
airflow
] Avoid deprecated values (AIR302
) (#14582)airflow
] Extend removed names forAIR302
(#14734)ruff
] Extendunnecessary-regular-expression
to non-literal strings (RUF055
) (#14679)ruff
] Implementused-dummy-variable
(RUF052
) (#14611)ruff
] Implementunnecessary-cast-to-int
(RUF046
) (#14697)Rule changes
airflow
] CheckAIR001
from builtin or providersoperators
module (#14631)flake8-pytest-style
] Remove@
inpytest.mark.parametrize
rule messages (#14770)pandas-vet
] Skip rules if thepanda
module hasn't been seen (#14671)pylint
] Fix false negatives forascii
andsorted
inlen-as-condition
(PLC1802
) (#14692)refurb
] Guardhashlib
imports and markhashlib-digest-hex
fix as safe (FURB181
) (#14694)Configuration
flake8-import-conventions
] Improve syntax check for aliases supplied in configuration forunconventional-import-alias
(ICN001
) (#14745)Bug fixes
@no_type_check
contexts (F821
,F722
) (#14615) (#14726)pep8-naming
] Avoid false positive forclass Bar(type(foo))
(N804
) (#14683)pycodestyle
] Handle f-strings properly forinvalid-escape-sequence
(W605
) (#14748)pylint
] Ignore@overload
inPLR0904
(#14730)refurb
] Handle non-finite decimals inverbose-decimal-constructor
(FURB157
) (#14596)ruff
] Avoid emittingassignment-in-assert
when all references to the assigned variable are themselves insideassert
s (RUF018
) (#14661)Documentation
flake8-use-pathlib
rules (#14741)flake8-comprehensions
rules (#14729)flake8-type-checking
] ExpandsTC006
docs to better explain itself (#14749)v0.8.1
Compare Source
Preview features
**
) in overlong f-string expressions (#14489)airflow
] Avoid implicitschedule
argument toDAG
and@dag
(AIR301
) (#14581)flake8-builtins
] Exempt private built-in modules (A005
) (#14505)flake8-pytest-style
] Fixpytest.mark.parametrize
rules to check calls instead of decorators (#14515)flake8-type-checking
] Implementruntime-cast-value
(TC006
) (#14511)flake8-type-checking
] Implementunquoted-type-alias
(TC007
) andquoted-type-alias
(TC008
) (#12927)flake8-use-pathlib
] RecommendPath.iterdir()
overos.listdir()
(PTH208
) (#14509)pylint
] Extendinvalid-envvar-default
to detectos.environ.get
(PLW1508
) (#14512)pylint
] Implementlen-test
(PLC1802
) (#14309)refurb
] Fix bug where methods defined using lambdas were flagged byFURB118
(#14639)ruff
] Auto-addr
prefix when string has no backslashes forunraw-re-pattern
(RUF039
) (#14536)ruff
] Implementinvalid-assert-message-literal-argument
(RUF040
) (#14488)ruff
] Implementunnecessary-nested-literal
(RUF041
) (#14323)ruff
] Implementunnecessary-regular-expression
(RUF055
) (#14659)Rule changes
pep8-naming
] Eliminate false positives for single-letter names (N811
,N814
) (#14584)pyflakes
] Avoid false positives in@no_type_check
contexts (F821
,F722
) (#14615)ruff
] Detect redirected-noqa in file-level comments (RUF101
) (#14635)ruff
] Mark fixes forunsorted-dunder-all
andunsorted-dunder-slots
as unsafe when there are complex comments in the sequence (RUF022
,RUF023
) (#14560)Bug fixes
None | None
forredundant-none-literal
(PYI061
) andnever-union
(RUF020
) (#14583, #14589)flake8-bugbear
] Fixmutable-contextvar-default
to resolve annotated function calls properly (B039
) (#14532)flake8-pyi
,ruff
] Fix traversal of nested literals and unions (PYI016
,PYI051
,PYI055
,PYI062
,RUF041
) (#14641)flake8-pyi
] Avoid rewriting invalid type expressions inunnecessary-type-union
(PYI055
) (#14660)flake8-type-checking
] Avoid syntax errors and type checking problem for quoted annotations autofix (TC003
,TC006
) (#14634)pylint
] Do not wrap function calls in parentheses in the fix for unnecessary-dunder-call (PLC2801
) (#14601)ruff
] Handleattrs
'sauto_attribs
correctly (RUF009
) (#14520)v0.8.0
Compare Source
Check out the blog post for a migration guide and overview of the changes!
Breaking changes
See also, the "Remapped rules" section which may result in disabled rules.
Default to Python 3.9
Ruff now defaults to Python 3.9 instead of 3.8 if no explicit Python version is configured using
ruff.target-version
orproject.requires-python
(#13896)Changed location of
pydoclint
diagnosticspydoclint
diagnostics now point to the first-line of the problematic docstring. Previously, this was not the case.If you've opted into these preview rules but have them suppressed using
noqa
comments insome places, this change may mean that you need to move the
noqa
suppressioncomments. Most users should be unaffected by this change.
Use XDG (i.e.
~/.local/bin
) instead of the Cargo home directory in the standalone installerPreviously, Ruff's installer used
$CARGO_HOME
or~/.cargo/bin
for its target install directory. Now, Ruff will be installed into$XDG_BIN_HOME
,$XDG_DATA_HOME/../bin
, or~/.local/bin
(in that order).This change is only relevant to users of the standalone Ruff installer (using the shell or PowerShell script). If you installed Ruff using uv or pip, you should be unaffected.
Changes to the line width calculation
Ruff now uses a new version of the unicode-width Rust crate to calculate the line width. In very rare cases, this may lead to lines containing Unicode characters being reformatted, or being considered too long when they were not before (
E501
).Removed Rules
The following deprecated rules have been removed:
missing-type-self
(ANN101
)missing-type-cls
(ANN102
)syntax-error
(E999
)pytest-missing-fixture-name-underscore
(PT004
)pytest-incorrect-fixture-name-underscore
(PT005
)unpacked-list-comprehension
(UP027
)Remapped rules
The following rules have been remapped to new rule codes:
flake8-type-checking
:TCH
toTC
Stabilization
The following rules have been stabilized and are no longer in preview:
builtin-import-shadowing
(A004
)mutable-contextvar-default
(B039
)fast-api-redundant-response-model
(FAST001
)fast-api-non-annotated-dependency
(FAST002
)dict-index-missing-items
(PLC0206
)pep484-style-positional-only-argument
(PYI063
)redundant-final-literal
(PYI064
)bad-version-info-order
(PYI066
)parenthesize-chained-operators
(RUF021
)unsorted-dunder-all
(RUF022
)unsorted-dunder-slots
(RUF023
)assert-with-print-message
(RUF030
)unnecessary-default-type-args
(UP043
)The following behaviors have been stabilized:
ambiguous-variable-name
(E741
): Violations in stub files are now ignored. Stub authors typically don't control variable names.printf-string-formatting
(UP031
): Report allprintf
-like usages even if no autofix is availableThe following fixes have been stabilized:
zip-instead-of-pairwise
(RUF007
)Preview features
flake8-datetimez
] Exemptmin.time()
andmax.time()
(DTZ901
) (#14394)flake8-pie
] Mark fix as unsafe if the following statement is a string literal (PIE790
) (#14393)flake8-pyi
] New ruleredundant-none-literal
(PYI061
) (#14316)flake8-pyi
] Add autofix forredundant-numeric-union
(PYI041
) (#14273)ruff
] New rulemap-int-version-parsing
(RUF048
) (#14373)ruff
] New ruleredundant-bool-literal
(RUF038
) (#14319)ruff
] New ruleunraw-re-pattern
(RUF039
) (#14446)pycodestyle
] Exemptpytest.importorskip()
calls (E402
) (#14474)pylint
] Autofix suggests using sets when possible (PLR1714
) (#14372)Rule changes
invalid-pyproject-toml
(RUF200
): Updated to reflect the provisionally accepted PEP 639.flake8-pyi
] Avoid panic in unfixable case (PYI041
) (#14402)flake8-type-checking
] Correctly handle quotes in subscript expression when generating an autofix (#14371)pylint
] Suggest correct autofix for__contains__
(PLC2801
) (#14424)Configuration
ignore
s a rule that has been removed (#14435)lint.flake8-import-conventions.aliases
only uses valid module names and aliases (#14477)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.
This PR was generated by Mend Renovate. View the repository job log.