mirror of
				https://github.com/astral-sh/ruff.git
				synced 2025-10-25 09:28:09 +00:00 
			
		
		
		
	![renovate[bot]](/assets/img/avatar_default.png) a192d96880
			
		
	
	
		a192d96880
		
			
		
	
	
	
	
		
			
			This PR contains the following updates: | Package | Type | Update | Change | |---|---|---|---| | [abravalheri/validate-pyproject](https://redirect.github.com/abravalheri/validate-pyproject) | repository | patch | `v0.24` -> `v0.24.1` | | [astral-sh/ruff-pre-commit](https://redirect.github.com/astral-sh/ruff-pre-commit) | repository | patch | `v0.11.0` -> `v0.11.2` | | [crate-ci/typos](https://redirect.github.com/crate-ci/typos) | repository | minor | `v1.30.2` -> `v1.31.0` | | [python-jsonschema/check-jsonschema](https://redirect.github.com/python-jsonschema/check-jsonschema) | repository | minor | `0.31.3` -> `0.32.1` | | [woodruffw/zizmor-pre-commit](https://redirect.github.com/woodruffw/zizmor-pre-commit) | repository | patch | `v1.5.1` -> `v1.5.2` | --- > [!WARNING] > Some dependencies could not be looked up. Check the Dependency Dashboard for more information. Note: The `pre-commit` manager in Renovate is not supported by the `pre-commit` maintainers or community. Please do not report any problems there, instead [create a Discussion in the Renovate repository](https://redirect.github.com/renovatebot/renovate/discussions/new) if you have any questions. --- ### Release Notes <details> <summary>abravalheri/validate-pyproject (abravalheri/validate-pyproject)</summary> ### [`v0.24.1`](https://redirect.github.com/abravalheri/validate-pyproject/releases/tag/v0.24.1) [Compare Source](https://redirect.github.com/abravalheri/validate-pyproject/compare/v0.24...v0.24.1) #### What's Changed - Fixed multi plugin id was read from the wrong place by [@​henryiii](https://redirect.github.com/henryiii) in [https://github.com/abravalheri/validate-pyproject/pull/240](https://redirect.github.com/abravalheri/validate-pyproject/pull/240) - Implemented alternative plugin sorting, [https://github.com/abravalheri/validate-pyproject/pull/243](https://redirect.github.com/abravalheri/validate-pyproject/pull/243) **Full Changelog**: https://github.com/abravalheri/validate-pyproject/compare/v0.24...v0.24.1 </details> <details> <summary>astral-sh/ruff-pre-commit (astral-sh/ruff-pre-commit)</summary> ### [`v0.11.2`](https://redirect.github.com/astral-sh/ruff-pre-commit/releases/tag/v0.11.2) [Compare Source](https://redirect.github.com/astral-sh/ruff-pre-commit/compare/v0.11.1...v0.11.2) See: https://github.com/astral-sh/ruff/releases/tag/0.11.2 ### [`v0.11.1`](https://redirect.github.com/astral-sh/ruff-pre-commit/releases/tag/v0.11.1) [Compare Source](https://redirect.github.com/astral-sh/ruff-pre-commit/compare/v0.11.0...v0.11.1) See: https://github.com/astral-sh/ruff/releases/tag/0.11.1 </details> <details> <summary>crate-ci/typos (crate-ci/typos)</summary> ### [`v1.31.0`](https://redirect.github.com/crate-ci/typos/releases/tag/v1.31.0) [Compare Source](https://redirect.github.com/crate-ci/typos/compare/v1.30.3...v1.31.0) #### \[1.31.0] - 2025-03-28 ##### Features - Updated the dictionary with the [March 2025](https://redirect.github.com/crate-ci/typos/issues/1266) changes ### [`v1.30.3`](https://redirect.github.com/crate-ci/typos/releases/tag/v1.30.3) [Compare Source](https://redirect.github.com/crate-ci/typos/compare/v1.30.2...v1.30.3) #### \[1.30.3] - 2025-03-24 ##### Features - Support detecting `go.work` and `go.work.sum` files </details> <details> <summary>python-jsonschema/check-jsonschema (python-jsonschema/check-jsonschema)</summary> ### [`v0.32.1`](https://redirect.github.com/python-jsonschema/check-jsonschema/blob/HEAD/CHANGELOG.rst#0321) [Compare Source](https://redirect.github.com/python-jsonschema/check-jsonschema/compare/0.32.0...0.32.1) - Fix the `check-meltano` hook to use `types_or`. Thanks :user:`edgarrmondragon`! (:pr:`543`) ### [`v0.32.0`](https://redirect.github.com/python-jsonschema/check-jsonschema/blob/HEAD/CHANGELOG.rst#0320) [Compare Source](https://redirect.github.com/python-jsonschema/check-jsonschema/compare/0.31.3...0.32.0) - Update vendored schemas: circle-ci, compose-spec, dependabot, github-workflows, gitlab-ci, mergify, renovate, taskfile (2025-03-25) - Add Meltano schema and pre-commit hook. Thanks :user:`edgarrmondragon`! (:issue:`540`) - Add Snapcraft schema and pre-commit hook. Thanks :user:`fabolhak`! (:issue:`535`) </details> <details> <summary>woodruffw/zizmor-pre-commit (woodruffw/zizmor-pre-commit)</summary> ### [`v1.5.2`](https://redirect.github.com/woodruffw/zizmor-pre-commit/releases/tag/v1.5.2) [Compare Source](https://redirect.github.com/woodruffw/zizmor-pre-commit/compare/v1.5.1...v1.5.2) See: https://github.com/woodruffw/zizmor/releases/tag/v1.5.2 </details> --- ### Configuration 📅 **Schedule**: Branch creation - "before 4am on Monday" (UTC), 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. 👻 **Immortal**: This PR will be recreated if closed unmerged. Get [config help](https://redirect.github.com/renovatebot/renovate/discussions) if that's undesired. --- - [ ] <!-- 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/astral-sh/ruff). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOS4yMDcuMSIsInVwZGF0ZWRJblZlciI6IjM5LjIwNy4xIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJpbnRlcm5hbCJdfQ==--> --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Micha Reiser <micha@reiser.io>
		
			
				
	
	
		
			95 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Contributing to the Python Parser
 | |
| 
 | |
| ## Development
 | |
| 
 | |
| ### Inline tests
 | |
| 
 | |
| The parser crate supports writing inline tests. These are tests that are written
 | |
| in the source code itself, and are extracted to a separate file and run with the
 | |
| test suite. They are written in the form of comments with a specific format. There
 | |
| are two forms of inline tests:
 | |
| 
 | |
| Test that the parser successfully parses the input with no syntax errors. They're
 | |
| written in the following format:
 | |
| 
 | |
| ```rs
 | |
| // test_ok this_is_the_test_name
 | |
| // def foo():
 | |
| //     pass
 | |
| println!("some rust code");
 | |
| ```
 | |
| 
 | |
| Test that the parser fails to parse the input with a syntax error. They're written
 | |
| in the following format:
 | |
| 
 | |
| ```rs
 | |
| // test_err this_is_the_test_name
 | |
| // [1, 2
 | |
| println!("some rust code");
 | |
| ```
 | |
| 
 | |
| Note that the difference between the two is the `test_ok` and `test_err` keywords.
 | |
| The comment block must be independent of any other comment blocks. For example, the
 | |
| following is not extracted:
 | |
| 
 | |
| ```rs
 | |
| // Some random comment
 | |
| //
 | |
| // test_ok this_is_the_test_name
 | |
| // def foo():
 | |
| //     pass
 | |
| println!("some rust code");
 | |
| ```
 | |
| 
 | |
| To generate the corresponding Python files for the inline tests, run the following command:
 | |
| 
 | |
| ```sh
 | |
| cargo test --package ruff_python_parser --test generate_inline_tests
 | |
| ```
 | |
| 
 | |
| Then, run the Parser test suite with the following command:
 | |
| 
 | |
| ```sh
 | |
| cargo test --package ruff_python_parser
 | |
| ```
 | |
| 
 | |
| ### Python-based fuzzer
 | |
| 
 | |
| The Ruff project includes a Python-based fuzzer that can be used to run the parser on
 | |
| randomly generated (but syntactically valid) Python source code files.
 | |
| 
 | |
| To run the fuzzer, execute the following command
 | |
| (requires [`uv`](https://github.com/astral-sh/uv) to be installed):
 | |
| 
 | |
| ```sh
 | |
| uvx --from ./python/py-fuzzer fuzz
 | |
| ```
 | |
| 
 | |
| Refer to the [py-fuzzer](https://github.com/astral-sh/ruff/blob/main/python/py-fuzzer/fuzz.py)
 | |
| script for more information or use the `--help` flag to see the available options.
 | |
| 
 | |
| #### CI
 | |
| 
 | |
| The fuzzer is run as part of the CI pipeline. The purpose of running the fuzzer in the CI is to
 | |
| catch any regressions introduced by any new changes to the parser. This is why the fuzzer is run on
 | |
| the same set of seeds on every run.
 | |
| 
 | |
| ## Benchmarks
 | |
| 
 | |
| The `ruff_benchmark` crate can benchmark both the lexer and the parser.
 | |
| 
 | |
| To run the lexer benchmarks, use the following command:
 | |
| 
 | |
| ```sh
 | |
| cargo bench --package ruff_benchmark --bench lexer
 | |
| ```
 | |
| 
 | |
| And to run the parser benchmarks, use the following command:
 | |
| 
 | |
| ```sh
 | |
| cargo bench --package ruff_benchmark --bench parser
 | |
| ```
 | |
| 
 | |
| Refer to the [Benchmarking and
 | |
| Profiling](https://docs.astral.sh/ruff/contributing/#benchmark-driven-development) section in the
 | |
| contributing guide for more information.
 |