Skip to content
/ vmn Public
forked from final-israel/vmn

A simple package for auto increasing version numbers of any application agnostic to language or architecture

License

Notifications You must be signed in to change notification settings

allingeek/vmn

Repository files navigation


Version managment package

A package for auto increasing version numbers of any application agnostic to language or architecture.

vmn is compliant with Semver (https://semver.org) semantics



What it does?

vmn is a CLI tool for handling project versioning needs.

vmn can also be used like a Python library.

Go ahead and read vmn's docs :)

Key features

  • Stamping of versions of type: major. minor.patch , e.g., 1.6.0 [Semver compliant]
  • Stamping of versions of type: major. minor.patch-prerelease , e.g., 1.6.0-rc23 [Semver compliant]
  • Stamping of versions of type: major. minor.patch.hotfix , e.g., 1.6.7.4 [Semver extension]
  • Bringing back the repository / repositories state to the state they were when the project was stamped (see goto section)
  • Stamping of micro-services-like project topologies (see Root apps section)
  • Stamping of a project depending on multiple git repositories (see Configuration: deps section)
  • Version auto-embedding into supported backends (npm, cargo) during the vmn stamp phase (see Version auto-embedding section)
  • WIP Addition of buildmetadata for an existing version, e.g., 1.6.0-rc23+build01.Info [Semver compliant]
  • WIP Addition of releasenotes for an existing version [Semver extension]
  • WIP Support "root apps" that are located in different repositories

Installation

pip3 install vmn

Usage

cd into your git repository

cd to/your/repository

vmn init

## Needed only once per repository.
vmn init

vmn stamp

## Needed only once per app-name
# will start from 0.0.0
vmn init-app <app-name>

# will stamp 0.0.1
vmn stamp -r patch <app-name>

# example for starting from version 1.6.8
vmn init-app -v 1.6.8 <app-name2>

# will stamp 1.7.0
vmn stamp -r minor <app-name2>
Note:

init-app and stamp both support --dry-run flag

vmn stamp for release candidates

vmn supports Semver's prerelease notion of version stamping, enabling you to release non-mature versions and only then release the final version.

# will start from 1.6.8
vmn init-app -v 1.6.8 <app-name>

# will stamp 2.0.0-alpha1
vmn stamp -r major --pr alpha <app-name>

# will stamp 2.0.0-alpha2
vmn stamp --pr alpha <app-name>

# will stamp 2.0.0-mybeta1
vmn stamp --pr mybeta <app-name>

# Run release when you ready - will stamp 2.0.0 (from the same commit)
vmn release -v 2.0.0-mybeta1 <app-name>

vmn stamp for "root apps" or microservices

vmn supports stamping of something called a "root app" which can be useful for managing version of multiple services that are logically located under the same solution.

For example:
vmn init-app my_root_app/service1
vmn stamp -r patch my_root_app/service1
vmn init-app my_root_app/service2
vmn stamp -r patch my_root_app/service2
vmn init-app my_root_app/service3
vmn stamp -r patch my_root_app/service3

Next we'll be able to use vmn show to display everything we need:

vmn show --verbose my_root_app/service3

vmn_info:
  description_message_version: '1'
  vmn_version: <the version of vmn itself that has stamped the application>
stamping:
  msg: 'my_root_app/service3: update to version 0.0.1'
  app:
    name: my_root_app/service3
    _version: 0.0.1
    release_mode: patch
    prerelease: release
    previous_version: 0.0.0
    stamped_on_branch: master
    changesets:
      .:
        hash: 8bbeb8a4d3ba8499423665ba94687b551309ea64
        remote: <remote url>
        vcs_type: git
    info: {}
  root_app:
    name: my_root_app
    version: 5
    latest_service: my_root_app/service3
    services:
      my_root_app/service1: 0.0.1
      my_root_app/service2: 0.0.1
      my_root_app/service3: 0.0.1
    external_services: {}

vmn show my_root_app/service3 will output 0.0.1

vmn show --root my_root_app will output 5

vmn show

Use vmn show for displaying version information of previous vmn stamp commands

vmn show <app-name>
vmn show --verbose <app-name>
vmn show -v 1.0.1 <app-name>

vmn goto

Similar to git checkout but also supports checking out all configured dependencies. This way you can easily go back to the exact state of you entire code for a specific version even when multiple git repositories are involved.

vmn goto -v 1.0.1 <app-name>

vmn gen

Generates version output file based on jinja2 template

vmn gen -t path/to/jinja_template.j2 -o path/to/output.txt app_name

Available jinja2 keywords

{
  "_version": "0.0.1", 
  "changesets":
  {
    ".": 
    {
      "hash": "ef4c6f4355d0190e4f516230f65a79ec24fc7396", 
      "remote": "../test_repo_remote",
      "vcs_type": "git"
    }
  }, 
  "info": {}, 
  "name": "test_app2/s1",
  "prerelease": "release",
  "prerelease_count": {},
  "previous_version": "0.0.0",
  "release_mode": "patch",
  "stamped_on_branch": "master",
  "version": "0.0.1",
  "root_external_services": {},
  "root_latest_service": "test_app2/s1",
  "root_name": "test_app2",
  "root_services": 
  {
    "test_app2/s1": "0.0.1"
  }, 
  "root_version": 1
}

vmn gen jinja template example

"VERSION: {{version}} \n" \
"NAME: {{name}} \n" \
"BRANCH: {{stamped_on_branch}} \n" \
"RELEASE_MODE: {{release_mode}} \n" \
"{% for k,v in changesets.items() %} \n" \
"    <h2>REPO: {{k}}\n" \
"    <h2>HASH: {{v.hash}}</h2> \n" \
"    <h2>REMOTE: {{v.remote}}</h2> \n" \
"    <h2>VCS_TYPE: {{v.vcs_type}}</h2> \n" \
"{% endfor %}\n"

vmn gen output example

VERSION: 0.0.1
NAME: test_app2/s1
BRANCH: master
RELEASE_MODE: patch

    <h2>REPO: .
    <h2>HASH: ef4c6f4355d0190e4f516230f65a79ec24fc7396</h2>
    <h2>REMOTE: ../test_repo_remote</h2>
    <h2>VCS_TYPE: git</h2>

Version auto-embedding

vmn supports auto-embedding the version string during the vmn stamp phase for supported backends:

Backend Description
alt text Will embed version string to package.json file within the vmn stamp command
alt text Will embed version string to Cargo.toml file within the vmn stamp command

Configuration

vmn auto generates a conf.yml file that can be modified later by the user.

An example of a possible conf.yml file:

# Autogenerated by vmn. You can edit this configuration file
conf:
  template: '[{major}][.{minor}]'
  deps:
    ../:
      <repo dir name>:
        vcs_type: git
  extra_info: false
  create_verinfo_files: false
  hide_zero_hotfix: true
  version_backends: 
    npm:
      path: "relative_path/to/Cargo.toml"
Field Description Example
template The template configuration string can be customized and will be applied on the "raw" vmn version.
vmn will display the version based on the template.
vmn show my_root_app/service3 will output 0.0
however running:
vmn show --raw my_root_app/service3 will output 0.0.1
deps In deps you can specify other repositories as your dependencies and vmn will consider them when stamping and performing goto. See example conf.yml file above
extra_info Setting this to true will make vmn output usefull data about the host on which vmn has stamped the version.
Note This feature is not very popular and may be remove / altered in the future.
See example conf.yml file above
create_verinfo_files Tells vmn to create file for each stamped version. vmn show --from-file will work with these files instead of working with git tags. See example conf.yml file above
hide_zero_hotfix Tells vmn to hide the fourth version octa when it is equal to zero. This way you will never see the fourth octa unless you will specifically stamp with vmn stamp -r hotfix. True by default. See example conf.yml file above
version_backends Tells vmn to auto-embed the version string into one of the supported backends' files during the vmn stamp command. For instance, vmn will auto-embed the version string into package.json file if configured for npm projects. See example conf.yml file above

codecov

About

A simple package for auto increasing version numbers of any application agnostic to language or architecture

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 96.4%
  • Shell 2.6%
  • Other 1.0%