Skip to content

chore(deps): update dependency wemake-python-styleguide to v1 #78

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

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Dec 28, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
wemake-python-styleguide (source) 0.18.0 -> 1.1.0 age adoption passing confidence

Release Notes

wemake-services/wemake-python-styleguide (wemake-python-styleguide)

v1.1.0

Compare Source

Command line utility

This version introduces wps CLI tool.
wps explain <code> command can be used to access WPS
violation docs (same as on website) but without any internet access.

Features
  • Adds WPS476: forbids to use await expressions in for loops, #​1600
  • Adds WPS477: forbids TypeVarTuple after a TypeVar with a default, #​3265
Bugfixes
  • Fixes WPS115 false-positive on Enum attributes, #​3238
  • Removes duplicated WPS312, #​3239
  • Fixes WPS432, now it shows literal num, #​1402
  • Fixes WPS226, now it points to the first string literal occurrence, #​3267
  • Fixes WPS605 false-positive on @staticmethod, #​3292
  • Fixes _SELF name not to trigger WPS117, #​3310
  • Fixes WPS221 being too strict with f-strings, #​3350

v1.0.0

Compare Source

Ruff

This release introduces the new main concept: ruff compatibility.

Now WPS is the only flake8 plugin that is installed.
Other things are done by ruff.
It is faster, it has autofixing, there are lots of rules.
Basically, this way WPS just gain lots
of new rule and plugins almost for free.
It is now stricter than ever! WPS now officially supports
ALL ruff existing rules. This means that there are no conflicts
between two linters.

To run WPS and ruff together, use:

ruff format && ruff check && flake8 --select=WPS .

You can copy our configuration from pyproject.toml (for ruff) and setup.cfg (for flake8).

Black

WPS can now also be used with black with default configuration.
However, we recommend using ruff format instead.

Speed

WPS got a lot faster! Because:

  • We removed a lot of flake8 plugins
  • We removed a lot of rules covered by ruff

Running 0.19.2 (previous version) on https://github.com/dry-python/returns

» time flake8 .
flake8 .  20.63s user 2.47s system 469% cpu 4.919 total

The same on 1.0.0:

» time flake8 .
flake8 .  8.56s user 0.54s system 898% cpu 1.013 total

Which is 2.4x times faster!

Integrations

We also significantly improved all the integrations!
WPS can now be used as first-class pre-commit hook with:

repos:
- repo: https://github.com/wemake-services/wemake-python-styleguide
  rev: 1.0.0
  hooks:
    - id: wemake-python-styleguide

Our GitHub Action also got a lot of new options and fixes.

