Skip to main content

No project description provided

Project description

pyplate

Overview

A boilerplate for Python 3 projects

  • Styles code with black
  • Lints code with flake8
  • Sorts imports with isort
  • Validates git commits (and/or formats changes) with pre-commit
  • Configures VSCode to use black, flake8, isort, etc. You'll want to install the recommended VSCode extensions, when prompted, as defined in .vscode/extensions.json

Dev Prerequisites

  • python 3.12
  • pipx, an optional tool for prerequisite installs
  • poetry (install globally with pipx install poetry)
  • flake8 (install globally with pipx install flake8)
    • flake8-bugbear extension (install with pipx inject flake8 flake8-bugbear)
    • flake8-naming extension (install with pipx inject flake8 pep8-naming)
  • black (install globally with pipx install black)
  • pre-commit (install globally with pipx install pre-commit)
  • just, a Justfile command runner

Windows

Justfile support for Windows requires cygwin. Once installed your PATH will need to be updated to resolve cygpath.exe (probably C:\cygwin64\bin). Justfile will forward any targets with shebangs starting with / to cygwin for execution.

Consider using a bash terminal through WSL instead.

Updating python version:

  • Update python version in Dev Prerequisites above
  • Update [tool.poetry.dependencies] section of pyproject.toml
  • Update pyupgrade hook in .pre-commit-config.yaml
  • Update python version in .gitlab-ci.yml

Justfile Targets

  • install: installs poetry dependencies and pre-commit git hooks
  • update_boilerplate: fetches and applies updates from the boilerplate remote
  • test: runs pytest with test coverage report

Usage

To start a new project, clone this repository, then rename the origin remote to boilerplate

git remote rename origin boilerplate

Then add your new remote origin

git remote add origin <remote repository>

Remove and replace (or rename) the pysrc/pyplate module to start your new project. Be sure to also replace pyplate references in pyproject.toml with your new module / project name.

Be sure to update .gitlab-ci.yml as needed. The PACKAGE_NAME variable should match the pyproject.toml tool.poetry.name field, otherwise the CI may publish incorrectly.

For the gitlab CI to publish you need to add two environment variables to your gitlab repository:

You can also add this repository to an existing project as the boilerplate remote:

git remote add boilerplate git@github.com:tysonholub/pyplate.git

The following should help apply the boilerplate history into an existing project. Depending on your existing project structure, you may want to move everything into a backup/ folder first, then refactor accordingly after merging the boilerplate remote.

git merge boilerplate/main --no-ff --allow-unrelated-histories

Then moving forward, run just update_boilerplate to pull latest changes from the boilerplate remote. NOTE: you must keep the boilerplate remote history intact to successfully merge updates from the boilerplate remote.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyplate_boilerplate-1.0.0.tar.gz (4.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyplate_boilerplate-1.0.0-py3-none-any.whl (3.4 kB view details)

Uploaded Python 3

File details

Details for the file pyplate_boilerplate-1.0.0.tar.gz.

File metadata

  • Download URL: pyplate_boilerplate-1.0.0.tar.gz
  • Upload date:
  • Size: 4.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.13.1 Linux/5.15.154+

File hashes

Hashes for pyplate_boilerplate-1.0.0.tar.gz
Algorithm Hash digest
SHA256 8d4d4e6adc5282255d7bc4f6847a85d1d0e5f713757153c6733bd88d88e5e66d
MD5 2c61d3dff2f5ea635b221124171a607a
BLAKE2b-256 e9b8cc7a1c03a573e442fc998c2ca3c6988dbb87d012cd74176e896a1954e04f

See more details on using hashes here.

File details

Details for the file pyplate_boilerplate-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pyplate_boilerplate-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 eb6bac07644b13cd02855dd0f449d4e1e1df1db0273fc4a7105213d82a2a2972
MD5 5c4c5f1025cded2e3c1972a6a1bc89dd
BLAKE2b-256 2cf6ad974268f4d5cbcc42252c4e3326ebb1b117579d24ba43990a6b3b9146e9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page