README.md 10.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
<!--
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements.  See the NOTICE file
distributed with this work for additional information
regarding copyright ownership.  The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License.  You may obtain a copy of the License at

  http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied.  See the License for the
specific language governing permissions and limitations
under the License.
-->
A
Alek Storm 已提交
19

20
# Apache Releases
A
Alek Storm 已提交
21

22 23
Until things settle and we create scripts that streamline this,
you'll probably want to run these commands manually and understand what
24
they do prior to doing so.
A
Alek Storm 已提交
25

26 27
For coordinating on releases, on operational topics that require more
synchronous communications, we recommend using the `#apache-releases` channel
28 29 30
on the Superset Slack. People crafting releases and those interested in
partaking in the process should join the channel.

31 32 33 34
## Release notes for recent releases
- [1.0.0](release-notes-1-0/README.md)
- [0.38](release-notes-0-38/README.md)

35
## Release setup (First Time Only)
36

37 38
First you need to setup a few things. This is a one-off and doesn't
need to be done at every release.
A
Alek Storm 已提交
39 40

```bash
41
    # Create PGP Key, and use your @apache.org email address
42
    gpg --gen-key
43

44
    # Checkout ASF dist repo
45

46
    svn checkout https://dist.apache.org/repos/dist/dev/superset/ ~/svn/superset_dev
47

48
    svn checkout https://dist.apache.org/repos/dist/release/superset/ ~/svn/superset
49
    cd ~/svn/superset
50 51


52
    # Add your GPG pub key to KEYS file. Replace "Maxime Beauchemin" with your name
53 54
    export SUPERSET_PGP_FULLNAME="Maxime Beauchemin"
    (gpg --list-sigs "${SUPERSET_PGP_FULLNAME}" && gpg --armor --export "${SUPERSET_PGP_FULLNAME}" ) >> KEYS
55 56


57 58
    # Commit the changes
    svn commit -m "Add PGP keys of new Superset committer"
A
Alek Storm 已提交
59 60
```

61 62
## Setting up the release environment (do every time)

63 64
As the vote process takes a minimum of 72h, sometimes stretching over several weeks
of calendar time if votes don't pass, chances are
65 66 67 68 69
the same terminal session won't be used for crafting the release candidate and the
final release. Therefore, it's a good idea to do the following every time you
work on a new phase of the release process to make sure you aren't releasing
the wrong files/using wrong names. There's a script to help you set correctly all the
necessary environment variables. Change your current directory to `superset/RELEASING`
70
and execute the `set_release_env.sh` script with the relevant parameters:
71

72
Usage (BASH):
73
```bash
74
. set_release_env.sh <SUPERSET_RC_VERSION> <PGP_KEY_FULLNAME>
75 76 77 78
```

Usage (ZSH):
```bash
79
source set_release_env.sh <SUPERSET_RC_VERSION> <PGP_KEY_FULLNAME>
80 81 82 83
```

Example:
```bash
84
source set_release_env.sh 0.38.0rc1 myid@apache.org
85 86
```

87
The script will output the exported variables. Here's example for 0.38.0rc1:
88 89

```
90 91 92 93 94 95 96 97 98 99 100
Set Release env variables
SUPERSET_VERSION=0.38.0
SUPERSET_RC=1
SUPERSET_GITHUB_BRANCH=0.38
SUPERSET_PGP_FULLNAME=myid@apache.org
SUPERSET_VERSION_RC=0.38.0rc1
SUPERSET_RELEASE=apache-superset-0.38.0
SUPERSET_RELEASE_RC=apache-superset-0.38.0rc1
SUPERSET_RELEASE_TARBALL=apache-superset-0.38.0-source.tar.gz
SUPERSET_RELEASE_RC_TARBALL=apache-superset-0.38.0rc1-source.tar.gz
SUPERSET_TMP_ASF_SITE_PATH=/tmp/superset-site-0.38.0
101 102
```

103 104
## Crafting a source release