Removals
  • Breaking: Drops python3.9 support
  • Breaking: Drops nitpick support
  • Breaking: Drops flake8-commas, flake8-isort,
    flake8-debugger, flake8-string-format, flake8-quotes,
    flake8-comprehensions, flake8-bugbear, flake8-docstrings,
    flake8-eradicate, flake8-bandit, flake8-broken-line,
    flake8-rst-docstrings, pep8-naming
    support, use ruff format and ruff check instead
  • Breaking: Drops darglint support, because it is unmaintained
  • Breaking: Removes WPS113, because is covered by pylint linter
  • Breaking: Removes WPS119, because is covered by pylint linter
  • Breaking: Removes WPS125, because it is covered by ruff linter
  • Breaking: Removes WPS302, because it is covered by ruff formatter
  • Breaking: Removes WPS304, because it is covered by ruff formatter
  • Breaking: Removes WPS305, because it is covered by ruff formatter
  • Breaking: Removes WPS306, because it is covered by ruff formatter
  • Breaking: Removes WPS309, because it is covered by ruff formatter
  • Breaking: Removes WPS310, because it is covered by ruff formatter
  • Breaking: Removes WPS313, because it is covered by ruff formatter
  • Breaking: Removes WPS315, because it is covered by ruff formatter
  • Breaking: Removes WPS316, because it is covered by ruff linter
  • Breaking: Removes WPS317, because it is covered by ruff formatter
  • Breaking: Removes WPS318, because it is covered by ruff formatter
  • Breaking: Removes WPS319, because it is covered by ruff formatter
  • Breaking: Removes WPS320, because it is covered by ruff formatter
  • Breaking: Removes WPS323, because it is covered by ruff formatter
  • Breaking: Removes WPS326, because it is covered by ruff linter
  • Breaking: Removes WPS329, because it is covered by ruff linter
  • Breaking: Removes WPS331, because it is covered by ruff linter
  • Breaking: Removes WPS333, because is covered by pylint linter
  • Breaking: Removes WPS337, because it is covered by ruff formatter
  • Breaking: Removes WPS340, because it is covered by ruff formatter
  • Breaking: Removes WPS341, because it is covered by ruff formatter
  • Breaking: Removes WPS343, because it is covered by ruff formatter
  • Breaking: Removes WPS348, because it conflicts with ruff formatter
  • Breaking: Removes WPS351, because it is covered by ruff linter
  • Breaking: Removes WPS352, because it is covered by ruff formatter
  • Breaking: Removes WPS355, because it is covered by ruff formatter
  • Breaking: Removes WPS360, because it is covered by ruff formatter
  • Breaking: Removes WPS361, because it is covered by ruff formatter
  • Breaking: Removes WPS415, because is covered by ruff linter
  • Breaking: Removes WPS417, because is covered by ruff linter
  • Breaking: Removes WPS419, because is covered by ruff linter
  • Breaking: Removes WPS423, because is covered by ruff linter
  • Breaking: Removes WPS424, because is covered by ruff linter
  • Breaking: Removes WPS425, because is covered by ruff linter
  • Breaking: Removes WPS428, because is covered by ruff linter
  • Breaking: Removes WPS433, because is covered by pylint linter
  • Breaking: Removes WPS434, because is covered by pylint linter
  • Breaking: Removes WPS436, because is covered by pylint linter
  • Breaking: Removes WPS437, because is covered by ruff linter
  • Breaking: Removes WPS440, because
    it was buggy and is covered by mypy, #​3209
  • Breaking: Removes WPS442, because
    it was buggy and is covered by mypy, #​3209
  • Breaking: Removes WPS450, because is covered by pylint linter
  • Breaking: Removes WPS452, because is covered by ruff linter
  • Breaking: Removes WPS454, because is covered by ruff linter
  • Breaking: Removes WPS456, because is covered by ruff linter
  • Breaking: Removes WPS465, because | is now heavily used by typing
  • Breaking: Removes WPS467, because is covered by pylint linter
  • Breaking: Removes WPS502, because is covered by ruff linter
  • Breaking: Removes WPS503, because is covered by ruff linter
  • Breaking: Removes WPS507, because is covered by pylint linter
  • Breaking: Removes WPS508, because is covered by ruff linter
  • Breaking: Removes WPS510, because is covered by pylint linter
  • Breaking: Removes WPS514, because is covered by pylint linter
  • Breaking: Removes WPS528, because is covered by pylint linter
  • Breaking: Removes WPS525, because is covered by ruff linter
  • Breaking: Removes WPS526, because is covered by ruff linter
  • Breaking: Removes WPS521, because is covered by ruff linter
  • Breaking: Removes WPS609, because is covered by pylint linter
  • Breaking: Removes --i-control-code setting,
    if you want to disable some violations, just use # noqa or --ignore
    with code that you want to exclude, there's no need
    to create one more way of disabling some specific violations
