Skip to content

Commit 2e23e5d

Browse files
authored
Merge pull request #11 from kaliber5/releaseit
Setup release-it
2 parents 17b17f1 + 9890f72 commit 2e23e5d

File tree

4 files changed

+1700
-77
lines changed

4 files changed

+1700
-77
lines changed

CHANGELOG.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
# Changelog

RELEASE.md

Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
# Release Process
2+
3+
Releases are mostly automated using
4+
[release-it](https://github.com/release-it/release-it/) and
5+
[lerna-changelog](https://github.com/lerna/lerna-changelog/).
6+
7+
## Preparation
8+
9+
Since the majority of the actual release process is automated, the primary
10+
remaining task prior to releasing is confirming that all pull requests that
11+
have been merged since the last release have been labeled with the appropriate
12+
`lerna-changelog` labels and the titles have been updated to ensure they
13+
represent something that would make sense to our users. Some great information
14+
on why this is important can be found at
15+
[keepachangelog.com](https://keepachangelog.com/en/1.0.0/), but the overall
16+
guiding principle here is that changelogs are for humans, not machines.
17+
18+
When reviewing merged PR's the labels to be used are:
19+
20+
* breaking - Used when the PR is considered a breaking change.
21+
* enhancement - Used when the PR adds a new feature or enhancement.
22+
* bug - Used when the PR fixes a bug included in a previous release.
23+
* documentation - Used when the PR adds or updates documentation.
24+
* internal - Used for internal changes that still require a mention in the
25+
changelog/release notes.
26+
27+
## Release
28+
29+
Once the prep work is completed, the actual release is straight forward:
30+
31+
* First, ensure that you have installed your projects dependencies:
32+
33+
```sh
34+
yarn install
35+
```
36+
37+
* Second, ensure that you have obtained a
38+
[GitHub personal access token][generate-token] with the `repo` scope (no
39+
other permissions are needed). Make sure the token is available as the
40+
`GITHUB_AUTH` environment variable.
41+
42+
For instance:
43+
44+
```bash
45+
export GITHUB_AUTH=abc123def456
46+
```
47+
48+
[generate-token]: https://github.com/settings/tokens/new?scopes=repo&description=GITHUB_AUTH+env+variable
49+
50+
* And last (but not least 😁) do your release.
51+
52+
```sh
53+
npx release-it
54+
```
55+
56+
[release-it](https://github.com/release-it/release-it/) manages the actual
57+
release process. It will prompt you to to choose the version number after which
58+
you will have the chance to hand tweak the changelog to be used (for the
59+
`CHANGELOG.md` and GitHub release), then `release-it` continues on to tagging,
60+
pushing the tag and commits, etc.

package.json

Lines changed: 36 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -1,25 +1,28 @@
11
{
22
"name": "ember-bootstrap-codemods",
3-
"description": "Codemods to ease upgrading of ember-bootstrap",
43
"version": "0.1.2",
5-
"author": "Simon Ihmig <simon.ihmig@kaliber5.de",
6-
"license": "MIT",
4+
"description": "Codemods to ease upgrading of ember-bootstrap",
5+
"keywords": [
6+
"codemod-cli"
7+
],
78
"repository": "github:kaliber5/ember-bootstrap-codemods",
9+
"license": "MIT",
10+
"author": "Simon Ihmig <simon.ihmig@kaliber5.de",
11+
"bin": "./bin/cli.js",
12+
"files": [
13+
"bin",
14+
"transforms"
15+
],
816
"scripts": {
17+
"coveralls": "cat ./coverage/lcov.info | node node_modules/.bin/coveralls",
918
"lint": "eslint --cache .",
1019
"test": "codemod-cli test",
1120
"test:coverage": "codemod-cli test --coverage",
12-
"update-docs": "codemod-cli update-docs",
13-
"coveralls": "cat ./coverage/lcov.info | node node_modules/.bin/coveralls"
21+
"update-docs": "codemod-cli update-docs"
22+
},
23+
"jest": {
24+
"testEnvironment": "node"
1425
},
15-
"files": [
16-
"bin",
17-
"transforms"
18-
],
19-
"bin": "./bin/cli.js",
20-
"keywords": [
21-
"codemod-cli"
22-
],
2326
"dependencies": {
2427
"codemod-cli": "^3.1.1"
2528
},
@@ -30,12 +33,29 @@
3033
"eslint-plugin-node": "^11.1.0",
3134
"eslint-plugin-prettier": "^3.3.1",
3235
"jest": "^26.6.3",
33-
"prettier": "^2.2.1"
36+
"prettier": "^2.2.1",
37+
"release-it": "^14.2.1",
38+
"release-it-lerna-changelog": "^3.1.0"
3439
},
3540
"engines": {
3641
"node": "10.* || >= 12"
3742
},
38-
"jest": {
39-
"testEnvironment": "node"
43+
"publishConfig": {
44+
"registry": "https://registry.npmjs.org"
45+
},
46+
"release-it": {
47+
"plugins": {
48+
"release-it-lerna-changelog": {
49+
"infile": "CHANGELOG.md",
50+
"launchEditor": true
51+
}
52+
},
53+
"git": {
54+
"tagName": "v${version}"
55+
},
56+
"github": {
57+
"release": true,
58+
"tokenRef": "GITHUB_AUTH"
59+
}
4060
}
4161
}

0 commit comments

Comments
 (0)