Skip to content

Commit 09f8ed6

Browse files
authored
Merge pull request #79 from ronco/automated-release-setup
Add release automation.
2 parents a1d9716 + 7b61d5d commit 09f8ed6

File tree

3 files changed

+1536
-186
lines changed

3 files changed

+1536
-186
lines changed

RELEASE.md

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

package.json

Lines changed: 31 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -2,17 +2,22 @@
22
"name": "ember-cli-head",
33
"version": "0.4.1",
44
"description": "An addon to easily set document head content via a template.",
5-
"main": "index.js",
6-
"directories": {
7-
"doc": "doc",
8-
"test": "tests"
9-
},
5+
"keywords": [
6+
"ember-addon",
7+
"meta",
8+
"seo"
9+
],
1010
"repository": {
1111
"type": "git",
1212
"url": "https://github.com/ronco/ember-cli-head.git"
1313
},
1414
"license": "MIT",
1515
"author": "",
16+
"main": "index.js",
17+
"directories": {
18+
"doc": "doc",
19+
"test": "tests"
20+
},
1621
"scripts": {
1722
"build": "ember build --environment=production",
1823
"lint:hbs": "ember-template-lint .",
@@ -21,11 +26,6 @@
2126
"test": "ember test",
2227
"test:all": "ember try:each"
2328
},
24-
"keywords": [
25-
"ember-addon",
26-
"meta",
27-
"seo"
28-
],
2929
"dependencies": {
3030
"ember-cli-babel": "^7.19.0",
3131
"ember-cli-htmlbars": "^4.3.1",
@@ -60,17 +60,37 @@
6060
"eslint-plugin-ember": "^8.4.0",
6161
"eslint-plugin-node": "^11.1.0",
6262
"loader.js": "^4.7.0",
63-
"qunit-dom": "^1.2.0"
63+
"qunit-dom": "^1.2.0",
64+
"release-it": "^13.6.0",
65+
"release-it-lerna-changelog": "^2.3.0"
6466
},
6567
"engines": {
6668
"node": "10.* || >= 12"
6769
},
70+
"publishConfig": {
71+
"registry": "https://registry.npmjs.org"
72+
},
6873
"ember": {
6974
"edition": "octane"
7075
},
7176
"ember-addon": {
7277
"configPath": "tests/dummy/config"
7378
},
79+
"release-it": {
80+
"plugins": {
81+
"release-it-lerna-changelog": {
82+
"infile": "CHANGELOG.md",
83+
"launchEditor": true
84+
}
85+
},
86+
"git": {
87+
"tagName": "v${version}"
88+
},
89+
"github": {
90+
"release": true,
91+
"tokenRef": "GITHUB_AUTH"
92+
}
93+
},
7494
"volta": {
7595
"node": "10.20.1",
7696
"yarn": "1.22.4"

0 commit comments

Comments
 (0)