diff --git a/.github/ISSUE_TEMPLATE/bug-report.md b/.github/ISSUE_TEMPLATE/bug-report.md index 83bdd15f1..be31bc61f 100644 --- a/.github/ISSUE_TEMPLATE/bug-report.md +++ b/.github/ISSUE_TEMPLATE/bug-report.md @@ -8,7 +8,7 @@ assignees: "" ## Issue - + ## Environment diff --git a/.github/workflows/check.yml b/.github/workflows/check.yml index bf68c7968..987725469 100644 --- a/.github/workflows/check.yml +++ b/.github/workflows/check.yml @@ -2,7 +2,7 @@ name: check on: workflow_dispatch: push: - branches: "main" + branches: ["main"] tags-ignore: [ "**" ] pull_request: schedule: diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 6a822bfed..4a8e580c2 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -4,34 +4,37 @@ repos: hooks: - id: end-of-file-fixer - id: trailing-whitespace + - repo: https://github.com/python-jsonschema/check-jsonschema + rev: 0.28.0 + hooks: + - id: check-github-workflows + args: [ "--verbose" ] - repo: https://github.com/codespell-project/codespell rev: v2.2.6 hooks: - id: codespell - args: ["--ignore-words-list", "crate,releas", "--skip", "*.svg"] - additional_dependencies: - - tomli>=2.0.1 + additional_dependencies: ["tomli>=2.0.1"] - repo: https://github.com/tox-dev/tox-ini-fmt - rev: 1.3.1 + rev: "1.3.1" hooks: - id: tox-ini-fmt args: ["-p", "fix"] - repo: https://github.com/tox-dev/pyproject-fmt - rev: 1.7.0 + rev: "1.7.0" hooks: - id: pyproject-fmt - additional_dependencies: ["tox>=4.11.4"] - - repo: https://github.com/asottile/blacken-docs - rev: 1.16.0 - hooks: - - id: blacken-docs - additional_dependencies: [black==23.12.1] + additional_dependencies: ["tox>=4.12.1"] - repo: https://github.com/astral-sh/ruff-pre-commit - rev: v0.1.14 + rev: "v0.2.1" hooks: - id: ruff-format - id: ruff args: ["--fix", "--unsafe-fixes", "--exit-non-zero-on-fix"] + - repo: https://github.com/asottile/blacken-docs + rev: 1.16.0 + hooks: + - id: blacken-docs + additional_dependencies: [black==23.12.1] - repo: https://github.com/pre-commit/pygrep-hooks rev: v1.10.0 hooks: diff --git a/docs/changelog.rst b/docs/changelog.rst index 986657524..6e2679791 100644 --- a/docs/changelog.rst +++ b/docs/changelog.rst @@ -559,8 +559,8 @@ v4.1.2 (2022-12-30) Bugfixes - 4.1.2 ~~~~~~~~~~~~~~~~ -- Fix ``--skip-missing-interpreters`` behaviour - by :user:`q0w`. (:issue:`2649`) -- Restore tox 3 behaviour of showing the output of pip freeze, however now only active when running inside a CI +- Fix ``--skip-missing-interpreters`` behavior - by :user:`q0w`. (:issue:`2649`) +- Restore tox 3 behavior of showing the output of pip freeze, however now only active when running inside a CI environment - by :user:`gaborbernat`. (:issue:`2685`) - Fix extracting extras from markers with many extras - by :user:`q0w`. (:issue:`2791`) @@ -614,7 +614,7 @@ Features - 4.0.17 Bugfixes - 4.0.17 ~~~~~~~~~~~~~~~~~ -- Fix ``--sdistonly`` behaviour. (:issue:`2653`) +- Fix ``--sdistonly`` behavior. (:issue:`2653`) - Override toxworkdir with --workdir. (:issue:`2654`) diff --git a/docs/changelog/3197.doc.rst b/docs/changelog/3197.doc.rst index 09fa45f62..7697a37ed 100644 --- a/docs/changelog/3197.doc.rst +++ b/docs/changelog/3197.doc.rst @@ -1 +1 @@ -Development: summarise important points experienced developers need to know - by :user:`0cjs`. +Development: summarize important points experienced developers need to know - by :user:`0cjs`. diff --git a/docs/config.rst b/docs/config.rst index d6bb850e0..a1cb834f6 100644 --- a/docs/config.rst +++ b/docs/config.rst @@ -454,7 +454,7 @@ Run .. note:: Inline scripts can be used, however note these are discovered from the project root directory, and is not - influenced by :ref:`change_dir` (this only affects the runtime current working directory). To make this behaviour + influenced by :ref:`change_dir` (this only affects the runtime current working directory). To make this behavior explicit we recommend that you make inline scripts absolute paths by prepending ``{tox_root}``, instead of ``path/to/my_script`` prefer ``{tox_root}{/}path{/}to{/}my_script``. If your inline script is platform dependent refer to :ref:`platform-specification` on how to select different script per platform. diff --git a/ignore-words.txt b/ignore-words.txt new file mode 100644 index 000000000..c290503b0 --- /dev/null +++ b/ignore-words.txt @@ -0,0 +1,2 @@ +releas +master diff --git a/pyproject.toml b/pyproject.toml index 7cb8de3ca..5e9b104a8 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -103,11 +103,11 @@ build.targets.sdist.include = ["/src", "/tests", "/tox.ini"] version.source = "vcs" [tool.ruff] -select = ["ALL"] line-length = 120 target-version = "py38" -isort = { known-first-party = ["tox", "tests"], required-imports = ["from __future__ import annotations"] } -ignore = [ +lint.isort = { known-first-party = ["tox", "tests"], required-imports = ["from __future__ import annotations"] } +lint.select = ["ALL"] +lint.ignore = [ "CPY", # No copyright header "INP001", # no implicit namespaces here "D", # ignore documentation for now @@ -118,21 +118,16 @@ ignore = [ "D212", # `multi-line-summary-first-line` (D212) and `multi-line-summary-second-line` (D213) are incompatible "S104", # Possible binding to all interfaces "COM812", # conflicts with formatter - "COM819", # conflicts with formatter - "E501", # conflicts with formatter "ISC001", # conflicts with formatter - "Q000", # conflicts with formatter - "Q001", # conflicts with formatter - "Q002", # conflicts with formatter - "Q003", # conflicts with formatter - "W191", # conflicts with formatter "S404", # Using subprocess is alright. "PLR0914", ## Too many local variables "PLR0917", ## Too many positional arguments ] format.preview = true lint.preview = true -[tool.ruff.per-file-ignores] +format.docstring-code-format = true +format.docstring-code-line-length = 100 +[tool.ruff.lint.per-file-ignores] "tests/**/*.py" = [ "S101", # asserts allowed in tests... "FBT", # don"t care about booleans as positional arguments in tests @@ -142,6 +137,13 @@ lint.preview = true "PLR2004", # Magic value used in comparison, consider replacing with a constant variable ] +[tool.codespell] +builtin = "clear,usage,en-GB_to_en-US" +write-changes = true +skip = "*.svg" +ignore-words = "ignore-words.txt" +count = true + [tool.pytest.ini_options] testpaths = ["tests"] addopts = "--tb=auto -ra --showlocals --no-success-flaky-report" diff --git a/src/tox/config/set_env.py b/src/tox/config/set_env.py index 1fdcbc05a..3d98c902d 100644 --- a/src/tox/config/set_env.py +++ b/src/tox/config/set_env.py @@ -20,7 +20,7 @@ def __init__(self, raw: str, name: str, env_name: str | None, root: Path) -> Non self._name, self._env_name, self._root = name, env_name, root from .loader.ini.replace import MatchExpression, find_replace_expr # noqa: PLC0415 - for line in raw.splitlines(): + for line in raw.splitlines(): # noqa: PLR1702 if line.strip(): if line.startswith("file|"): self._env_files.append(line[len("file|") :]) diff --git a/src/tox/plugin/__init__.py b/src/tox/plugin/__init__.py index 508c7f64d..7ec350875 100644 --- a/src/tox/plugin/__init__.py +++ b/src/tox/plugin/__init__.py @@ -1,5 +1,5 @@ """ -tox uses `pluggy `_ to customize the default behaviour. It provides an +tox uses `pluggy `_ to customize the default behavior. It provides an extension mechanism for plugin management an calling hooks. Pluggy discovers a plugin by looking up for entry-points named ``tox``, for example in a pyproject.toml: diff --git a/src/tox/session/cmd/run/common.py b/src/tox/session/cmd/run/common.py index 365cc15c6..fbddbcce9 100644 --- a/src/tox/session/cmd/run/common.py +++ b/src/tox/session/cmd/run/common.py @@ -256,9 +256,9 @@ def execute(state: State, max_workers: int | None, has_spinner: bool, live: bool interrupt.set() # cancel in reverse order to not allow submitting new jobs as we cancel running ones for future, tox_env in reversed(list(future_to_env.items())): - cancelled = future.cancel() - # if cannot be cancelled and not done -> still runs - if cancelled is False and not future.done(): # pragma: no branch + canceled = future.cancel() + # if cannot be canceled and not done -> still runs + if canceled is False and not future.done(): # pragma: no branch tox_env.interrupt() done.wait() # workaround for https://bugs.python.org/issue45274 @@ -310,7 +310,7 @@ def _queue_and_wait( # noqa: C901, PLR0913, PLR0915 spinner: ToxSpinner, live: bool, # noqa: FBT001 ) -> None: - try: + try: # noqa: PLR1702 options = state._options # noqa: SLF001 with spinner: max_workers = len(to_run_list) if max_workers is None else max_workers diff --git a/src/tox/session/env_select.py b/src/tox/session/env_select.py index a654eaa49..9d6c25c2f 100644 --- a/src/tox/session/env_select.py +++ b/src/tox/session/env_select.py @@ -189,7 +189,7 @@ def _ensure_envs_valid(self) -> None: for env in self._cli_envs or []: if env.startswith(".pkg_external"): # external package continue - factors: dict[str, str | None] = {k: None for k in env.split("-")} + factors: dict[str, str | None] = dict.fromkeys(env.split("-")) found_factors: set[str] = set() for factor in factors: if ( @@ -247,7 +247,7 @@ def _defined_envs(self) -> dict[str, _ToxEnvInfo]: # noqa: C901, PLR0912 # we need to redefine it, e.g. when it shows up in config as [testenv:.package] and afterwards by a run env is # marked as package_env. - if self._defined_envs_ is None: + if self._defined_envs_ is None: # noqa: PLR1702 self._defined_envs_ = {} failed: dict[str, Exception] = {} env_name_to_active = self._env_name_to_active() diff --git a/src/tox/tox_env/api.py b/src/tox/tox_env/api.py index 5b4bb7c30..367209306 100644 --- a/src/tox/tox_env/api.py +++ b/src/tox/tox_env/api.py @@ -139,7 +139,7 @@ def register_config(self) -> None: def pass_env_post_process(values: list[str]) -> list[str]: values.extend(self._default_pass_env()) - result = sorted({k: None for k in values}.keys()) + result = sorted(dict.fromkeys(values).keys()) invalid_chars = set(string.whitespace) invalid = [v for v in result if any(c in invalid_chars for c in v)] if invalid: @@ -436,7 +436,7 @@ def execute_async( # noqa: PLR0913 finally: self._execute_statuses.pop(execute_id) if show and self._hidden_outcomes is not None and execute_status.outcome is not None: - # if it gets cancelled before even starting + # if it gets canceled before even starting self._hidden_outcomes.append(execute_status.outcome) if self.journal and execute_status.outcome is not None: self.journal.add_execute(execute_status.outcome, run_id) diff --git a/src/tox/util/graph.py b/src/tox/util/graph.py index 4786578cd..fb7f331ff 100644 --- a/src/tox/util/graph.py +++ b/src/tox/util/graph.py @@ -58,8 +58,8 @@ def visit(vertex: str) -> dict[str, None] | None: return None visited.add(vertex) path[vertex] = None - for neighbour in graph.get(vertex, ()): - if neighbour in path or visit(neighbour): + for neighbor in graph.get(vertex, ()): + if neighbor in path or visit(neighbor): return path del path[vertex] return None