Skip to main content

Automatic semantic versioning for python projects

Project description

Automatic semantic versioning for python projects. This is an python implementation of the semantic-release for js by Stephan Bönnemann. If you find this topic interesting you should check out his talk from JSConf Budapest.

Build status PyPI version

Install

pip install python-semantic-release

Usage

The general idea is to have some sort of tag in commit messages that indicates certain types of changes. If a commit message lack a tag it is ignored. Running release can be run locally or from a CI service.

Usage: semantic-release [OPTIONS] COMMAND

Options:
  --major  Force major version.
  --minor  Force minor version.
  --patch  Force patch version.
  --noop   No-operations mode, finds the new version number without changing it.
  --post   If used with the changelog command, the changelog will be posted to the release api.
  --retry  Retry the same release, do not bump.
  --help   Show this message and exit.

Commands

  • version - Create a new release. Will change the version, commit it and tag it.

  • publish - Runs version before pushing to git and uploading to pypi.

  • changelog - Generates the changelog for the next release.

Running commands from setup.py

Add the following to your setup.py and you will be able to run python setup.py <command> as you would semantic-release <command>.

try:
    from semantic_release import setup_hook
    setup_hook(sys.argv)
except ImportError:
    pass

Configuration

Configuration belongs in semantic_release section of the setup.cfg file in your project. Details about configuration options can be found in the configuration documentation.

Development

Install this module and the development dependencies:

python setup.py develop
pip install -r requirements/dev.txt

Testing

To test your modifications locally:

tox

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

python-semantic-release-4.1.1.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

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

python_semantic_release-4.1.1-py3-none-any.whl (24.8 kB view details)

Uploaded Python 3

File details

Details for the file python-semantic-release-4.1.1.tar.gz.

File metadata

  • Download URL: python-semantic-release-4.1.1.tar.gz
  • Upload date:
  • Size: 15.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.1

File hashes

Hashes for python-semantic-release-4.1.1.tar.gz
Algorithm Hash digest
SHA256 d36ae9ea27eef1359403348b26105e615038541ac7271b9e775c079348e685b3
MD5 8f968478cdfaa5e37cf67e88bf9dbc05
BLAKE2b-256 3e4125a521b6d86183537f779a926e7b4a76cf18081bdda2abd57cc5051aca7f

See more details on using hashes here.

File details

Details for the file python_semantic_release-4.1.1-py3-none-any.whl.

File metadata

  • Download URL: python_semantic_release-4.1.1-py3-none-any.whl
  • Upload date:
  • Size: 24.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.1

File hashes

Hashes for python_semantic_release-4.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7e6645400e0f94e49a134270f6296fee8dafb5ac6d18af87fa61ed8693dbb9b6
MD5 83f45818f9040b283593085512180266
BLAKE2b-256 5644b94fa7aee29f7844d27c2ab0a49826b0b3f24204d0bf59bba7866e74e207

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