##// END OF EJS Templates
some updates to release scripts
Matthias Bussonnier -
Show More
@@ -1,171 +1,178 b''
1 # Simple tool to help for release
1 # Simple tool to help for release
2 # when releasing with bash, simple source it to get asked questions.
2 # when releasing with bash, simple source it to get asked questions.
3
3
4 # misc check before starting
4 # misc check before starting
5
5
6 python -c 'import keyring'
6 python -c 'import keyring'
7 python -c 'import twine'
7 python -c 'import twine'
8 python -c 'import sphinx'
8 python -c 'import sphinx'
9 python -c 'import sphinx_rtd_theme'
9 python -c 'import sphinx_rtd_theme'
10 python -c 'import nose'
10 python -c 'import nose'
11
11
12
12
13 BLACK=$(tput setaf 1)
13 BLACK=$(tput setaf 1)
14 RED=$(tput setaf 1)
14 RED=$(tput setaf 1)
15 GREEN=$(tput setaf 2)
15 GREEN=$(tput setaf 2)
16 YELLOW=$(tput setaf 3)
16 YELLOW=$(tput setaf 3)
17 BLUE=$(tput setaf 4)
17 BLUE=$(tput setaf 4)
18 MAGENTA=$(tput setaf 5)
18 MAGENTA=$(tput setaf 5)
19 CYAN=$(tput setaf 6)
19 CYAN=$(tput setaf 6)
20 WHITE=$(tput setaf 7)
20 WHITE=$(tput setaf 7)
21 NOR=$(tput sgr0)
21 NOR=$(tput sgr0)
22
22
23
23
24 echo -n "PREV_RELEASE (X.y.z) [$PREV_RELEASE]: "
24 echo -n "PREV_RELEASE (X.y.z) [$PREV_RELEASE]: "
25 read input
25 read input
26 PREV_RELEASE=${input:-$PREV_RELEASE}
26 PREV_RELEASE=${input:-$PREV_RELEASE}
27 echo -n "MILESTONE (X.y) [$MILESTONE]: "
27 echo -n "MILESTONE (X.y) [$MILESTONE]: "
28 read input
28 read input
29 MILESTONE=${input:-$MILESTONE}
29 MILESTONE=${input:-$MILESTONE}
30 echo -n "VERSION (X.y.z) [$VERSION]:"
30 echo -n "VERSION (X.y.z) [$VERSION]:"
31 read input
31 read input
32 VERSION=${input:-$VERSION}
32 VERSION=${input:-$VERSION}
33 echo -n "BRANCH (master|X.y) [$BRANCH]:"
33 echo -n "BRANCH (master|X.y) [$BRANCH]:"
34 read input
34 read input
35 BRANCH=${input:-$BRANCH}
35 BRANCH=${input:-$BRANCH}
36
36
37 ask_section(){
37 ask_section(){
38 echo
38 echo
39 echo $BLUE"$1"$NOR
39 echo $BLUE"$1"$NOR
40 echo -n $GREEN"Press Enter to continue, S to skip: "$NOR
40 echo -n $GREEN"Press Enter to continue, S to skip: "$NOR
41 read -n1 value
41 read -n1 value
42 echo
42 echo
43 if [ -z $value ] || [ $value = 'y' ] ; then
43 if [ -z $value ] || [ $value = 'y' ] ; then
44 return 0
44 return 0
45 fi
45 fi
46 return 1
46 return 1
47 }
47 }
48
48
49
49
50
50
51 echo
51 echo
52 if ask_section "Updating what's new with informations from docs/source/whatsnew/pr"
52 if ask_section "Updating what's new with informations from docs/source/whatsnew/pr"
53 then
53 then
54 python tools/update_whatsnew.py
54 python tools/update_whatsnew.py
55
55
56 echo
56 echo
57 echo $BLUE"please move the contents of "docs/source/whatsnew/development.rst" to version-X.rst"$NOR
57 echo $BLUE"please move the contents of "docs/source/whatsnew/development.rst" to version-X.rst"$NOR
58 echo $GREEN"Press enter to continue"$NOR
58 echo $GREEN"Press enter to continue"$NOR
59 read
59 read
60 fi
60 fi
61
61
62 if ask_section "Gen Stats, and authors"
62 if ask_section "Gen Stats, and authors"
63 then
63 then
64
64
65 echo
65 echo
66 echo $BLUE"here are all the authors that contributed to this release:"$NOR
66 echo $BLUE"here are all the authors that contributed to this release:"$NOR
67 git log --format="%aN <%aE>" $PREV_RELEASE... | sort -u -f
67 git log --format="%aN <%aE>" $PREV_RELEASE... | sort -u -f
68
68
69 echo
69 echo
70 echo $BLUE"If you see any duplicates cancel (Ctrl-C), then edit .mailmap."
70 echo $BLUE"If you see any duplicates cancel (Ctrl-C), then edit .mailmap."
71 echo $GREEN"Press enter to continue:"$NOR
71 echo $GREEN"Press enter to continue:"$NOR
72 read
72 read
73
73
74 echo $BLUE"generating stats"$NOR
74 echo $BLUE"generating stats"$NOR
75 python tools/github_stats.py --milestone $MILESTONE > stats.rst
75 python tools/github_stats.py --milestone $MILESTONE > stats.rst
76
76
77 echo $BLUE"stats.rst files generated."$NOR
77 echo $BLUE"stats.rst files generated."$NOR
78 echo $GREEN"Please merge it with the right file (github-stats-X.rst) and commit."$NOR
78 echo $GREEN"Please merge it with the right file (github-stats-X.rst) and commit."$NOR
79 echo $GREEN"press enter to continue."$NOR
79 echo $GREEN"press enter to continue."$NOR
80 read
80 read
81
81
82 fi
82 fi
83
83
84 echo "Cleaning repository"
84 echo "Cleaning repository"
85 git clean -xfdi
85 git clean -xfdi
86
86
87 echo $GREEN"please update version number in ${RED}IPython/core/release.py${NOR} , Do not commit yet – we'll do it later."$NOR
87 echo $GREEN"please update version number in ${RED}IPython/core/release.py${NOR} , Do not commit yet – we'll do it later."$NOR
88
88
89 echo $GREEN"Press enter to continue"$NOR
89 echo $GREEN"Press enter to continue"$NOR
90 read
90 read
91
91
92 if ask_section "Build the documentation ?"
92 if ask_section "Build the documentation ?"
93 then
93 then
94 make html -C docs
94 make html -C docs
95 echo
95 echo
96 echo $GREEN"Check the docs, press enter to continue"$NOR
96 echo $GREEN"Check the docs, press enter to continue"$NOR
97 read
97 read
98
98
99 fi
99 fi
100
100
101 echo
101 echo
102 echo $BLUE"Attempting to build package..."$NOR
102 echo $BLUE"Attempting to build package..."$NOR
103
103
104 tools/build_release
104 tools/build_release
105 rm dist/*
105 rm dist/*
106
106
107 if ask_section "Should we commit, tag, push... etc ? "
107 if ask_section "Should we commit, tag, push... etc ? "
108 then
108 then
109 echo
109 echo
110 echo $BLUE"Let's commit : git commit -am \"release $VERSION\" -S"
110 echo $BLUE"Let's commit : git commit -am \"release $VERSION\" -S"
111 echo $GREEN"Press enter to commit"$NOR
111 echo $GREEN"Press enter to commit"$NOR
112 read
112 read
113 git commit -am "release $VERSION" -S
113 git commit -am "release $VERSION" -S
114
114
115 echo
115 echo
116 echo $BLUE"git push origin \$BRANCH ($BRANCH)?"$NOR
116 echo $BLUE"git push origin \$BRANCH ($BRANCH)?"$NOR
117 echo $GREEN"Make sure you can push"$NOR
117 echo $GREEN"Make sure you can push"$NOR
118 echo $GREEN"Press enter to continue"$NOR
118 echo $GREEN"Press enter to continue"$NOR
119 read
119 read
120 git push origin $BRANCH
120 git push origin $BRANCH
121
121
122 echo
122 echo
123 echo "Let's tag : git tag -am \"release $VERSION\" \"$VERSION\" -s"
123 echo "Let's tag : git tag -am \"release $VERSION\" \"$VERSION\" -s"
124 echo $GREEN"Press enter to tag commit"$NOR
124 echo $GREEN"Press enter to tag commit"$NOR
125 read
125 read
126 git tag -am "release $VERSION" "$VERSION" -s
126 git tag -am "release $VERSION" "$VERSION" -s
127
127
128 echo
128 echo
129 echo $BLUE"And push the tag: git push origin \$VERSION ?"$NOR
129 echo $BLUE"And push the tag: git push origin \$VERSION ?"$NOR
130 echo $GREEN"Press enter to continue"$NOR
130 echo $GREEN"Press enter to continue"$NOR
131 read
131 read
132 git push origin $VERSION
132 git push origin $VERSION
133
133
134
134
135 echo $GREEN"please update version number and back to .dev in ${RED}IPython/core/release.py"
135 echo $GREEN"please update version number and back to .dev in ${RED}IPython/core/release.py"
136 echo ${BLUE}"Do not commit yet – we'll do it later."$NOR
136 echo ${BLUE}"Do not commit yet – we'll do it later."$NOR
137
137
138 echo $GREEN"Press enter to continue"$NOR
138 echo $GREEN"Press enter to continue"$NOR
139 read
139 read
140
140
141 echo
141 echo
142 echo "Let's commit : "$BLUE"git commit -am \"back to dev\""$NOR
142 echo "Let's commit : "$BLUE"git commit -am \"back to dev\""$NOR
143 echo $GREEN"Press enter to commit"$NOR
143 echo $GREEN"Press enter to commit"$NOR
144 read
144 read
145 git commit -am "back to dev"
145 git commit -am "back to dev"
146
146
147 echo
147 echo
148 echo $BLUE"git push origin \$BRANCH ($BRANCH)?"$NOR
149 echo $GREEN"Press enter to continue"$NOR
150 read
151 git push origin $BRANCH
152
153
154 echo
148 echo $BLUE"let's : git checkout $VERSION"$NOR
155 echo $BLUE"let's : git checkout $VERSION"$NOR
149 echo $GREEN"Press enter to continue"$NOR
156 echo $GREEN"Press enter to continue"$NOR
150 read
157 read
151 git checkout $VERSION
158 git checkout $VERSION
152 fi
159 fi
153
160
154 if ask_section "Should we build and release ?"
161 if ask_section "Should we build and release ?"
155 then
162 then
156
163
157 echo
164 echo
158 echo $BLUE"Attempting to build package..."$NOR
165 echo $BLUE"Attempting to build package..."$NOR
159
166
160 tools/release
167 tools/release
161
168
162 echo '$ shasum -a 256 dist/*'
163 echo $RED
169 echo $RED
170 echo '$ shasum -a 256 dist/*'
164 shasum -a 256 dist/*
171 shasum -a 256 dist/*
165 echo $NOR
172 echo $NOR
166
173
167 if ask_section "upload packages ?"
174 if ask_section "upload packages ?"
168 then
175 then
169 tools/release upload
176 tools/release upload
170 fi
177 fi
171 fi
178 fi
General Comments 0
You need to be logged in to leave comments. Login now