Skip to main content

A simple importable Python package

Project description

import-ready

image image image image image image

This repository demonstrates steps needed to publish an importable Python package first to TestPyPI, and second to PyPI. If this demonstration deviates from best practice in any way, please submit an issue on GitHub.

Inside import-ready is a package called huntsville_havoc that divulges a couple of bona fide secrets that most diehard SPHL Huntsville Havoc fans don't know.

Prepare the Package

  1. Prepare your environment before installing Python packages.
  2. Update version in setup.py per semantic versioning guidance.

Test in Development Environment

Run as follows from the top level directory in a clean venv with pip-tools installed:

python -m piptools compile --generate-hashes --allow-unsafe dev-requirements.in
dos2unix dev-requirements.txt
python -m pip install -r dev-requirements.txt
python -m pytest -s tests

Publish to TestPyPI

  1. Git commit, tag, & push all desired edits for release.
  2. Create a new release in GitHub to mirror your new version.
  3. Generate distribution archives for your package.
  4. Upload your package to TestPyPI.

Test the TestPyPI Published Package

Run as follows from some random directory (to prove to yourself you're not "cheating" with some locally obtained import-ready) in another clean venv with pip-tools installed:

cp <path to import-ready>/tests/origins_test.py .
cp <path to import-ready>/tests/pubtest-requirements.in .
python -m piptools compile --generate-hashes pubtest-requirements.in
dos2unix pubtest-requirements.txt
python -m pip install -r pubtest-requirements.txt
python -m pytest -s

Publish to PyPI

After completing the above steps, upload your package to PyPI.

Test the real deal

Post-publish test, importing import-ready itself back from PyPI. Run as follows from some other random directory (same reason as for TestPyPI testing above) in yet another clean venv with pip-tools installed:

cp <path to import-ready>/tests/origins_test.py .
cp <path to import-ready>/tests/pub-requirements.in .
python -m piptools compile --generate-hashes pub-requirements.in
dos2unix pub-requirements.txt
python -m pip install -r pub-requirements.txt
python -m pytest -s

Thanks

License

MIT.

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

import-ready-0.10.3.tar.gz (3.9 kB view details)

Uploaded Source

Built Distribution

import_ready-0.10.3-py3-none-any.whl (4.0 kB view details)

Uploaded Python 3

File details

Details for the file import-ready-0.10.3.tar.gz.

File metadata

  • Download URL: import-ready-0.10.3.tar.gz
  • Upload date:
  • Size: 3.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for import-ready-0.10.3.tar.gz
Algorithm Hash digest
SHA256 2bd4723991fa4ddb333fd3d7f0ba448a7353a7a09c28cd444de9b1b4e4ed6c63
MD5 e2729c01daa96e0461b53db037863d5a
BLAKE2b-256 17cfb783a08c0b57748b896f72172063b5c8ad83333595e787cb2c5cf6d50099

See more details on using hashes here.

File details

Details for the file import_ready-0.10.3-py3-none-any.whl.

File metadata

  • Download URL: import_ready-0.10.3-py3-none-any.whl
  • Upload date:
  • Size: 4.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for import_ready-0.10.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b315d7609357e93573c671312dc6032ac9c3a94f26b9e4c155ae8d056bb34e46
MD5 821e60339648ebee1bd530f0a5543465
BLAKE2b-256 5b8deff95a7584973542d00dab4cd770a0a7c7c31a6219020b105b5db3a40724

See more details on using hashes here.

Supported by

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