Skip to main content

Package configuration example using bleeding edge toolset.

Project description

nup

This package allows to quickly initialise new Python package using bleeding edge tools like linters, just run:

  • pip install nup
  • nup <your-package-name>

Now you are able to:

  • cd <your-package-name>
  • make check # To run tests and linters
  • make publish # To publish your new package to PyPi.org to make it accessable to everyone

This is also a boilerplate for a new python package, so you can create a new package this way as well:

  • git clone git@github.com:albertas/nup.git <your-package-name>
  • cd <your-package-name>
  • make init <your-package-name> - to start your modern package.

Development

Commonly used commands for package development:

  • make check - run unit tests and linters.
  • make fix - format code and fix detected fixable issues.
  • make publish - publishes current package version to pypi.org.
  • make compile - bump and freeze dependency versions in requirements*.txt files
  • make sync - upgrade installed dependencies in Virtual Environment (executed after make compile)

Toolset

This package uses these cutting edge tools:

  • ruff - for linting and code formatting
  • mypy - for type checking
  • pip-audit - for known vulnerability detection in dependencies
  • deadcode - for unused code detection
  • pytest - for collecting and running unit tests
  • coverage - for code coverage by unit tests
  • hatch - for publishing package to pypi.org
  • uv - for Python virtual environment and dependency management
  • pyproject.toml - configuration file for all tools
  • Makefile - aliases for commonly used command line commands

Feature requests:

  • Newly installed package could have virtualenv initialised.
  • Check if git is available before trying to initialise the repository.
  • remove init Makefile alias and cli.py command python files.
  • make a cli command: this package should be installable. Ideally this flow should work:
    • pip install nup
    • nup mynewpackage
    • cd mynewpackage && make check && make publish
  • Add pre-commit hooks with all the tools enabled.
  • codspeed.io could be considered for Continuous integration pipeline

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

nup-0.0.1.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

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

nup-0.0.1-py3-none-any.whl (3.3 kB view details)

Uploaded Python 3

File details

Details for the file nup-0.0.1.tar.gz.

File metadata

  • Download URL: nup-0.0.1.tar.gz
  • Upload date:
  • Size: 4.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for nup-0.0.1.tar.gz
Algorithm Hash digest
SHA256 4fc366d8f22a0be2e1ac7c9a4dc124a69902352df14adf2119170aa66b853456
MD5 046285f8c38360915d379dff846d5152
BLAKE2b-256 b3b54a7fd0aceb1d48b7b2d3ad5344baf7b1990fa47a5380f1a8b80400256791

See more details on using hashes here.

File details

Details for the file nup-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: nup-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 3.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for nup-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5c95f706458e4c51ea7f273ba93afeb45a186fca2197f69fbbcda9ec2a82d9ac
MD5 bbcabad6be3aa63de9580ae3fb5763aa
BLAKE2b-256 fdfb4a8d9227499fdab5d72e6196acb606f617450ced398218ca9f3cbfbab65e

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