Skip to main content

USGS lightweight utilities for package releases

Project description

ESI Releases

Note that relevant info on USGS code distribution and repository metadata can be found at <https://www.usgs.gov/products/software/software-management/distribution-usgs-code>

Description

This repository provides a CLI release tool for use in the repositories of the USGS Engineering Seismology and Impacts Gitlab group.

At present the CLI is a minimally functionally tool to increment major, minor, or patch version numbers in the code and update the project metadata in code.json accordingly.

For our purposes, this amounts to changing the version field in code.json followed by 3 URLs:

  • 'downloardURL``
    • This URL is tied to a specific release on Gitlab based on a tag
  • disclaimerURL
  • A licenses URL that exists under the permissions field
At the moment, this tool assumes that the version tag is of the form `v#.#.#`

Installation

It can be installed directly from source by calling pip in the cloned repository base directory:

pip install .

Developers or advanced users may which to include optional dependencies and install in editable mode:

pip install -e .[dev,test,build]

The package is also availbe on PyPI and can be installed with:

pip install esi-releases

Usage

This CLI tool allows for three levels of version incrementation, depending on the scope of changes to a repostories code, and attempts to adhere to the conventions of Semantic Versioning

<Major>.<Minor>.<Patch>
  • Major version increments are used when new features that are backwards incompatible are introduced
  • Minor version increments are used when new features that retain backwards compatibility are introduced
  • Patch increments are used for bugfixes that do not introduce new features

The general behavior of this tool is the following:

  • When a patch release is initiated, the patch number is simply incremented and adjusted across the metadata
  • When a minor release is initiated, the minor number is incremented and the patch number is reset to zero
  • When a major release is initiated, the major number is incremented, while the minor and patch numbers are reset to zero

Commands

To initiate a release the following syntax is used:

releases <major|minor|patch>

For example, for a package in a patch release at the a current version of v1.0.0:

releases patch

will result in v1.0.1

Should the same package have a following 'minor' release, i.e.:

releases minor

this will result in v1.1.0

Finally, if the package then undergoes a major release:

releases major

the version will be incremented to v2.0.0

Help can be obtained in the CLI with the following:

releases --help

In Development

The intention of this CLI tool is to soon also support automate CHANGELOG.md updates based on commit messages in the repository, and to also prepare for a release by creating a new version entry. This is currently under development.

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

esi-releases-0.1.2.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

esi_releases-0.1.2-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file esi-releases-0.1.2.tar.gz.

File metadata

  • Download URL: esi-releases-0.1.2.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.5

File hashes

Hashes for esi-releases-0.1.2.tar.gz
Algorithm Hash digest
SHA256 69521347282e891110d1c06e41dd6be565cead07bada16f80e5829ac2bb3879d
MD5 73cd981157c19b51c6f6f00529a2debd
BLAKE2b-256 fa73b072cc0240aa46cacf6d5f4dd4a48b902e509774484cb1655a2ac73b254d

See more details on using hashes here.

File details

Details for the file esi_releases-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for esi_releases-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 436f5bb5c19a96e5f0be95287f54595c5d3f05dcc4393a2326b18e710f65fe8d
MD5 debc54a18f72cd28205105859fe7a77a
BLAKE2b-256 cb10150b995fdea7fd1f23ee61f9da71617693af5e7b8a12300088bb9ac09dc0

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