Skip to content

Commit

Permalink
Replace pip with uv for the project files
Browse files Browse the repository at this point in the history
  • Loading branch information
foarsitter committed Sep 18, 2024
1 parent aab05d3 commit ab8601e
Show file tree
Hide file tree
Showing 14 changed files with 1,045 additions and 76 deletions.
27 changes: 16 additions & 11 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,14 +23,17 @@ jobs:
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- name: Install uv
uses: astral-sh/setup-uv@v2
with:
enable-cache: "true"
- uses: actions/setup-python@v5
with:
python-version: "3.12"
cache: pip
- name: Install dependencies
run: pip install -r requirements.txt
run: uv sync
- name: Run tests
run: pytest -n auto tests
run: uv run pytest -n auto tests

docker:
strategy:
Expand All @@ -54,12 +57,15 @@ jobs:

steps:
- uses: actions/checkout@v4
- name: Install uv
uses: astral-sh/setup-uv@v2
with:
enable-cache: "true"
- uses: actions/setup-python@v5
with:
python-version: "3.12"
cache: pip
- name: Install dependencies
run: pip install -r requirements.txt
run: uv sync
- name: Docker ${{ matrix.script.name }}
run: sh tests/test_docker.sh ${{ matrix.script.args }}

Expand Down Expand Up @@ -98,16 +104,15 @@ jobs:

steps:
- uses: actions/checkout@v4
- name: Install uv
uses: astral-sh/setup-uv@v2
with:
enable-cache: "true"
- uses: actions/setup-python@v5
with:
python-version: "3.12"
cache: pip
cache-dependency-path: |
requirements.txt
{{cookiecutter.project_slug}}/requirements/base.txt
{{cookiecutter.project_slug}}/requirements/local.txt
- name: Install dependencies
run: pip install -r requirements.txt
run: uv sync
- uses: actions/setup-node@v4
with:
node-version: "22"
Expand Down
10 changes: 5 additions & 5 deletions .github/workflows/django-issue-checker.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,14 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Install uv
uses: astral-sh/setup-uv@v2
with:
enable-cache: "true"
- uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Create Django Major Issue
run: python scripts/create_django_issue.py
run: uv run scripts/create_django_issue.py
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
11 changes: 5 additions & 6 deletions .github/workflows/update-changelog.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,20 +15,19 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4

- name: Install uv
uses: astral-sh/setup-uv@v2
with:
enable-cache: "true"
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Set git details
run: |
git config --global user.name "github-actions"
git config --global user.email "[email protected]"
- name: Update list
run: python scripts/update_changelog.py
run: uv run scripts/update_changelog.py
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
11 changes: 5 additions & 6 deletions .github/workflows/update-contributors.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,16 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4

- name: Install uv
uses: astral-sh/setup-uv@v2
with:
enable-cache: "true"
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Update list
run: python scripts/update_contributors.py
run: uv run scripts/update_contributors.py
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

Expand Down
19 changes: 3 additions & 16 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,33 +24,20 @@ We'll also run the tests on GitHub actions when you send your pull request, but

### Installation

First, make sure that your version of Python is 3.12:

```bash
$ python --version
Python 3.12.2
```

