- Sponsor
-
Notifications
You must be signed in to change notification settings - Fork 225
Commit a594a14
feat: allow Ruff 0.9 (#1192)
This PR contains the following updates:
| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| [ruff](https://docs.astral.sh/ruff)
([source](https://redirect.github.com/astral-sh/ruff),
[changelog](https://redirect.github.com/astral-sh/ruff/blob/main/CHANGELOG.md))
| `>=0.2,<0.9` -> `>=0.2,<0.10` |
[](https://docs.renovatebot.com/merge-confidence/)
|
[](https://docs.renovatebot.com/merge-confidence/)
|
[](https://docs.renovatebot.com/merge-confidence/)
|
[](https://docs.renovatebot.com/merge-confidence/)
|
---
### Release Notes
<details>
<summary>astral-sh/ruff (ruff)</summary>
###
[`v0.9.0`](https://redirect.github.com/astral-sh/ruff/blob/HEAD/CHANGELOG.md#090)
[Compare
Source](https://redirect.github.com/astral-sh/ruff/compare/0.8.6...0.9.0)
Check out the [blog post](https://astral.sh/blog/ruff-v0.9.0) 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`](https://docs.astral.sh/ruff/rules/stdlib-module-shadowing/)
(`A005`).
This rule has also been renamed: previously, it was called
`builtin-module-shadowing`.
-
[`builtin-lambda-argument-shadowing`](https://docs.astral.sh/ruff/rules/builtin-lambda-argument-shadowing/)
(`A006`)
-
[`slice-to-remove-prefix-or-suffix`](https://docs.astral.sh/ruff/rules/slice-to-remove-prefix-or-suffix/)
(`FURB188`)
-
[`boolean-chained-comparison`](https://docs.astral.sh/ruff/rules/boolean-chained-comparison/)
(`PLR1716`)
-
[`decimal-from-float-literal`](https://docs.astral.sh/ruff/rules/decimal-from-float-literal/)
(`RUF032`)
-
[`post-init-default`](https://docs.astral.sh/ruff/rules/post-init-default/)
(`RUF033`)
-
[`useless-if-else`](https://docs.astral.sh/ruff/rules/useless-if-else/)
(`RUF034`)
The following behaviors have been stabilized:
-
[`pytest-parametrize-names-wrong-type`](https://docs.astral.sh/ruff/rules/pytest-parametrize-names-wrong-type/)
(`PT006`): Detect
[`pytest.parametrize`](https://docs.pytest.org/en/7.1.x/how-to/parametrize.html#parametrize)
calls outside decorators and calls with keyword arguments.
-
[`module-import-not-at-top-of-file`](https://docs.astral.sh/ruff/rules/module-import-not-at-top-of-file/)
(`E402`): Ignore
[`pytest.importorskip`](https://docs.pytest.org/en/7.1.x/reference/reference.html#pytest-importorskip)
calls between import statements.
-
[`mutable-dataclass-default`](https://docs.astral.sh/ruff/rules/mutable-dataclass-default/)
(`RUF008`) and
[`function-call-in-dataclass-default-argument`](https://docs.astral.sh/ruff/rules/function-call-in-dataclass-default-argument/)
(`RUF009`): Add support for [`attrs`](https://www.attrs.org/en/stable/).
-
[`bad-version-info-comparison`](https://docs.astral.sh/ruff/rules/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`](https://docs.astral.sh/ruff/rules/redundant-numeric-union/)
(`PYI041`)
-
[`duplicate-union-members`](https://docs.astral.sh/ruff/rules/duplicate-union-member/)
(`PYI016`)
##### Formatter
This release introduces the new 2025 stable style
([#​13371](https://redirect.github.com/astral-sh/ruff/issues/13371)),
stabilizing the following changes:
- Format expressions in f-string elements
([#​7594](https://redirect.github.com/astral-sh/ruff/issues/7594))
- Alternate quotes for strings inside f-strings
([#​13860](https://redirect.github.com/astral-sh/ruff/pull/13860))
- Preserve the casing of hex codes in f-string debug expressions
([#​14766](https://redirect.github.com/astral-sh/ruff/issues/14766))
- Choose the quote style for each string literal in an implicitly
concatenated f-string rather than for the entire string
([#​13539](https://redirect.github.com/astral-sh/ruff/pull/13539))
- Automatically join an implicitly concatenated string into a single
string literal if it fits on a single line
([#​9457](https://redirect.github.com/astral-sh/ruff/issues/9457))
- Remove the
[`ISC001`](https://docs.astral.sh/ruff/rules/single-line-implicit-string-concatenation/)
incompatibility warning
([#​15123](https://redirect.github.com/astral-sh/ruff/pull/15123))
- Prefer parenthesizing the `assert` message over breaking the assertion
expression
([#​9457](https://redirect.github.com/astral-sh/ruff/issues/9457))
- Automatically parenthesize over-long `if` guards in `match` `case`
clauses
([#​13513](https://redirect.github.com/astral-sh/ruff/pull/13513))
- More consistent formatting for `match` `case` patterns
([#​6933](https://redirect.github.com/astral-sh/ruff/issues/6933))
- Avoid unnecessary parentheses around return type annotations
([#​13381](https://redirect.github.com/astral-sh/ruff/pull/13381))
- Keep the opening parentheses on the same line as the `if` keyword for
comprehensions where the condition has a leading comment
([#​12282](https://redirect.github.com/astral-sh/ruff/pull/12282))
- More consistent formatting for `with` statements with a single context
manager for Python 3.8 or older
([#​10276](https://redirect.github.com/astral-sh/ruff/pull/10276))
- Correctly calculate the line-width for code blocks in docstrings when
using `max-doc-code-line-length = "dynamic"`
([#​13523](https://redirect.github.com/astral-sh/ruff/pull/13523))
##### Preview features
- \[`flake8-bugbear`] Implement `class-as-data-structure` (`B903`)
([#​9601](https://redirect.github.com/astral-sh/ruff/pull/9601))
- \[`flake8-type-checking`] Apply `quoted-type-alias` more eagerly in
`TYPE_CHECKING` blocks and ignore it in stubs (`TC008`)
([#​15180](https://redirect.github.com/astral-sh/ruff/pull/15180))
- \[`pylint`] Ignore `eq-without-hash` in stub files (`PLW1641`)
([#​15310](https://redirect.github.com/astral-sh/ruff/pull/15310))
- \[`pyupgrade`] Split `UP007` into two individual rules: `UP007` for
`Union` and `UP045` for `Optional` (`UP007`, `UP045`)
([#​15313](https://redirect.github.com/astral-sh/ruff/pull/15313))
- \[`ruff`] New rule that detects classes that are both an enum and a
`dataclass` (`RUF049`)
([#​15299](https://redirect.github.com/astral-sh/ruff/pull/15299))
- \[`ruff`] Recode `RUF025` to `RUF037` (`RUF037`)
([#​15258](https://redirect.github.com/astral-sh/ruff/pull/15258))
##### Rule changes
- \[`flake8-builtins`] Ignore
[`stdlib-module-shadowing`](https://docs.astral.sh/ruff/rules/stdlib-module-shadowing/)
in stub files(`A005`)
([#​15350](https://redirect.github.com/astral-sh/ruff/pull/15350))
- \[`flake8-return`] Add support for functions returning `typing.Never`
(`RET503`)
([#​15298](https://redirect.github.com/astral-sh/ruff/pull/15298))
##### Server
- Improve the observability by removing the need for the ["trace"
value](https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#traceValue)
to turn on or off logging. The server logging is solely controlled using
the [`logLevel` server
setting](https://docs.astral.sh/ruff/editors/settings/#loglevel)
which 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](https://redirect.github.com/astral-sh/ruff/pull/15232))
- Ignore diagnostics from other sources for code action requests
([#​15373](https://redirect.github.com/astral-sh/ruff/pull/15373))
##### CLI
- Improve the error message for `--config key=value` when the `key` is
for a table and it’s a simple `value`
##### Bug fixes
- \[`eradicate`] Ignore metadata blocks directly followed by normal
blocks (`ERA001`)
([#​15330](https://redirect.github.com/astral-sh/ruff/pull/15330))
- \[`flake8-django`] Recognize other magic methods (`DJ012`)
([#​15365](https://redirect.github.com/astral-sh/ruff/pull/15365))
- \[`pycodestyle`] Avoid false positives related to type aliases
(`E252`)
([#​15356](https://redirect.github.com/astral-sh/ruff/pull/15356))
- \[`pydocstyle`] Avoid treating newline-separated sections as
sub-sections (`D405`)
([#​15311](https://redirect.github.com/astral-sh/ruff/pull/15311))
- \[`pyflakes`] Remove call when removing final argument from `format`
(`F523`)
([#​15309](https://redirect.github.com/astral-sh/ruff/pull/15309))
- \[`refurb`] Mark fix as unsafe when the right-hand side is a string
(`FURB171`)
([#​15273](https://redirect.github.com/astral-sh/ruff/pull/15273))
- \[`ruff`] Treat `)` as a regex metacharacter (`RUF043`, `RUF055`)
([#​15318](https://redirect.github.com/astral-sh/ruff/pull/15318))
- \[`ruff`] Parenthesize the `int`-call argument when removing the `int`
call would change semantics (`RUF046`)
([#​15277](https://redirect.github.com/astral-sh/ruff/pull/15277))
###
[`v0.8.6`](https://redirect.github.com/astral-sh/ruff/blob/HEAD/CHANGELOG.md#086)
[Compare
Source](https://redirect.github.com/astral-sh/ruff/compare/0.8.5...0.8.6)
##### Preview features
- \[`format`]: Preserve multiline implicit concatenated strings in
docstring positions
([#​15126](https://redirect.github.com/astral-sh/ruff/pull/15126))
- \[`ruff`] Add rule to detect empty literal in deque call (`RUF025`)
([#​15104](https://redirect.github.com/astral-sh/ruff/pull/15104))
- \[`ruff`] Avoid reporting when `ndigits` is possibly negative
(`RUF057`)
([#​15234](https://redirect.github.com/astral-sh/ruff/pull/15234))
##### Rule changes
- \[`flake8-todos`] remove issue code length restriction (`TD003`)
([#​15175](https://redirect.github.com/astral-sh/ruff/pull/15175))
- \[`pyflakes`] Ignore errors in `@no_type_check` string annotations
(`F722`, `F821`)
([#​15215](https://redirect.github.com/astral-sh/ruff/pull/15215))
##### CLI
- Show errors for attempted fixes only when passed `--verbose`
([#​15237](https://redirect.github.com/astral-sh/ruff/pull/15237))
##### Bug fixes
- \[`ruff`] Avoid syntax error when removing int over multiple lines
(`RUF046`)
([#​15230](https://redirect.github.com/astral-sh/ruff/pull/15230))
- \[`pyupgrade`] Revert "Add all PEP-585 names to `UP006` rule"
([#​15250](https://redirect.github.com/astral-sh/ruff/pull/15250))
###
[`v0.8.5`](https://redirect.github.com/astral-sh/ruff/blob/HEAD/CHANGELOG.md#085)
[Compare
Source](https://redirect.github.com/astral-sh/ruff/compare/0.8.4...0.8.5)
##### Preview features
- \[`airflow`] Extend names moved from core to provider (`AIR303`)
([#​15145](https://redirect.github.com/astral-sh/ruff/pull/15145),
[#​15159](https://redirect.github.com/astral-sh/ruff/pull/15159),
[#​15196](https://redirect.github.com/astral-sh/ruff/pull/15196),
[#​15216](https://redirect.github.com/astral-sh/ruff/pull/15216))
- \[`airflow`] Extend rule to check class attributes, methods, arguments
(`AIR302`)
([#​15054](https://redirect.github.com/astral-sh/ruff/pull/15054),
[#​15083](https://redirect.github.com/astral-sh/ruff/pull/15083))
- \[`fastapi`] Update `FAST002` to check keyword-only arguments
([#​15119](https://redirect.github.com/astral-sh/ruff/pull/15119))
- \[`flake8-type-checking`] Disable `TC006` and `TC007` in stub files
([#​15179](https://redirect.github.com/astral-sh/ruff/pull/15179))
- \[`pylint`] Detect nested methods correctly (`PLW1641`)
([#​15032](https://redirect.github.com/astral-sh/ruff/pull/15032))
- \[`ruff`] Detect more strict-integer expressions (`RUF046`)
([#​14833](https://redirect.github.com/astral-sh/ruff/pull/14833))
- \[`ruff`] Implement `falsy-dict-get-fallback` (`RUF056`)
([#​15160](https://redirect.github.com/astral-sh/ruff/pull/15160))
- \[`ruff`] Implement `unnecessary-round` (`RUF057`)
([#​14828](https://redirect.github.com/astral-sh/ruff/pull/14828))
##### Rule changes
- Visit PEP 764 inline `TypedDict` keys as non-type-expressions
([#​15073](https://redirect.github.com/astral-sh/ruff/pull/15073))
- \[`flake8-comprehensions`] Skip `C416` if comprehension contains
unpacking
([#​14909](https://redirect.github.com/astral-sh/ruff/pull/14909))
- \[`flake8-pie`] Allow `cast(SomeType, ...)` (`PIE796`)
([#​15141](https://redirect.github.com/astral-sh/ruff/pull/15141))
- \[`flake8-simplify`] More precise inference for dictionaries
(`SIM300`)
([#​15164](https://redirect.github.com/astral-sh/ruff/pull/15164))
- \[`flake8-use-pathlib`] Catch redundant joins in `PTH201` and avoid
syntax errors
([#​15177](https://redirect.github.com/astral-sh/ruff/pull/15177))
- \[`pycodestyle`] Preserve original value format (`E731`)
([#​15097](https://redirect.github.com/astral-sh/ruff/pull/15097))
- \[`pydocstyle`] Split on first whitespace character (`D403`)
([#​15082](https://redirect.github.com/astral-sh/ruff/pull/15082))
- \[`pyupgrade`] Add all PEP-585 names to `UP006` rule
([#​5454](https://redirect.github.com/astral-sh/ruff/pull/5454))
##### Configuration
- \[`flake8-type-checking`] Improve flexibility of
`runtime-evaluated-decorators`
([#​15204](https://redirect.github.com/astral-sh/ruff/pull/15204))
- \[`pydocstyle`] Add setting to ignore missing documentation for
`*args` and `**kwargs` parameters (`D417`)
([#​15210](https://redirect.github.com/astral-sh/ruff/pull/15210))
- \[`ruff`] Add an allowlist for `unsafe-markup-use` (`RUF035`)
([#​15076](https://redirect.github.com/astral-sh/ruff/pull/15076))
##### Bug fixes
- Fix type subscript on older python versions
([#​15090](https://redirect.github.com/astral-sh/ruff/pull/15090))
- Use `TypeChecker` for detecting `fastapi` routes
([#​15093](https://redirect.github.com/astral-sh/ruff/pull/15093))
- \[`pycodestyle`] Avoid false positives and negatives related to type
parameter default syntax (`E225`, `E251`)
([#​15214](https://redirect.github.com/astral-sh/ruff/pull/15214))
##### Documentation
- Fix incorrect doc in `shebang-not-executable` (`EXE001`) and add
git+windows solution to executable bit
([#​15208](https://redirect.github.com/astral-sh/ruff/pull/15208))
- Rename rules currently not conforming to naming convention
([#​15102](https://redirect.github.com/astral-sh/ruff/pull/15102))
</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 was generated by [Mend Renovate](https://mend.io/renovate/).
View the [repository job
log](https://developer.mend.io/github/openapi-generators/openapi-python-client).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOS45Mi4wIiwidXBkYXRlZEluVmVyIjoiMzkuOTIuMCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>2 files changed
+21
-21
lines changed+20-20
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.
+1-1
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
14 | 14 |
| |
15 | 15 |
| |
16 | 16 |
| |
17 |
| - | |
| 17 | + | |
18 | 18 |
| |
19 | 19 |
| |
20 | 20 |
| |
|
0 commit comments