Skip to content

Cookie cutter recipe for bootstrapping a modern Python module project

License

Notifications You must be signed in to change notification settings

gsemet/python-module-cookiecutter

Repository files navigation

Modern Python Module Cookiecutter (Library and Application)

image

Cookie cutter recipe for bootstrapping an state of the art Python module using free services and the best "opensource" mindset.

TD;DR

Pipenv + PBR + Travis + Auto Pipy publish + autoformatting (yapf, isort) + static checks (pylint, flake8, mypy) + sphinx doc, for both "Library" and "Application" use cases

Python Module Cookiecutter Features

See https://github.com/audreyr/cookiecutter for more information about Cookiecutter.

Feature of the "Python Module" Cookiecutter recipe:

  • Use Pipenv to describe dependencies in Pipfile
  • Source code is hosted on Github
  • Free software: MIT license
  • Badges for Travis, Coverage, Pypi, ReadTheDoc
  • handle automatic versioning derived from Git Tag with PBR. It also automatic creates ChangeLog and AUTHORS files from Git history
  • a Makefile allows easy daily-life for developers and maintainers
  • isort, Yapf, AutoPep8 code formatting
  • Pylint, Flake8, Mypy: static checks
  • Editorconfig: autoconfiguration of almost any editor
  • build and unit test on Travis-CI
  • Use Pytest for Unit testing
  • automatic deployment to Pypi of distribution packages and wheels on successful build on a tagged commit ("Tag to release" principle)
  • Automatically set Travis CI deployment token with travis_pypi_setup.py script
  • Coverage unit test code coverage report
  • Sphinx docs: Documentation ready for generation and publication to ReadTheDoc

Please note this cookiecutter does not support Python 2 intentionnaly.

Usage

Bootstrap

Do not create a folder for your project, it will be automatically created.

Boostrap your Python library (or app):

$ pip3 install --user --upgrade pip pipenv cookiecutter
# or
$ python3 -m pip install --user --upgrade pip pipenv cookiecutter

# Then the cookiecutter can be invoked:

$ cookiecutter https://github.com/gsemet/python-module-cookiecutter
# or
$ cookiecutter gh:gsemet/python-module-cookiecutter

Questions upon bootstraping

This cookiecutter will ask you a series of questions:

  • team_name: Author name. To fill the "Author" field of the module manifest.
  • email: Author email. To fill the "email" field of the module manifest
  • is_application: y for application, n for library (see bellow for explanation)
  • project_name: Human Readable Project Name, for example "My wonderful library"
  • project_short_description: one-line description of the project
  • project_slug: project name without space and other special charact. Name of the python modules.
  • github_username: GitHub user name
  • github_repository_name: project name on GitHub
  • pypi_username: username on Pypi
  • use_pypi_deployment_with_travis: deploy with travis on successful tag build
  • docker_build: create Dockerfile
  • add_git_remote_after_scapfolding: add git remote to GitHub project

Library vs Application

It is important to differentiate a Python "Library" and a Python "Application". Each form have its own life and should handle dependencies differently:

  • To ensure stability and reproductibility of the deployment of an Application, a good practice is to freeze the versions of all its dependencies (both direct and indirect), so, no matter what happens for example on https://pypi.python.org, for example a new, buggy version of a package your application relies on might actually break your deployment. Without proper "frozen" dependencies management, you might get this dependency library deployed on production without any validation.
  • A Library does not have any meaning alone, it is always used by at least an application. The dependencies of a library should not be frozen and should be defined using version ranges. For example, let's imagine your library depends on a module A in version 1.0. Your library is then used in an application that also depends on the same module A, but in version 1.2. The best way to handle this is to let libraries describe the range of supported versions, and let the package manager (Pip) find the best candidates.

Setup for development:

$ make dev

Execute unit tests:

$ make test

Build package (source, binary and wheels):

Use it for most package without low level system dependencies.

make dists

To register Pipy deployment:

  • commit your work!
  • enable your project on Travis
  • execute pipenv run python travis_pypi_setup.py

Create a release:

make tag-pbr

On successful travis build on the Tag branch, your Pypi package will be updated automatically.

Configuration

You will need to configure .travis.yml to enable automatic PyPi deployment, or use the provided travis_pypi_setup.py script.

About

Cookie cutter recipe for bootstrapping a modern Python module project

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published