Skip to main content

releasecmd is a release subcommand for setup.py (setuptools.setup). the subcommand create a git tag and push, and upload packages to PyPI.

Project description

releasecmd

PyPI package version Supported Python versions

Summary

releasecmd is a release subcommand for setup.py (setuptools.setup). The subcommand create a git tag and push, and upload packages to PyPI.

The subcommand class (releasecmd.ReleaseCommand) is implemented as a subclass of setuptools.Command class. The release subcommand will do the followings:

  1. Find a file that defined the package version (e.g. <package>/__init__.py)

  2. Create .asc (ASCII-armored signature) files of the package binary files if --sign option is specified
  3. Create a git tag from the package version information
    • GPG signing to the git tag if --sign option is specified

  4. Push git tags

  5. Upload package files to PyPI by using twine
    • uploading for both the package binaries and .asc files

Installation

pip install releasecmd

Usage

setup.py:
import setuptools

from releasecmd import ReleaseCommand

setuptools.setup(
    ...
    cmdclass={"release": ReleaseCommand},
)

release command options

Options for 'ReleaseCommand' command:
  --skip-tagging  skip a git tag creation
  --dry-run       do no harm
  --sign          make a GPG-signed tag
  --search-dir    specify a root directory path to search a version file.
                  defaults to the current directory.
  --tag-template  specify git tag format. defaults to 'v{version}'.
  --version       specify version manually

Example

$ python3 setup.py release
running release
[get the version from ./releasecmd/__version__.py]
[create a git tag: v0.0.15]
[push git tags]
[upload the package to PyPI]
...

prerequisite: package binaries must bein in the dist/ directory.

Specify version manually

You can specify a vesion manually by --version option:

$ python3 setup.py release --version 0.1.0
[create a git tag: v0.1.0]
[push git tags]
[upload packages to PyPI]

Create a GPG signed tag and upload packages

$ python3 setup.py release --sign
running release
[get the version from ./releasecmd/__version__.py]
[create a .asc file for releasecmd-0.1.0.tar.gz]
[create a .asc file for releasecmd-0.1.0-py2.py3-none-any.whl]
[create a git tag with gpg signing: v0.1.0]
[push git tags]
[upload packages to PyPI]
...

Skip create a git tag and upload packages

$ python3 setup.py release --skip-tagging
running release
[get the version from ./releasecmd/__version__.py]
[push git tags]
[upload packages to PyPI]
...

Dependencies

  • Python 3.6+

  • Git

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

releasecmd-0.6.0.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

releasecmd-0.6.0-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file releasecmd-0.6.0.tar.gz.

File metadata

  • Download URL: releasecmd-0.6.0.tar.gz
  • Upload date:
  • Size: 7.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.3.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.5

File hashes

Hashes for releasecmd-0.6.0.tar.gz
Algorithm Hash digest
SHA256 369594b100885c14ee6a9dfd3a9e3bb74423425465544da97a68ad751feb378c
MD5 1ad652d576f1fdea3ca78dbd2336c24d
BLAKE2b-256 1ef6c5f930be12e28e1ccebc7e45bfa477dae8706a90d4b8796752946860dd1f

See more details on using hashes here.

File details

Details for the file releasecmd-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: releasecmd-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 6.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.3.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.5

File hashes

Hashes for releasecmd-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 740527f318095329acd4ac96ca48d9246fb303b06188d287744b7d68c67bb8a4
MD5 007c2d4c257d092a69b4379b4c849a68
BLAKE2b-256 3680905b9429a6f1fd618a7e1defc543ebc273f0048b4d96022167dfd2d74415

See more details on using hashes here.

Supported by

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