Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/superlinear-ai/poetry-cookiecutter
๐ช Poetry Cookiecutter is a modern Cookiecutter template for scaffolding Python packages and apps
https://github.com/superlinear-ai/poetry-cookiecutter
cookiecutter cookiecutter-poetry cookiecutter-python cookiecutter-template devcontainer docker poetry python scaffolding template
Last synced: 2 days ago
JSON representation
๐ช Poetry Cookiecutter is a modern Cookiecutter template for scaffolding Python packages and apps
- Host: GitHub
- URL: https://github.com/superlinear-ai/poetry-cookiecutter
- Owner: superlinear-ai
- License: agpl-3.0
- Created: 2022-01-05T16:20:19.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-12-22T13:42:47.000Z (12 days ago)
- Last Synced: 2024-12-25T00:48:43.501Z (9 days ago)
- Topics: cookiecutter, cookiecutter-poetry, cookiecutter-python, cookiecutter-template, devcontainer, docker, poetry, python, scaffolding, template
- Language: Dockerfile
- Homepage:
- Size: 263 KB
- Stars: 258
- Watchers: 12
- Forks: 37
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Open in Dev Containers](https://img.shields.io/static/v1?label=Dev%20Containers&message=Open&color=blue&logo=)](https://vscode.dev/redirect?url=vscode://ms-vscode-remote.remote-containers/cloneInVolume?url=https://github.com/superlinear-ai/poetry-cookiecutter) [![Open in GitHub Codespaces](https://img.shields.io/static/v1?label=GitHub%20Codespaces&message=Open&color=blue&logo=github)](https://github.com/codespaces/new?hide_repo_select=true&ref=main&repo=444870763)
# ๐ช Poetry Cookiecutter
A modern [Cookiecutter](https://github.com/cookiecutter/cookiecutter) template for scaffolding Python packages and apps.
## ๐ฟ Demo
See ๐ [Conformal Tights](https://github.com/superlinear-ai/conformal-tights) for an example of a Python package that is scaffolded with this template. Contributing to this package can be done with a single click by [starting a GitHub Codespace](https://github.com/codespaces/new?hide_repo_select=true&ref=main&repo=765698489&skip_quickstart=true) or [starting a Dev Container](https://vscode.dev/redirect?url=vscode://ms-vscode-remote.remote-containers/cloneInVolume?url=https://github.com/superlinear-ai/conformal-tights).
## ๐ Features
- ๐งโ๐ป Quick and reproducible development environments with VS Code's [Dev Containers](https://code.visualstudio.com/docs/devcontainers/containers), PyCharm's [Docker Compose interpreter](https://www.jetbrains.com/help/pycharm/using-docker-compose-as-a-remote-interpreter.html#docker-compose-remote), and [GitHub Codespaces](https://github.com/features/codespaces)
- ๐ Cross-platform support for Linux, macOS (Apple silicon and Intel), and Windows
- ๐ Modern shell prompt with [Starship](https://github.com/starship/starship)
- ๐ฆ Packaging and dependency management with [Poetry](https://github.com/python-poetry/poetry)
- ๐ Installing from and publishing to private package repositories and [PyPI](https://pypi.org/)
- โก๏ธ Task running with [Poe the Poet](https://github.com/nat-n/poethepoet)
- โ๏ธ Code formatting with [Ruff](https://github.com/charliermarsh/ruff)
- โ Code linting with [Pre-commit](https://pre-commit.com/), [Mypy](https://github.com/python/mypy), and [Ruff](https://github.com/charliermarsh/ruff)
- ๐ท Optionally follows the [Conventional Commits](https://www.conventionalcommits.org/) standard to automate [Semantic Versioning](https://semver.org/) and [Keep A Changelog](https://keepachangelog.com/) with [Commitizen](https://github.com/commitizen-tools/commitizen)
- ๐ Verified commits with [GPG](https://gnupg.org/)
- โป๏ธ Continuous integration with [GitHub Actions](https://docs.github.com/en/actions) or [GitLab CI/CD](https://docs.gitlab.com/ee/ci/)
- ๐งช Test coverage with [Coverage.py](https://github.com/nedbat/coveragepy)
- ๐ Scaffolding updates with [Cookiecutter](https://github.com/cookiecutter/cookiecutter) and [Cruft](https://github.com/cruft/cruft)
- ๐งฐ Dependency updates with [Dependabot](https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/about-dependabot-version-updates)## โจ Using
### Creating a new Python project
To create a new Python project with this template:
1. Install the latest [Cruft](https://github.com/cruft/cruft) and [Cookiecutter](https://github.com/cookiecutter/cookiecutter) in your [Python environment](https://github.com/pyenv/pyenv-virtualenv) with:
```sh
pip install --upgrade "cruft>=2.12.0" "cookiecutter>=2.1.1"
```2. [Create a new repository](https://github.com/new) for your Python project, then clone it locally.
3. Run the following command in the parent directory of the cloned repository to apply the Poetry Cookiecutter template:```sh
cruft create -f https://github.com/superlinear-ai/poetry-cookiecutter
```
โ ๏ธ If your repository name โ the project's slugified name
If your repository name differs from your project's slugified name (see `project_name` in the [Template parameters](https://github.com/superlinear-ai/poetry-cookiecutter#-template-parameters) below), you will need to copy the scaffolded project into the repository with:
```sh
cp -r {project-name}/ {repository-name}/
```
### Updating your Python project
To update your Python project to the latest template version:
1. Update the project while verifying the existing template parameters and setting any new parameters, if there are any:
```sh
cruft update --cookiecutter-input
```2. If any of the file updates failed, resolve them by inspecting the corresponding `.rej` files.
## ๐ค Template parameters
| Parameter | Description |
| ------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `project_type`
["package", "app"] | Whether the project is a publishable Python package or a deployable Python app. |
| `project_name`
"Spline Reticulator" | The name of the project. Will be slugified to `snake_case` for importing and `kebab-case` for installing. For example, `My Package` will be `my_package` for importing and `my-package` for installing. |
| `project_description`
"A Python package that reticulates splines." | A single-line description of the project. |
| `project_url`
"" | The URL to the project's repository. |
| `author_name`
"John Smith" | The full name of the primary author of the project. |
| `author_email`
"" | The email address of the primary author of the project. |
| `python_version`
"3.10" | The minimum Python version that the project requires. |
| `development_environment`
["simple", "strict"] | Whether to configure the development environment with a focus on simplicity or with a focus on strictness. In strict mode, additional [Ruff rules](https://docs.astral.sh/ruff/rules/) are added, and tools such as [Mypy](https://github.com/python/mypy) and [Pytest](https://github.com/pytest-dev/pytest) are set to strict mode. |
| `with_conventional_commits`
["0", "1"] | If "1", [Commitizen](https://github.com/commitizen-tools/commitizen) will verify that your commits follow the [Conventional Commits](https://www.conventionalcommits.org/) standard. In return, `cz bump` may be used to automate [Semantic Versioning](https://semver.org/) and [Keep A Changelog](https://keepachangelog.com/). |
| `with_fastapi_api`
["0", "1"] | If "1", [FastAPI](https://github.com/tiangolo/fastapi) is added as a run time dependency, FastAPI API stubs and tests are added, a `poe api` command for serving the API is added. |
| `with_typer_cli`
["0", "1"] | If "1", [Typer](https://github.com/tiangolo/typer) is added as a run time dependency, Typer CLI stubs and tests are added, the package itself is registered as a CLI. |
| `continuous_integration`
["GitHub", "GitLab"] | Whether to include a [GitHub Actions](https://docs.github.com/en/actions) or a [GitLab CI/CD](https://docs.gitlab.com/ee/ci/) continuous integration workflow for testing the project, and publishing the package or deploying the app. |
| `private_package_repository_name`
"Private Package Repository" | Optional name of a private package repository to install packages from and publish this package to. |
| `private_package_repository_url`
"" | Optional URL of a private package repository to install packages from and publish this package to. Make sure to include the `/simple` suffix. For instance, when using a GitLab Package Registry this value should be of the form `https://gitlab.com/api/v4/projects/` `{project_id}` `/packages/pypi/simple`. |