105
When crafting a new minor or major release we create
106
a branch named with the release MAJOR.MINOR version (on this example 0.37).
107
This new branch will hold all PATCH and release candidates
108 109 110
that belong to the MAJOR.MINOR version.

The MAJOR.MINOR branch is normally a "cut" from a specific point in time from the master branch.
111
Then (if needed) apply all cherries that will make the PATCH.
112

113 114 115 116 117 118 119
```bash
git checkout -b $SUPERSET_GITHUB_BRANCH
git push upstream $SUPERSET_GITHUB_BRANCH
```

Next, update the `CHANGELOG.md` with all the changes that are included in the release.
Make sure the branch has been pushed to `upstream` to ensure the changelog generator
120
can pick up changes since the previous release.
121

122
Example:
123
```bash
124
python changelog.py --previous_version 0.37 --current_version 0.38 changelog
125 126
```

127 128
The script will checkout both branches and compare all the PR's, copy the output and paste it on the `CHANGELOG.md`

129 130 131 132 133
Then, in `UPDATING.md`, a file that contains a list of notifications around
deprecations and upgrading-related topics,
make sure to move the content now under the `Next Version` section under a new
section for the new release.

134
Finally bump the version number on `superset-frontend/package.json` (replace with whichever version is being released excluding the RC version):
135

136
```json
137
"version": "0.38.0"
138
```
139

140 141 142
Commit the change with the version number, then git tag the version with the release candidate and push to the branch:

```
143 144 145 146 147 148
# add changed files and commit
git add ...
git commit ...
# push new tag
git tag ${SUPERSET_VERSION_RC}
git push upstream ${SUPERSET_VERSION_RC}
149
```
150

151 152 153
## Preparing the release candidate

The first step of preparing an Apache Release is packaging a release candidate
154
to be voted on. Make sure you have correctly prepared and tagged the ready to ship
155
release on Superset's repo (MAJOR.MINOR branch), the following script will clone
156
the tag and create a signed source tarball from it:
157 158

```bash
159 160 161
# make_tarball will use the previously set environment variables
# you can override by passing arguments: make_tarball.sh <SUPERSET_VERSION> <SUPERSET_VERSION_RC> "<PGP_KEY_FULLNAME>"
./make_tarball.sh
162
```
163

164
Note that `make_tarball.sh`:
165

166 167
- By default assumes you have already executed an SVN checkout to `$HOME/svn/superset_dev`.
This can be overriden by setting `SUPERSET_SVN_DEV_PATH` environment var to a different svn dev directory
168 169
- Will refuse to craft a new release candidate if a release already exists on your local svn dev directory
- Will check `package.json` version number and fails if it's not correctly set
170

171
### Build and test the created source tarball
172

173
To build and run the **local copy** of the recently created tarball:
174
```bash
175 176 177 178
# Build and run a release candidate tarball
./test_run_tarball.sh local
# you should be able to access localhost:5001 on your browser
# login using admin/admin
179 180
```

181
### Shipping to SVN
182

183
Now let's ship this RC into svn's dev folder
184 185

```bash
186 187 188
cd ~/svn/superset_dev/
svn add ${SUPERSET_VERSION_RC}
svn commit -m "Release ${SUPERSET_VERSION_RC}"
189 190
```

191
### Build and test from SVN source tarball
192

193
To build and run the recently created tarball **from SVN**:
194
```bash
195 196 197 198
# Build and run a release candidate tarball
./test_run_tarball.sh
# you should be able to access localhost:5001 on your browser
# login using admin/admin
199 200
```

201 202 203 204 205
### Voting
Now you're ready to start the [VOTE] thread. Here's an example of a
previous release vote thread:
https://lists.apache.org/thread.html/e60f080ebdda26896214f7d3d5be1ccadfab95d48fbe813252762879@<dev.superset.apache.org>

206 207 208
To easily send a voting request to Superset community, still on the `superset/RELEASING` directory:

```bash
209 210
# Note: use Superset's virtualenv
(venv)$ python send_email.py vote_pmc
211 212 213
```

