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 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

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
  --dir           specify a search root directory path. defaults to the
                  current directory.
  --tag-template  specify git tag format. defaults to 'v{version}'.
  --version       specify version manually

Example

$ python 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:

$ python 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

$ python 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

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

Dependencies

  • Python 3.5+

  • 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.4.0.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

releasecmd-0.4.0-py3-none-any.whl (5.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: releasecmd-0.4.0.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.5

File hashes

Hashes for releasecmd-0.4.0.tar.gz
Algorithm Hash digest
SHA256 d78a8eef30185b0a5dd9ce2479544ac03c639ae1e2625d39e5c572c15e31af0f
MD5 ffc4f62dda97450f32f9f47c8261cf0b
BLAKE2b-256 4fa9c1b7fb7256de205555255d219a760fe63dd550083883485888bc330be8a7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: releasecmd-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 5.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.5

File hashes

Hashes for releasecmd-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7ab97e16eaad1ba97e6eeccc3ee839b227302a355e5e68c1d98aa43b58534d09
MD5 48d5a5875112a32d20dbae463402c737
BLAKE2b-256 a0dca9c486de19123292e0cd481368040509df3b5ce59847066008d71d1d327d

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