2013-08-22 07:59:15 +08:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
## This is to be used once jenkins has finished building the release
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2014-02-19 10:57:45 +08:00
|
|
|
if [[ ! -e ../node-website/Makefile ]];
|
|
|
|
then
|
|
|
|
echo "node-website must be checked out one level up"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2013-08-22 07:59:15 +08:00
|
|
|
stability="$(python tools/getstability.py)"
|
|
|
|
NODE_STABC="$(tr '[:lower:]' '[:upper:]' <<< ${stability:0:1})${stability:1}"
|
|
|
|
NODE_STABL="$stability"
|
|
|
|
|
|
|
|
echo "Building for $stability"
|
|
|
|
|
|
|
|
scp tj@nodejs.org:archive/node/tmp/v$(python tools/getnodeversion.py)/SHASUM* .
|
|
|
|
FILES="SHASUMS SHASUMS256"
|
|
|
|
for i in $FILES ; do gpg -s $i.txt; gpg --clearsign $i.txt; done
|
|
|
|
scp SHASUM* tj@nodejs.org:archive/node/tmp/v$(python tools/getnodeversion.py)/
|
|
|
|
|
|
|
|
ssh nodejs.org mkdir -p "dist/v$(python tools/getnodeversion.py)/{x64,docs}"
|
|
|
|
ssh nodejs.org ln -s ../dist/v$(python tools/getnodeversion.py)/docs docs/v$(python tools/getnodeversion.py)
|
|
|
|
|
|
|
|
ssh root@nodejs.org mv /home/tj/archive/node/tmp/v$(python tools/getnodeversion.py)/* /home/node/dist/v$(python tools/getnodeversion.py)/
|
|
|
|
ssh root@nodejs.org chown -R node:other /home/node/dist/v$(python tools/getnodeversion.py)
|
|
|
|
|
|
|
|
# tag the release
|
|
|
|
# should be the same key used to sign the shasums
|
|
|
|
git tag -sm "$(bash tools/changelog-head.sh)" v$(python tools/getnodeversion.py)
|
|
|
|
|
|
|
|
# push to github
|
|
|
|
git push git@github.com:joyent/node v$(python tools/getnodeversion.py)-release --tags
|
|
|
|
|
|
|
|
# blog post and email
|
|
|
|
make email.md
|
|
|
|
( echo ""
|
|
|
|
echo "Shasums:"
|
|
|
|
echo '```'
|
|
|
|
cat SHASUMS.txt
|
|
|
|
echo '```' ) >> email.md
|
|
|
|
( echo -n "date: "
|
|
|
|
date
|
|
|
|
echo -n "version: "
|
|
|
|
python tools/getnodeversion.py
|
|
|
|
echo "category: release"
|
|
|
|
echo "title: Node v"$(python tools/getnodeversion.py)" ($NODE_STABC)"
|
|
|
|
echo "slug: node-v"$(python tools/getnodeversion.py | sed 's|\.|-|g')"-$NODE_STABL"
|
|
|
|
echo ""
|
2014-02-19 10:57:45 +08:00
|
|
|
cat email.md ) > ../node-website/doc/blog/release/v$(python tools/getnodeversion.py).md
|
2013-08-22 07:59:15 +08:00
|
|
|
|
|
|
|
if [ "$stability" = "stable" ];
|
|
|
|
then
|
|
|
|
## this needs to happen here because the website depends on the current node
|
|
|
|
## node version
|
2014-02-19 10:57:45 +08:00
|
|
|
## this will get the api docs in the right place
|
2013-08-22 07:59:15 +08:00
|
|
|
make website-upload
|
|
|
|
BRANCH="v$(python tools/getnodeversion.py | sed -E 's#\.[0-9]+$##')"
|
2014-02-19 10:57:45 +08:00
|
|
|
echo $(python tools/getnodeversion.py) > ../node-website/STABLE
|
2013-08-22 07:59:15 +08:00
|
|
|
else
|
|
|
|
BRANCH="master"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "Merging back into $BRANCH"
|
|
|
|
|
|
|
|
# merge back into mainline stable branch
|
|
|
|
git checkout $BRANCH
|
|
|
|
git merge --no-ff v$(python tools/getnodeversion.py)-release
|
|
|
|
|
|
|
|
# change the version number, set isrelease = 0
|
|
|
|
## TODO automagic.
|
|
|
|
vim src/node_version.h
|
|
|
|
git commit -am "Now working on "$(python tools/getnodeversion.py)
|
|
|
|
|
|
|
|
git push git@github.com:joyent/node $BRANCH
|
2014-02-19 10:57:45 +08:00
|
|
|
|
|
|
|
echo "Now go do the website stuff"
|