The script will interactively ask for extra information so it can authenticate on the Apache Email Relay.
214
The release version and release candidate number are fetched from the previously set environment variables.
215

216 217 218 219
```
Sender email (ex: user@apache.org): your_apache_email@apache.org
Apache username: your_apache_user
Apache password: your_apache_password
220 221
```

222 223 224 225
Once 3+ binding votes (by PMC members) have been cast and at
least 72 hours have past, you can post a [RESULT] thread:
https://lists.apache.org/thread.html/50a6b134d66b86b237d5d7bc89df1b567246d125a71394d78b45f9a8@%3Cdev.superset.apache.org%3E

226 227 228
To easily send the result email, still on the `superset/RELEASING` directory:

```bash
229 230
# Note: use Superset's virtualenv
python send_email.py result_pmc
231 232 233
```

The script will interactively ask for extra information needed to fill out the email template. Based on the
234
voting description, it will generate a passing, non passing or non conclusive email.
235 236
here's an example:

237 238 239 240 241 242 243
```
Sender email (ex: user@apache.org): your_apache_email@apache.org
Apache username: your_apache_user
Apache password: your_apache_password
A List of people with +1 binding vote (ex: Max,Grace,Krist): Daniel,Alan,Max,Grace
A List of people with +1 non binding vote (ex: Ville): Ville
A List of people with -1 vote (ex: John):
244 245
```

246
Following the result thread, yet another [VOTE] thread should be
247

248
### Validating a release
249 250 251 252 253

https://www.apache.org/info/verification.html

## Publishing a successful release

254
Upon a successful vote, you'll have to copy the folder into the non-"dev/" folder.
255
```bash
256 257 258 259 260 261
cp -r ~/svn/superset_dev/${SUPERSET_VERSION_RC}/ ~/svn/superset/${SUPERSET_VERSION}/
cd ~/svn/superset/
# Rename the RC (0.34.1rc1) to the actual version being released (0.34.1)
for f in ${SUPERSET_VERSION}/*; do mv "$f" "${f/${SUPERSET_VERSION_RC}/${SUPERSET_VERSION}}"; done
svn add ${SUPERSET_VERSION}
svn commit -m "Release ${SUPERSET_VERSION}"
262 263 264 265
```

Then tag the final release:
```bash
266 267 268 269 270 271
# Go to the root directory of the repo, e.g. `~/src/superset`
cd ~/src/superset/
# make sure you're on the correct branch (e.g. 0.34)
git branch
# Create the release tag
git tag -f ${SUPERSET_VERSION}
272 273
```

274 275 276 277
### Update CHANGELOG and UPDATING on superset

Now that we have a final Apache source release we need to open a pull request on Superset
with the changes on `CHANGELOG.md` and `UPDATING.md`.
278

279
### Publishing a Convenience Release to PyPI
280

281
Using the final release tarball, unpack it and run `./pypi_push.sh`.
282
This script will build the Javascript bundle and echo the twine command
283
allowing you to publish to PyPI. You may need to ask a fellow committer to grant
284 285 286 287
you access to it if you don't have access already. Make sure to create
an account first if you don't have one, and reference your username
while requesting access to push packages.

288
### Announcing
289

290 291 292
Once it's all done, an [ANNOUNCE] thread announcing the release to the dev@ mailing list is the final step.

```bash
293 294
# Note use Superset's virtualenv
python send_email.py announce
295 296
```

297 298 299
### Github Release

Finally, so the Github UI reflects the latest release, you should create a release from the
300
tag corresponding with the new version. Go to https://github.com/apache/superset/tags,
301 302
click the 3-dot icon and select `Create Release`, paste the content of the ANNOUNCE thread in the
release notes, and publish the new release.
303 304

At this point, a GitHub action will run that will check whether this release's version number is higher than the current 'latest' release. If that condition is true, this release sha will automatically be tagged as `latest` so that the most recent release can be referenced simply by using the 'latest' tag instead of looking up the version number. The existing version number tag will still exist, and can also be used for reference.