A GitHub template for Python projects using Pyenv and Poetry
Project description
Python Pyenv Poetry Template
A template repository for Python projects using Pyenv and Poetry.
Makefile
The project relies heavily on make
, which is used to run all commands. It has been tested on macOS and Ubuntu 22.04. Windows users are strongly encouraged to install WSL.
Run make
to see the list of the available targets.
$ make
Usage:
make [target] [ARGS="..."]
Info
help Show this help message
info Show development environment info
System
python Check if Python is installed
virtualenv Check if virtualenv exists and activate it - create it if not
poetry Check if Poetry is installed
poetry-update Update Poetry
Project
project/install Install the project for development
project/production Install the project for production
project/update Update the project
project/clean Clean the project - removes all cache dirs and stamp files
project/reset Cleans plus removes the virtual environment (use ARGS="hard" to re-initialize the project)
project/run Run the project
project/tests Run the tests
project/build Build the project as a package
project/buildall Build the project package and generate the documentation
project/publish Publish the project to PyPI
project/publishall Publish the project package to PyPI and the documentation to GitHub Pages
project/deps-export Export the project's dependencies to requirements*.txt files
Check
check/format Format the code
check/lint Lint the code
check/precommit Run all pre-commit checks
Release
release/version Tag a new release version
release/publish Push the tagged version to origin - triggers the release and docker actions
Docker
docker/build Build the Docker image
docker/run Run the Docker container
docker/all Build and run the Docker container
docker/stop Stop the Docker container
docker/remove Remove the Docker image, container, and volumes
Documentation
docs/build Generate the project documentation
docs/serve Serve the project documentation locally
docs/publish Publish the project documentation to GitHub Pages (use ARGS="--force" to force the deployment)
Installation
This is a template repository, so first things first, you create a new GitHub repository and choose this as its template. After that, follow the installation steps below.
-
Clone the repository:
git clone https://github.com/<your-github-name>/<your-project-name>.git
-
Navigate to the project directory:
cd <your-project-name>
-
Check the status of the dev environment:
make info
will list the tools currently installed and the default value of project vars, as in the example below:$ make info System: OS: Darwin Shell: /bin/bash - GNU bash, version 3.2.57(1)-release (arm64-apple-darwin23) Make: GNU Make 3.81 Git: git version 2.39.3 (Apple Git-146) Project: Project name: python_pyenv_poetry_template Project directory: /Users/fabio/Dev/git/python_pyenv_poetry_template Project author: Fabio Calefato (bateman <fcalefato@gmail.com>) Project repository: https://github.com/bateman/python_pyenv_poetry_template Project version: 0.4.4 Project license: MIT Project description: 'A GitHub template for Python projects using Pyenv and Poetry' Python: Python version: 3.12.1 Pyenv version: pyenv 2.3.36 Pyenv root: /Users/fabio/.pyenv Pyenv virtualenv name: venvp3t Poetry version: Poetry (version 1.8.2) Docker: Docker: Docker version 25.0.3, build 4debf41 Docker Compose: Docker Compose version v2.24.6-desktop.1 Docker image name: p3t Docker container name: p3t
-
If any of the needed tools are missing, it will be marked as 'not installed'. Install them and re-run
make info
to ensure the tools are now correctly installed and in your PATH. -
Update the project variables values by editing
pyproject.toml
. In addition, you can add any of the variables in the list below to aMakefile.env
file to override the default values used in theMakefile
. You can check the variables configuration usingmake info
.PYTHON_VERSION=3.12.1 PYENV_VIRTUALENV_NAME=venvp3t DOCKER_CONTAINER_NAME=p3t DOCKER_IMAGE_NAME=p3t
-
To create the virtual environment, run
make virtualenv
. Note that this will also check for the requested Python version; if not available, it will ask you to usepyenv
to install it. -
To complete the installation for development purposes, run
make project/install
-- this will install all development dependencies. Otherwise, for production purposes only, runmake project/production
.
[!TIP] The installation step will install some 'default' dependencies, such as
rich
andpretty-errors
, but also dev-dependecies, such asruff
andpytest
. Edit thepyproject.toml
to add/remove dependencies before runningmake project/install
. Otherwise, you can add and remove dependencies later usingpoetry add
andpoetry remove
commands.
[!NOTE] The
PROJECT_NAME
var will be converted to lowercase and whitespaces will be replaced by_
. This value will be the name of your project module.
[!CAUTION] The
Makefile.env
should specify at least thePYTHON_VERSION=...
. Otherwise, the GitHub Actions will fail. Also, make sure that the Python version specified inMakefile.env
(e.g., 3.12.1) satisfies the requirements inpyproject.toml
file (e.g., python = "^3.12").
Development
The project uses the following development libraries:
ruff
: for code linting and formatting.mypy
: for static type-checking.bandit
: for security analysis.pre-commit
: for automating all the checks above before committing.
[!TIP] To manually run code formatting and linting, run
make check/format
andmake check/lint
, respectively. To execute all the checks, stage your changes, then runmake check/precommit
.
Execution
- To run the project:
make project/run
- To run the tests:
make project/tests
[!TIP] Pass parameters using the ARGS variable (e.g.,
make project/run ARGS="--text Ciao --color red"
).
[!NOTE] Tests are executed using
pytest
. Test coverage is calculated using the pluginpytest-cov
.
[!IMPORTANT] Pushing new commits to GitHub, will trigger the GitHub Action defined in
test.yml
, which will try to upload the coverage report to Codecov. To ensure correct execution, first log in to Codecov and enable the coverage report for your repository; this will generate aCODECOV_TOKEN
. Then, add theCODECOV_TOKEN
to your repository's 'Actions secrets and variables' settings page.
Update
Run make project/update
to update all the dependencies using poetry
.
Build
Run make project/build
to build the project as a Python package.
The *.tar.gz
and *.whl
will be placed in the BUILD
directory (by default dist/
).
Release
- Add your pending changes to the staging, commit, and push them to the origin.
- Apply a semver tag to your repository by updating the current project version (note that this will update
pyproject.toml
accordingly):make tag/patch
- e.g., 0.1.0 -> 0.1.1make tag/minor
- e.g., 0.1.1 -> 0.2.0make tag/major
- e.g., 0.2.0 -> 1.0.0
- Run
make tag/push
to trigger the upload of a new release by executing the GitHub Actionrelease.yml
.
GitHub Actions
As shown in the table below, there are four GitHub Actions workflow. Take note on the event triggering the run and the Secrets needed for a succesfull execution.
Action name | Purpose | Runs on | Secrets |
---|---|---|---|
release.yml |
Release package to PyPI and GitHub 📦 | tag push | - |
docker.yml |
Push image to DockerHub 🚀 | tag push | DOCKERHUB_USERNAME , DOCKERHUB_TOKEN |
tests.yml |
Run tests and upload coverage to Codecov 📊 | commit push on branches != main , manual |
CODECOV_TOKEN |
docs.yml |
Upload documentation to GitHub Pages 📓 | commit push on main branch (path docs/** ), manual |
RELEASE_TOKEN |
[!CAUTION] Follow this guide and configure PyPI’s trusted publishing implementation to connect to GitHub Actions CI/CD. Otherwise, the release workflow will fail.
Publish to PyPI
To manually publish your package to PyPI, run make project/publish
. If necessary, this will build the project as a Python package and upload the generated *.tar.gz
and *.whl
files to PyPI.
[!IMPORTANT] Before trying manually publish your package to PyPI, make sure you have a valid API token. Then, you need manually configure
poetry
running the following command:poetry config pypi-token.pypi <your-api-token>
.
Documentation
- Run
make docs/build
to build the project documentation usingmkdocstrings
. The documentation will be generated from your project files' comments in docstring format. The documentation files will be stored in theDOCS_SITE
directory (by defaultsite/
). - Run
make docs/serve
to browse the built site locally, at http://127.0.0.1:8000/your-github-name/your-project-name/ - Run
make docs/publish
to publish the documentation site as GitHub pages. The content will be published to a separate branch, namedgh-pages
. Access the documentation online at https://your-github-name.github.io/your-project-name/
[!NOTE] After the first deployment to your GitHub repository, your repository Pages settings (Settings > Pages) will be automatically updated to point to the documentation site content stored in the
gh-pages
branch.
[!IMPORTANT] You will have to edit the
mkdocs.yml
file to adapt it to your project's specifics. For example, it uses by default thereadthedocs
theme.
[!WARNING] Before being able to succesfully publishing the project documentation to GitHub pages, you need to add a
RELEASE_TOKEN
to your repository's 'Actions secrets and variables' settings page. TheRELEASE_TOKEN
is generated from your GitHub 'Developer Settings' page. Make sure to select the fullrepo
scope when generating it.
Docker
- To build the Docker container:
make docker/build
- To start the Docker container and run the application:
make docker/run
- To build and run:
make docker/all
[!TIP] Before building the container, edit
Dockerfile
and change the name of the folder containing your Python module (by defaultpython_pyenv_poetry_template
).
[!WARNING] Pushing a new tag to GitHub will trigger the GitHub Action defined in
docker.yml
. To ensure correct execution, you first need to add theDOCKERHUB_USERNAME
andDOCKERHUB_TOKEN
secrets to your repository's 'Actions secrets and variables' settings page.
Contributing
Contributions are welcome! Follow these steps:
- Fork the repository.
- Create a new branch:
git checkout -b feature-name
- Make your changes and commit:
git commit -m 'Add feature'
- Push to the branch:
git push origin feature-name
- Submit a pull request.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file python_pyenv_poetry_template-0.9.0.tar.gz
.
File metadata
- Download URL: python_pyenv_poetry_template-0.9.0.tar.gz
- Upload date:
- Size: 7.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 43387e11007ac41475cfd7d689d75a801baef0c54035e4e37172e768768b822b |
|
MD5 | b87b17c0c260ac10eda0794ddeb1d4f3 |
|
BLAKE2b-256 | f5813e44750b32eb14f1440d7ecebb870f86a13276c0de91ab3c324a484dadb6 |
File details
Details for the file python_pyenv_poetry_template-0.9.0-py3-none-any.whl
.
File metadata
- Download URL: python_pyenv_poetry_template-0.9.0-py3-none-any.whl
- Upload date:
- Size: 8.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d4c99ffcdeb9811fbd2b3b7ce5ce760a707b1e8a753b7028b57dd0a3c5fef18b |
|
MD5 | 5d72d99918970d94be90abe888d75dde |
|
BLAKE2b-256 | 13cf22baa3888f675f49c8d0b8fb0f2be38a1f3900ccab1a86e31046f4e88241 |