A development process for Python code that uses Test Drivern Development (TDD) to iterate on a new project based around uv. Use when creating a new Python project, writing Python code with tests, or working on Python development using test-driven development practices with the uv package manager.
Install
npx skillscat add gali-leilei/agent-skills-md/uv-tdd Install via the SkillsCat registry.
uv-tdd skill
A development process for Python applications that uses TDD to iterate on a new project based around uv.
Create a project with this command:
mkdir name-of-project
cd name-of-project
uv init --python 3.14
git init (if not already in a git repo)This creates an initial pyproject.toml file
Add dependencies using:
uv add httpxAlways start by adding a dev dependency of pytest like this:
uv add pytest --devThen add a starting test:
mkdir tests
echo 'def test_add():
assert 1 + 1 == 2' > tests/test_add.pyThen run the tests like this:
uv run pytestAlways run Python code like this:
uv run python -c "..."Always create a README.md for the project, which starts with just the project name as a heading plus a short description.
Start by creating a spec.md file with a detailed specification that includes markdown TODO lists. Update the spec and those TODOs as you progress, including adding new ones and checking off previous ones.
Practice TDD. For every change start by writing a test (grouped sensible in test files with other related tests) and then use uv run pytest -k name_of_test to watch it fail. Then implement the change and watch the test pass. Update the TODOs and add or update relevant documentation in the README, then commit the implementation and tests and documentation as a single commit.
Use and reuse pytest fixtures where appropriate, including for temporary files used for the duration of the test run. Use pytest.mark.parameterized to avoid duplicated test code.
Delete that test_add.py file once you have implemented your first real test. Do not include that test_add.py file in any of your commits.
Commit often, in sensible chunks. If a remote is configured then push after every commit.