A better poetry publish experience.
Project description
🗞 Publicator
A better
poetry publish
experience.
While Poetry finally brings us a sane solution for publishing and maintaining Python packages, many developers crave for a more enhanced and safer user experience. Publicator aims to offer a convenient tool for everyday work.
Licensed under MIT.
Features
Supported
- Ensures you are publishing from your release branch (
main
andmaster
by default) - Ensures the working directory is clean and latest changes are pulled
- Reinstalls dependencies to ensure your project works with the latest dependency tree
- Ensures your Python version is supported by the project and its dependencies
- Runs the tests
- Bumps the version in
pyproject.toml
and creates a Git tag based on it - Publishes the new version to Python Package Index or custom repository
- Pushes commits and tags (newly & previously created) to your Git server
- See what will be executed with preview mode, without pushing or publishing anything remotely
Planned
- Open a prefilled GitHub Releases draft after publishing
Prerequisites
- Python 3.8 or later
- Poetry 1.1 or later
- Git 2.11 or later
Install
Install or run directly using pipx
, which manages an isolated virtual environment for you.
pipx install publicator
pipx run publicator <version>
Alternatively, add it as dependency to your Poetry project.
poetry add --dev publicator
poetry run publicator <version>
Usage
$ publicator --help
Usage: publicator [OPTIONS] version
Arguments:
version can be a valid semver or one of: patch, minor, major, prepatch,
preminor, premajor, prerelease [required]
Options:
--repository name Custom repository for publishing (must be
specified in pyproject.toml)
--any-branch / --no-any-branch Allow publishing from any branch [default:
no-any-branch]
--clean / --no-clean Ensure you're working with the latest
changes [default: clean]
--tag / --no-tag Create a new tag for Git [default: tag]
--publish / --no-publish Publish the package to the registry
[default: publish]
--push / --no-push Push commits and tags to Git [default:
push]
--test-script TEXT Name of the test script to run under the
current virtual environment [default:
pytest]
--template TEXT Commit message template (`%s` will be
replaced with the new version tag)
[default: release: %s]
--release-draft / --no-release-draft
Opens a pre-filled GitHub release page with
browser if the current project is hosted on
GitHub [default: release-draft]
--install-completion [bash|zsh|fish|powershell|pwsh]
Install completion for the specified shell.
--show-completion [bash|zsh|fish|powershell|pwsh]
Show completion for the specified shell, to
copy it or customize the installation.
--help Show this message and exit.
Configuration
Flags described above enable more granular usage. For example, in CI/CD pipelines you might want to disable publishing the package to registry or disable creating Git tags depending on your use case.
If you'd rather skip on everything and check what would be executed (dry run), you can activate a preview mode via environment variable like so:
PUBLICATOR_PREVIEW=true publicator <version>
Shell Completion
Publicator stands on the shoulders of Typer, which is a robust CLI library for Python. You can generate TAB completions for common shells such as Bash, ZSH, Fish, and Powershell.
publicator --install-completion <shell>
Contributing
See here for instructions.
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
Hashes for publicator-0.5.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8c183f0477bd9f29acd87b623e23fda74e61054a2f79e201d8300d3dbd71f8a9 |
|
MD5 | 24a8e311d1f2eb5f297524f78907adad |
|
BLAKE2b-256 | 857318d7b0937a3c9fdab58a48bd1dfaa90e8431ef5c132367522c84c6d4c92a |