Features
  • Adds official python3.13 support
  • Allows any compares in assert statements for WPS520, #​3112
  • Allows walrus operator (:=) in comprehesions, #​3121
  • Allows pass in case bodies, #​2642
  • Allows subclassing builtins in WPS600, when creating an Enum, #​2506
  • Allows using variables after blocks for WPS441 in assert statements, #​2543
  • Does not count self, cls, and mcs as arguments
    for WPS211 complexity check anymore, #​2394
  • Allows underscores (_) with exactly 3 digits after it in WPS303, #​3120
  • Allows class / instance attribute shadowing
    in @dataclasses for WPS601, #​1926
  • Allows any number of instance attributes on @dataclasses in WPS230, #​2448
  • Allows any number of function parameters
    in @overload definitions for WPS211, #​1957
  • Allows using multiline strings when placed on separate lines, #​3056
  • Allows using hasattr builtin function, #​2228
  • Disallows using is not and not in as negated conditions in WPS504, #​2617
  • Allows all branches in if/elif/else to be negated in WPS504, #​2617
  • Adds a new rule to forbid lambda assigns to special attributes, #​1733
  • Adds a new rule to check problematic function params, #​1343
  • Adds a new rule to detect duplicate conditions in ifs and elifs, #​2241
  • Adds a new rule to detect duplicate case pattens in match, #​3206
  • Adds a new rule to find too many match subjects, #​3201
  • Adds a new rule to detect too many case statements, #​3202
  • Adds a new rule to find too complex except with too many exceptions
  • Adds a new rule to find too many PEP695 type params
  • Adds a new rule to find useless ternary expressions, #​1706
  • Adds a new rule to forbid raise SystemExit, use sys.exit instead, #​1786
  • Adds a new rule to forbid extra syntax in match ... subjects, #​3217
  • Adds new --allowed-module-metadata and --forbidden-module-metadata
    configuration options for WPS410, #​3060
  • Now --allowed-domain-names also affect WPS11
    to allow custom short variable names, #​2554
  • Adds support to run wemake-python-styleguide as a pre-commit hook, #​2588
  • GitHub Action can now use cwd: parameter to specify
    where your configuration file is, #​2474
  • GitHub Action can now use fail_workflow: parameter to not fail
    the workflow even if the check did find any issues
  • GitHub Action can now use filter_mode: parameter to specify
    how ReviewDog will filter found violations,
    see https://github.com/reviewdog/reviewdog#filter-mode #​2239
Bugfixes
  • Fixes WPS217 to allow simple calls in f strings, #​3150
  • Fixes WPS217 not to raise on empty f strings,
    because ruff check handles that now for us
  • Fixes OverusedStringViolation not to include '...' string
  • Removes astor package in favour of ast.unparse
  • Fixes WPS210 to not count nested local variables in nested scopes #​3108
  • Fixes IterableUnpackingViolation with generic types and TypeVarTuple
  • Fixes WPS469 detecting incorrect names of raised exceptions, #​3109
  • Fixes unnormalized paths in formatter output
  • Fixes WPS221 to ignore PEP695's TypeAlias from line complexity checks
  • Fixes WPS474 to only count import collisions in the same context, #​2962
  • Fixes WPS612 to count defaults in function definitions, #​2478
  • Fixes several bugs in WPS322 with multiline strings detection
  • Fixes several violations not been detected in case: statements
  • Fixes WPS314 not detecting match statements
  • Fixes match + case does not increase cognitive complexity
Misc
  • Integration with ondivi doc for legacy codebases
  • Fixes a documentation error for the Formatter (Showing statistic) section
  • Source code is now formatted with ruff
  • Removes deprecated ast nodes from code:
    ast.Num, ast.Bytes, ast.Str, ast.NamedConstant, etc

v0.19.2

Compare Source

Bugfixes
  • Fixes WrongEmptyLinesCountViolation crash on Callable[..., ...] #​2899

v0.19.1

Compare Source

This release fixes how ... is used. For example, it is common to define
function stubs / protocols like this:

def some_function(): ...

Now, ... will be excluded from several rules.

Bugfixes
  • Fixes TooDeepNestingViolation not to trigger
    on ... in functions and classes
  • Fixes StatementHasNoEffectViolation not to trigger
    on ... in functions and classes, when it is the only node

v0.19.0

Compare Source

This minor version will be the last release with all the flake8 plugins.
In the future this project will be migrated to be used together with ruff.

