mirror of
https://github.com/Llewellynvdm/nativefier.git
synced 2025-01-03 06:10:20 +00:00
generate-changelog: integrate doc, creating tag, remind about smoke test
This commit is contained in:
parent
7ee2f97599
commit
9b455670c4
@ -68,3 +68,12 @@ but is painful to do manually. Do yourself a favor and install a
|
|||||||
1. Run a TSC watcher: `npm run build:watch`
|
1. Run a TSC watcher: `npm run build:watch`
|
||||||
2. Run a Jest unit tests watcher: `npm run test:watch`
|
2. Run a Jest unit tests watcher: `npm run test:watch`
|
||||||
- Alternatively, you can run both test processes in the same terminal by running: `npm run watch`
|
- Alternatively, you can run both test processes in the same terminal by running: `npm run watch`
|
||||||
|
|
||||||
|
## Release
|
||||||
|
|
||||||
|
While on `master`, with no uncommitted changes, run:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm run changelog -- $VERSION
|
||||||
|
# With no 'v'. For example: npm run changelog -- 42.5.0
|
||||||
|
```
|
||||||
|
@ -1,21 +1,25 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
#
|
|
||||||
# Updates the changelog and version in the package.json
|
# Updates the changelog and version in the package.json
|
||||||
# Will also create a commit with these changes locally
|
# Will also create a commit with these changes locally
|
||||||
# Run `git commit --amend` after that if you wish to make changes
|
|
||||||
#
|
#
|
||||||
# Usage:
|
# Usage:
|
||||||
# ./changelog "7.0.0"
|
# ./generate-changelog -- "7.0.0"
|
||||||
#
|
#
|
||||||
# Prerequisites:
|
# Prerequisites:
|
||||||
# - On master branch
|
# - On master branch
|
||||||
# - No uncommitted changes
|
# - No uncommitted changes
|
||||||
#
|
#
|
||||||
# Dependencies:
|
# Dependencies:
|
||||||
# - git-extras https://github.com/tj/git-extras/blob/master/Installation.md
|
# - git-extras: https://github.com/tj/git-extras/blob/master/Installation.md
|
||||||
|
# - jq: https://stedolan.github.io/jq/download/
|
||||||
|
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
echo 'HEY YOU. Did you run the quick pre-release smoke test? ( npm run test:manual )'
|
||||||
|
echo 'Press any key to continue, or Ctrl+C to abort'
|
||||||
|
read -r
|
||||||
|
|
||||||
# Checks if we are on the master branch
|
# Checks if we are on the master branch
|
||||||
BRANCH=$(git rev-parse --abbrev-ref HEAD)
|
BRANCH=$(git rev-parse --abbrev-ref HEAD)
|
||||||
if [[ "$BRANCH" != 'master' ]]; then
|
if [[ "$BRANCH" != 'master' ]]; then
|
||||||
@ -35,17 +39,27 @@ if ! [[ $VERSION =~ $SEMVER_REGEX ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Change the version in the package.json
|
# 1. Update the version in the package.json
|
||||||
cat package.json | jq ".version = \"$VERSION\"" > package.json.tmp
|
cat package.json | jq ".version = \"$VERSION\"" > package.json.tmp
|
||||||
|
mv package.json.tmp package.json # workaround for in-place jq editing
|
||||||
|
|
||||||
# Workaround for inplace jq editing
|
# 2. Compile new commits from CHANGELOG.md, and open it in your EDITOR for cleanup
|
||||||
mv package.json.tmp package.json
|
|
||||||
|
|
||||||
# Unset the editor so that git changelog does not open a editor
|
|
||||||
EDITOR=:
|
|
||||||
git changelog CHANGELOG.md --tag "$VERSION"
|
git changelog CHANGELOG.md --tag "$VERSION"
|
||||||
|
|
||||||
# Commit these changes
|
# 3. Commit the changes
|
||||||
git add CHANGELOG.md
|
git add CHANGELOG.md
|
||||||
git add package.json
|
git add package.json
|
||||||
git commit -m "Update changelog for \`v$VERSION\`"
|
git commit -m "Update changelog for \`v$VERSION\`"
|
||||||
|
|
||||||
|
# 4. Create an annotated tag
|
||||||
|
git tag -a "v$VERSION" -m "v$VERSION"
|
||||||
|
|
||||||
|
# 5. List remaining work
|
||||||
|
echo
|
||||||
|
echo 'Please verify commit & tag look fine in Git, then:'
|
||||||
|
echo ' 1. Push: git push --follow-tags origin master'
|
||||||
|
echo ' 2. Create a GitHub Release at https://github.com/nativefier/nativefier/releases ,'
|
||||||
|
echo " using created tag v$VERSION and with title \"Nativefier v$VERSION\" (yes, with a \"v\")."
|
||||||
|
echo
|
||||||
|
echo 'GitHub Action "publish" will react on the new release, and publish it to npm.'
|
||||||
|
echo 'The new version will be visible on npm within a few minutes/hours.'
|
||||||
|
@ -1,51 +0,0 @@
|
|||||||
# Release
|
|
||||||
|
|
||||||
Releases are automatically deployed to npm from Travis, when they are tagged.
|
|
||||||
However, we have to make sure that the version in the `package.json`,
|
|
||||||
and the changelog is updated.
|
|
||||||
|
|
||||||
## Tests
|
|
||||||
|
|
||||||
Before anything, run a little manual smoke test of some of our
|
|
||||||
hard-to-programatically-test features:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
npm run test:manual
|
|
||||||
```
|
|
||||||
|
|
||||||
## How to release
|
|
||||||
|
|
||||||
With [Git Extras](https://github.com/tj/git-extras/blob/master/Installation.md)
|
|
||||||
and [jq](https://stedolan.github.io/jq/download/) installed.
|
|
||||||
|
|
||||||
While on `master`, with no uncommitted changes,
|
|
||||||
|
|
||||||
```bash
|
|
||||||
npm run changelog -- $VERSION
|
|
||||||
# With no 'v'. For example: npm run changelog -- 7.7.1
|
|
||||||
```
|
|
||||||
|
|
||||||
This command does 3 things:
|
|
||||||
1. Update the version in the `package.json`
|
|
||||||
2. Update the changelog
|
|
||||||
3. Creates a new commit with the changes
|
|
||||||
|
|
||||||
Now we may want to cleanup the changelog:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
vim CHANGELOG.md
|
|
||||||
git commit --amend
|
|
||||||
```
|
|
||||||
|
|
||||||
Once we are satisfied,
|
|
||||||
|
|
||||||
```bash
|
|
||||||
git tag -a vX.Y.Z -m 'vX.Y.Z'
|
|
||||||
git push --follow-tags origin master
|
|
||||||
```
|
|
||||||
|
|
||||||
On [GitHub Releases](https://github.com/nativefier/nativefier/releases),
|
|
||||||
draft and publish a new release with title `Nativefier vX.Y.Z` (yes, with a `v`).
|
|
||||||
|
|
||||||
Our CI will react on the new release, and publish it to npm.
|
|
||||||
The new version will be visible on npm within a few minutes.
|
|
Loading…
Reference in New Issue
Block a user