mirror of
https://github.com/astral-sh/ruff.git
synced 2025-08-04 10:48:32 +00:00
Turn the fuzz-parser
script into a properly packaged Python project (#14606)
## Summary This PR gets rid of the `requirements.in` and `requirements.txt` files in the `scripts/fuzz-parser` directory, and replaces them with `pyproject.toml` and `uv.lock` files. The script is renamed from `fuzz-parser` to `py-fuzzer` (since it can now also be used to fuzz red-knot as well as the parser, following https://github.com/astral-sh/ruff/pull/14566), and moved from the `scripts/` directory to the `python/` directory, since it's now a (uv)-pip-installable project in its own right. I've been resisting this for a while, because conceptually this script just doesn't feel "complicated" enough to me for it to be a full-blown package. However, I think it's time to do this. Making it a proper package has several advantages: - It means we can run it from the project root using `uv run` without having to activate a virtual environment and ensure that all required dependencies are installed into that environment - Using a `pyproject.toml` file means that we can express that the project requires Python 3.12+ to run properly; this wasn't possible before - I've been running mypy on the project locally when I've been working on it or reviewing other people's PRs; now I can put the mypy config for the project in the `pyproject.toml` file ## Test Plan I manually tested that all the commands detailed in `python/py-fuzzer/README.md` work for me locally. --------- Co-authored-by: David Peter <sharkdp@users.noreply.github.com>
This commit is contained in:
parent
c84c690f1e
commit
e0f3eaf1dd
10 changed files with 379 additions and 83 deletions
|
@ -58,19 +58,14 @@ cargo test --package ruff_python_parser
|
|||
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, first install the required dependencies:
|
||||
To run the fuzzer, execute the following command
|
||||
(requires [`uv`](https://github.com/astral-sh/uv) to be installed):
|
||||
|
||||
```sh
|
||||
uv pip install -r scripts/fuzz-parser/requirements.txt
|
||||
uv run --no-project --with ./python/py-fuzzer fuzz
|
||||
```
|
||||
|
||||
Then, run the fuzzer with the following command:
|
||||
|
||||
```sh
|
||||
python scripts/fuzz-parser/fuzz.py
|
||||
```
|
||||
|
||||
Refer to the [fuzz.py](https://github.com/astral-sh/ruff/blob/main/scripts/fuzz-parser/fuzz.py)
|
||||
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
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue