Skip to content
This repository has been archived by the owner on Nov 5, 2019. It is now read-only.

kimmobrunfeldt/releasor

Repository files navigation

Archived and unmaintained. I recommend using https://github.com/sindresorhus/np instead

Releasor

Build Status

Command line tool to automate node module releasing to NPM and Git. And of course, releasor has been released with releasor. 🍲 🐕 Releasor is used in ProgressBar.js, git-hours, arr-mutations, and many others. It has proven itself in production releases.

Don't *

*bump patch version*
git add package.json
git commit -m "Release *version*"
git tag *version*
npm publish
git push origin *tag*
git push

Do

releasor

And you will get list of commits since last release conveniently to stdout. Remember to add release notes to the new GitHub release.



* npm version actually automates most of the stuff, but releasor gives some more control to the automation. The point I'm trying to make is that you shouldn't do a release manually.

What it does

  • Check that branch is master Can be disabled with --no-verify-branch.
  • Output commit messages since last release.
  • Bump version number in package.json.
  • Commit package.json to git with a configurable message. Default is Release {{ version }}.
  • Create a new tag with configurable string. Default is {{ version }} without any prefixes.
  • Publish module to NPM with npm publish.
  • Push new tag to remote, usually GitHub.
  • Push commits to remote, usually GitHub.

Install

npm install -g releasor

Usage

Usage: releasor [options]

Options:
  --bump             Bump type. Valid values patch, minor, major
                                                     [string] [default: "patch"]
  --dry-run          When set, dry run is done. No state changing commands are
                     executed. Some commands, such as git log, are executed.
                                                      [boolean] [default: false]
  --release          When set to false, only commands which modify local
                     environment will be run. Nothing will be sent to remote
                     environments such as git or NPM. This can be used to test
                     what the script does. "--release false" is same as "--no-
                     release"                          [boolean] [default: true]
  --verify-branch    When set to false, branch will be not verified to be master
                     "--verify-branch false" is same as "--no-verify-branch"
                                                       [boolean] [default: true]
  -m, --message      Message for the new release. Used in git commit.Default: "
                     Release {{ version }}". {{ version }} will be replaced with
                     the new version.
                                     [string] [default: "Release {{ version }}"]
  -t, --tag          Format for the new git tag. Default: "{{ version }}" {{
                     version }} will be replaced with the new version.
                                             [string] [default: "{{ version }}"]
  --npm-user-config  Specify custom .npmrc to be used with npm commands.
                     Optional.                                          [string]
  -h, --help         Show help                                         [boolean]
  -v, --version      Show version number                               [boolean]

Examples:
  releasor
  releasor --bump minor
  releasor --dry-run
  releasor --no-release --bump major
  releasor --verify-branch false
  releasor --no-verify-branch

Handling errors

If an error occurs during the release process, you have to resolve it manually. You might need to do some git operation such as:

  • Revert a commit
  • Remove local and remote tag
  • etc ..

Alternatives

License

MIT