From 4ddf9e8f73fdbc97357a979663308c59015a67ef Mon Sep 17 00:00:00 2001 From: Anish Athalye Date: Sat, 4 Jan 2025 07:13:37 -0800 Subject: [PATCH] Add development guide --- CONTRIBUTING.md | 43 +++++------------------------------- DEVELOPMENT.md | 58 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 63 insertions(+), 38 deletions(-) create mode 100644 DEVELOPMENT.md diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 0854adb..699e175 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -44,43 +44,11 @@ describing what you intend to work on. Any changes to the code base should follow the style and coding conventions used in the rest of the project. The version history should be clean, and commit messages should be descriptive and [properly -formatted][commit-messages]. +formatted][commit-messages]. It's recommended that you add unit tests to +demonstrate that the bug is fixed (or that the feature works). -### Testing - -When preparing a patch, it's recommended that you add unit tests -that demonstrate the bug is fixed (or that the feature works). You -can run tests on your local machine using [Hatch][hatch]: - -```bash -hatch test -``` - -If you prefer to run the tests in an isolated container using Docker, you can -do so with the following: - -```bash -docker run -it --rm -v "${PWD}:/dotbot" -w /dotbot python:3.13-bookworm /bin/bash -``` - -After spawning the container, install Hatch with `pip install hatch`, and then -run the tests. - -### Type checking - -You can run type checking with: - -```bash -hatch run types:check -``` - -### Formatting and linting - -You can run the [Ruff][ruff] formatter and linter with: - -```bash -hatch fmt -``` +See the [Dotbot development guide][development] to learn how to run the tests, +type checking, and more. --- @@ -91,5 +59,4 @@ If you have any questions about anything, feel free to [ask][email]! [fork]: https://github.com/anishathalye/dotbot/fork [email]: mailto:me@anishathalye.com [commit-messages]: http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html -[hatch]: https://hatch.pypa.io/ -[ruff]: https://github.com/astral-sh/ruff +[development]: DEVELOPMENT.md diff --git a/DEVELOPMENT.md b/DEVELOPMENT.md new file mode 100644 index 0000000..a46dc1c --- /dev/null +++ b/DEVELOPMENT.md @@ -0,0 +1,58 @@ +# Development + +Dotbot uses the [Hatch] project manager ([installation instructions][hatch-install]). Hatch automatically manages dependencies and runs testing, type checking, and other operations in isolated [environments][hatch-environments]. + +[Hatch]: https://hatch.pypa.io/ +[hatch-install]: https://hatch.pypa.io/latest/install/ +[hatch-environments]: https://hatch.pypa.io/latest/environment/ + +## Testing + +You can run the tests on your local machine with: + +```bash +hatch test +``` + +The [`test` command][hatch-test] supports options such as `-c` for measuring test coverage, `-a` for testing with a matrix of Python versions, and appending an argument like `tests/test_shell.py::test_shell_can_override_defaults` for running a single test. + +[hatch-test]: https://hatch.pypa.io/latest/tutorials/testing/overview/ + +### Isolation + +Dotbot executes shell commands and interacts with the filesystem, and the tests exercise this functionality. The tests try to [insulate][dotbot-conftest] themselves from the machine, but if you prefer to run tests in an isolated container using Docker, you can do so with the following: + +```bash +docker run -it --rm -v "${PWD}:/dotbot" -w /dotbot python:3.13-bookworm /bin/bash +``` + +After spawning the container, install Hatch with `pip install hatch`, and then run the tests as described above. + +[dotbot-conftest]: tests/conftest.py + +## Type checking + +You can run the [mypy static type checker][mypy] with: + +```bash +hatch run types:check +``` + +[mypy]: https://mypy-lang.org/ + +## Formatting and linting + +You can run the [Ruff][ruff] formatter and linter with: + +```bash +hatch fmt +``` + +[ruff]: https://github.com/astral-sh/ruff + +## Packaging + +You can use `hatch build` to create build artifacts, a [source distribution ("sdist")][sdist] and a [built distribution ("wheel")][bdist]. + +[sdist]: https://packaging.python.org/en/latest/glossary/#term-Source-Distribution-or-sdist +[bdist]: https://packaging.python.org/en/latest/glossary/#term-Built-Distribution