Any version that starts with 3.12 will do. If you need to install it, you can get it from [python.org](https://www.python.org/downloads/).

Then install `tox`, if not already installed:

```bash
$ python -m pip install tox
```
We use uv to manage our environment and manage our Python installation. You can install it following the instructions at https://docs.astral.sh/uv/getting-started/installation/

### Run the template's test suite

To run the tests of the template using the current Python version:

```bash
$ tox -e py
$ uv run tox run -e py
```

This uses `pytest `under the hood, and you can pass options to it after a `--`. So to run a particular test:

```bash
$ tox -e py -- -k test_default_configuration
$ uv run tox run -e py -- -k test_default_configuration
```

For further information, please consult the [pytest usage docs](https://pytest.org/en/latest/how-to/usage.html#specifying-which-tests-to-run).
Expand Down
26 changes: 23 additions & 3 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -28,14 +28,34 @@ classifiers = [
"Programming Language :: Python :: Implementation :: CPython",
"Topic :: Software Development",
]
dependencies = [
"binaryornot==0.4.4",
"cookiecutter==2.6",
"django-upgrade==1.21",
"djlint==1.35.2",
"gitpython==3.1.43",
"jinja2==3.1.4",
"pre-commit==3.8",
"pygithub==2.4",
"pytest==8.3.2",
"pytest-cookies==0.7",
"pytest-instafail==0.5",
"pytest-xdist==3.6.1",
"pyyaml==6.0.2",
"requests==2.32.3",
"ruff==0.6.4",
"sh==2.0.7; sys_platform!='win23'",
"tox==4.18",
"tox-uv>=1.11.2",
]
urls = { Repository = "https://github.com/cookiecutter/cookiecutter-django" }
# ==== black ====

[tool.black]
line-length = 119
target-version = [
'py312',
]

# ==== isort ====

[tool.isort]
Expand All @@ -47,7 +67,7 @@ known_first_party = [
"hooks",
]

# ==== djLint ====
# ==== pytest ====

[tool.pytest.ini_options]
addopts = "-v --tb=short"
Expand All @@ -61,7 +81,7 @@ norecursedirs = [
"*/{{cookiecutter.project_slug}}/*",
]

# ==== black ====
# ==== djLint ====

[tool.djlint]
blank_line_after_tag = "load,extends"
Expand Down
26 changes: 0 additions & 26 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -1,26 +0,0 @@
cookiecutter==2.6.0
sh==2.0.7; sys_platform != "win32"
binaryornot==0.4.4

# Code quality
# ------------------------------------------------------------------------------
ruff==0.6.5
django-upgrade==1.21.0
djlint==1.35.2
pre-commit==3.8.0

# Testing
# ------------------------------------------------------------------------------
tox==4.19.0
pytest==8.3.3
pytest-xdist==3.6.1
pytest-cookies==0.7.0
pytest-instafail==0.5.0
pyyaml==6.0.2

# Scripting
# ------------------------------------------------------------------------------
PyGithub==2.4.0
gitpython==3.1.43
jinja2==3.1.4
requests==2.32.3
9 changes: 9 additions & 0 deletions scripts/create_django_issue.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,12 @@
# /// script
# requires-python = ">=3.12"
# dependencies = [
# "gitpython",
# "PyGithub",
# "jinja2",
# "requests",
# ]
# ///
"""
Creates an issue that generates a table for dependency checking whether
all packages support the latest Django version. "Latest" does not include
Expand Down
8 changes: 8 additions & 0 deletions scripts/update_changelog.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,11 @@
# /// script
# requires-python = ">=3.12"
# dependencies = [
# "gitpython",
# "PyGithub",
# "jinja2",
# ]
# ///
import datetime as dt
import os
import re
Expand Down
7 changes: 7 additions & 0 deletions scripts/update_contributors.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
# /// script
# requires-python = ">=3.12"
# dependencies = [
# "PyGithub",
# "jinja2",
# ]
# ///
import json
import os
from pathlib import Path
Expand Down
2 changes: 1 addition & 1 deletion tests/test_bare.sh
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ mkdir -p .cache/bare
cd .cache/bare

# create the project using the default settings in cookiecutter.json
cookiecutter ../../ --no-input --overwrite-if-exists use_docker=n "$@"
uv run cookiecutter ../../ --no-input --overwrite-if-exists use_docker=n "$@"
cd my_awesome_project

# Install OS deps
Expand Down
2 changes: 1 addition & 1 deletion tests/test_docker.sh
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ mkdir -p .cache/docker
cd .cache/docker

# create the project using the default settings in cookiecutter.json
cookiecutter ../../ --no-input --overwrite-if-exists use_docker=y "$@"
uv run cookiecutter ../../ --no-input --overwrite-if-exists use_docker=y "$@"
cd my_awesome_project

# make sure all images build
Expand Down
1 change: 0 additions & 1 deletion tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ skipsdist = true
envlist = py312,black-template

[testenv]
deps = -rrequirements.txt
passenv = AUTOFIXABLE_STYLES
commands = pytest -n auto {posargs:./tests}

Expand Down
Loading

0 comments on commit ab8601e

Please sign in to comment.