mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-29 22:46:12 +00:00
Add hack/cherry_pick_list.sh to list all automated cherry picks
* Adds hack/cherry_pick_list.sh to list all automated cherry picks since the last tag. * Adds a short python script to extract title/author and print it in markdown style like our current release notes. * Revises patch release instructions to use said script.
This commit is contained in:
parent
8f3c3108b8
commit
af1a8b825a
@ -137,7 +137,9 @@ manage cherry picks prior to cutting the release.
|
|||||||
version commit.
|
version commit.
|
||||||
1. Follow the instructions given to you by that script. They are canon for the
|
1. Follow the instructions given to you by that script. They are canon for the
|
||||||
remainder of the Git process. If you don't understand something in that
|
remainder of the Git process. If you don't understand something in that
|
||||||
process, please ask!
|
process, please ask! When proposing PRs, you can pre-fill the body with
|
||||||
|
`hack/cherry_pick_list.sh upstream/release-${VER}` to inform people of what
|
||||||
|
is already on the branch.
|
||||||
|
|
||||||
**TODO**: how to fix tags, etc., if the release is changed.
|
**TODO**: how to fix tags, etc., if the release is changed.
|
||||||
|
|
||||||
@ -154,10 +156,10 @@ In your git repo (you still have `${VER}` and `${PATCH}` set from above right?):
|
|||||||
|
|
||||||
#### Writing Release Notes
|
#### Writing Release Notes
|
||||||
|
|
||||||
Release notes for a patch release are relatives fast: `git log release-${VER}`
|
Run `hack/cherry_pick_list.sh ${VER}.${PATCH}~1` to get the release notes for
|
||||||
(If you followed the procedure in the first section, all the cherry-picks will
|
the patch release you just created. Feel free to prune anything internal, like
|
||||||
have the pull request number in the commit log). Unless there's some reason not
|
you would for a major release, but typically for patch releases we tend to
|
||||||
to, just include all the PRs back to the last release.
|
include everything in the release notes.
|
||||||
|
|
||||||
## Origin of the Sources
|
## Origin of the Sources
|
||||||
|
|
||||||
|
49
hack/cherry_pick_list.sh
Executable file
49
hack/cherry_pick_list.sh
Executable file
@ -0,0 +1,49 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2015 The Kubernetes Authors All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed 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.
|
||||||
|
|
||||||
|
# List cherry picks sitting on a release branch that AREN'T YET part
|
||||||
|
# of a release. Used when constructing a release.
|
||||||
|
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
declare -r KUBE_ROOT="$(dirname "${BASH_SOURCE}")/.."
|
||||||
|
|
||||||
|
if [[ "$#" -ne 1 ]]; then
|
||||||
|
echo "${0} <remote branch>: list all automated cherry picks on <remote release branch> since last release."
|
||||||
|
echo " (assumes branch format of cherry_pick_pull.sh)"
|
||||||
|
echo ""
|
||||||
|
echo "Example:"
|
||||||
|
echo " $0 upstream/release-1.0 # Lists all PRs on release-1.0 since list patch release."
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
declare -r BRANCH="$1"
|
||||||
|
|
||||||
|
git remote update >/dev/null
|
||||||
|
|
||||||
|
# First, the range specification: --abbrev=0 is saying to find the tag
|
||||||
|
# relevant for the branch, so this essentially the git log all the way
|
||||||
|
# back to the most recent tag on the release branch.
|
||||||
|
#
|
||||||
|
# The git log outputs something like:
|
||||||
|
# 0f3cdb7234e2239707e4c3fc58f5f89552f41c65 Merge pull request #98765 from zaphod/automated-cherry-pick-of-#12345-#56789-#13579-upstream-release-1.0
|
||||||
|
PULLS=( $(git log $(git describe --abbrev=0 "${BRANCH}").."${BRANCH}" -E --grep="Merge pull request \#[0-9]+ from .+/automated-cherry-pick-of-" --pretty=oneline |
|
||||||
|
awk '{ print $7 }' | sed -e 's/.*automated-cherry-pick-of-\(#[0-9]\{1,\}\)/\1/' -e 's/\(#[0-9]\{1,\}\)-[^#].*/\1/' -e 's/-/\
|
||||||
|
/g' | sed 's/^#//g') )
|
||||||
|
|
||||||
|
${KUBE_ROOT}/hack/lookup_pull.py "${PULLS[@]}"
|
40
hack/lookup_pull.py
Executable file
40
hack/lookup_pull.py
Executable file
@ -0,0 +1,40 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
# Copyright 2015 The Kubernetes Authors All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed 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.
|
||||||
|
|
||||||
|
# Script to print out PR info in release note format.
|
||||||
|
|
||||||
|
import json
|
||||||
|
import sys
|
||||||
|
import urllib2
|
||||||
|
|
||||||
|
PULLQUERY=("https://api.github.com/repos/"
|
||||||
|
"GoogleCloudPlatform/kubernetes/pulls/{pull}")
|
||||||
|
LOGIN="login"
|
||||||
|
TITLE="title"
|
||||||
|
USER="user"
|
||||||
|
|
||||||
|
def print_pulls(pulls):
|
||||||
|
for pull in pulls:
|
||||||
|
d = json.loads(urllib2.urlopen(PULLQUERY.format(pull=pull)).read())
|
||||||
|
print "* {title} #{pull} ({author})".format(
|
||||||
|
title=d[TITLE], pull=pull, author=d[USER][LOGIN])
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
if len(sys.argv) < 2:
|
||||||
|
print ("Usage: {cmd} <pulls>...: Prints out short " +
|
||||||
|
"markdown description for PRs appropriate for release notes.")
|
||||||
|
sys.exit(1)
|
||||||
|
print_pulls(sys.argv[1:])
|
Loading…
Reference in New Issue
Block a user