X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=scripts%2Frelease.sh;h=8c440975f0461702c111dae09aac79ae5c726b9c;hb=f8087a5476ecb4659949794b5c5978481c991cec;hp=aef4327e49b262464667e66032613a39aed40abb;hpb=519b8df5f840a9223dd78a83cbc484b0eebef578;p=github%2FChocobozzz%2FPeerTube.git diff --git a/scripts/release.sh b/scripts/release.sh index aef4327e4..8c440975f 100755 --- a/scripts/release.sh +++ b/scripts/release.sh @@ -16,20 +16,71 @@ if [ -z "$1" ]; then exit -1 fi +if [ -z $GITHUB_TOKEN ]; then + echo "Need GITHUB_TOKEN env set." + exit -1 +fi + +branch=$(git symbolic-ref --short -q HEAD) +if [ "$branch" != "develop" ]; then + echo "Need to be on develop branch." + exit -1 +fi + +version="v$1" +directory_name="peertube-$version" +zip_name="peertube-$version.zip" + +changelog=$(awk -v version="$version" '/## v/ { printit = $2 == version }; printit;' CHANGELOG.md | grep -v "$version" | sed '1{/^$/d}') + +echo -e "Changelog will be:\n" +echo "$changelog" +echo + +read -p "Are you sure to release? " -n 1 -r +echo +if [[ ! $REPLY =~ ^[Yy]$ ]] +then + [[ "$0" = "$BASH_SOURCE" ]] && exit 0 +fi + cd ./client || exit -1 npm version --no-git-tag-version --no-commit-hooks $1 || exit -1 cd ../ || exit -1 npm version -f --no-git-tag-version --no-commit-hooks $1 || exit -1 -git commit package.json client/package.json -m "Bumped to version $1" || exit -1 -git tag -s -a "v$1" -m "v$1" +git commit package.json client/package.json -m "Bumped to version $version" || exit -1 +git tag -s -a "$version" -m "$version" npm run build || exit -1 -#npm test || exit -1 +rm "./client/dist/stats.json" || exit -1 cd ../ || exit -1 -ln -s "PeerTube" "peertube-v$1" || exit -1 -zip -r "PeerTube/peertube-v$1.zip" "peertube-v$1"/{CREDITS.md,FAQ.md,LICENSE,README.md,client/dist/,client/yarn.lock,client/package.json,config,dist,package.json,scripts,support,tsconfig.json,yarn.lock} || exit -1 -rm "peertube-v$1" || exit -1 +ln -s "PeerTube" "$directory_name" || exit -1 +zip -r "PeerTube/$zip_name" "$directory_name/CREDITS.md" "$directory_name/FAQ.md" \ + "$directory_name/LICENSE" "$directory_name/README.md" \ + "$directory_name/client/dist/" "$directory_name/client/yarn.lock" \ + "$directory_name/client/package.json" "$directory_name/config" \ + "$directory_name/dist" "$directory_name/package.json" \ + "$directory_name/scripts" "$directory_name/support" \ + "$directory_name/tsconfig.json" "$directory_name/yarn.lock" \ + || exit -1 +rm "$directory_name" || exit -1 + +cd "PeerTube" || exit -1 + +git push origin --tag + +github-release release --user chocobozzz --repo peertube --tag "$version" --name "$version" --description "$changelog" +github-release upload --user chocobozzz --repo peertube --tag "$version" --name "$zip_name" --file "$zip_name" + +git push origin develop + +# Update master branch +git checkout master +git rebase develop +git push origin master +git checkout develop +