Features
  • Adds official python3.12 support
  • Breaking: drops python3.8 support
  • Breaking: Reconsider object required base class exception:
    since class Klass[_Type] must not contain object,
    this rule is change to be the opposite:
    object explicit base class must not be used.
    You can use ruff to change all object-based types to the new style:
    ruff check --select=UP004 --fix .
    https://docs.astral.sh/ruff/rules/useless-object-inheritance/
  • Breaking: allow positional-only parameters,
    since it is required by mypy when using Concatenate
  • Adds support for naming rules for PEP695 type params
  • Due to how f-string are parsed in python3.12 several token-based
    violations are not reported anymore for them:
    UselessMultilineStringViolation, ImplicitRawStringViolation,
    WrongUnicodeEscapeViolation, RawStringNotNeededViolation
  • wemake output formatter now respects NO_COLOR=1 option
    to disable text highlighting. See https://no-color.org
  • Adds ImportObjectCollisionViolation to detect
    the same objects imported under different aliases
  • Adds reveal_locals to the list of forbidden functions
  • Updates flake8 to 7.x
Bugfixes
  • Fixes ForbiddenInlineIgnoreViolation config parsing. #​2590
  • Fixes WrongEmptyLinesCountViolation for func definitions with ellipsis. #​2847
  • Fixes WrongEmptyLinesCountViolation for multiline implicit string concatenation. #​2787
  • Fixes ObjectInBaseClassesListViolation, UnpythonicGetterSetterViolation,
    ImplicitInConditionViolation, RedundantSubscriptViolation,
    TooLongCompareViolation to include better error details
  • Fixes TooDeepNestingViolation for TryStar and Match statements
  • Fixes TooLongTryBodyViolation and TooManyExceptCasesViolation
    to work for TryStar statements as well
  • Fixes UselessNodeViolation to work with TryStar
  • Fixes DuplicateExceptionViolation to work with TryStar
  • Fixes TryExceptMultipleReturnPathViolation to work with TryStar
  • Fixes IncorrectExceptOrderViolation to work with TryStar
  • Fixes that MatchStar was not checked in pattern matching name assignments
  • Fixes pattern matching support
    in BlockAndLocalOverlapViolation and OuterScopeShadowingViolation
Misc
  • Updates multipleflake8-* dependencies
  • Fixes multiple typos in docs

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 becomes conflicted, 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.

Copy link
Contributor Author

renovate bot commented Dec 28, 2024

⚠️ Artifact update problem

Renovate failed to update an artifact related to this branch. You probably do not want to merge this PR as-is.

♻ Renovate will retry this branch, including artifacts, only when one of the following happens:

  • any of the package files in this branch needs updating, or
  • the branch becomes conflicted, or
  • you click the rebase/retry checkbox if found above, or
  • you rename this PR's title to start with "rebase!" to trigger it manually

The artifact failure details are included below:

File name: poetry.lock
Updating dependencies
Resolving dependencies...

The "poetry.dev-dependencies" section is deprecated and will be removed in a future version. Use "poetry.group.dev.dependencies" instead.

The current project's supported Python range (>=3.8.1,<3.13) is not compatible with some of the required packages Python requirement:
  - wemake-python-styleguide requires Python <4.0,>=3.10, so it will not be satisfied for Python >=3.8.1,<3.10

Because pybotx-fsm depends on wemake-python-styleguide (1.1.0) which requires Python <4.0,>=3.10, version solving failed.

  * Check your dependencies Python requirement: The Python requirement can be specified via the `python` or `markers` properties

    For wemake-python-styleguide, a possible solution would be to set the `python` property to ">=3.10,<3.13"

    https://python-poetry.org/docs/dependency-specification/#python-restricted-dependencies,
    https://python-poetry.org/docs/dependency-specification/#using-environment-markers


@renovate renovate bot force-pushed the renovate/wemake-python-styleguide-1.x branch from 01e1cf3 to abe7a4e Compare March 25, 2025 12:51
@renovate renovate bot force-pushed the renovate/wemake-python-styleguide-1.x branch from abe7a4e to b053305 Compare May 6, 2025 14:15
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.

0 participants