X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;f=release.sh;h=21c0c34dcadab666382c16a923f8196cc1b0919b;hb=25ca4e1c935157d4ab13aacd1b8dae327fa0b14e;hp=84fd072b83606945d46bc24ebdc17f1e2b58c211;hpb=806e1ea5f693c8e0788094faf0d2029a1fa8c836;p=dygraphs.git diff --git a/release.sh b/release.sh index 84fd072..21c0c34 100755 --- a/release.sh +++ b/release.sh @@ -20,6 +20,38 @@ if [ $branch != "release-$VERSION" ]; then exit 1 fi +git status | grep 'working directory clean' > /dev/null +if [ $? -ne 0 ]; then + echo "Must release with a clean working directory. Commit your changes." >&2 + exit 1 +fi + +grep "$VERSION" package.json +if [ $? -ne 0 ]; then + echo "Version in package.json doesn't match command line argument." >&2 + exit 1 +fi + +grep "v$VERSION" bower.json +if [ $? -ne 0 ]; then + echo "Version in bower.json doesn't match command line argument." >&2 + exit 1 +fi + +grep "$VERSION" releases.json +if [ $? -ne 0 ]; then + echo "Version $VERSION does not appear in releases.json." >&2 + exit 1 +fi + +rm dygraph-combined.js # changes to this will make the tests fail. +make lint test test-combined +if [ $? -ne 0 ]; then + echo "Tests failed. Won't release!" >&2 + exit 1 +fi +git reset --hard # make test-combined deletes the source map + # Push a permanent copy of documentation & generated files to a versioned copy # of the site. This is where the downloadable files are generated. # TODO(danvk): make sure this actually generates the downloadable files! @@ -30,11 +62,24 @@ if [ $? -ne 0 ]; then exit 1 fi -# Everything is good. Tag this release and push it. +# Everything is good. +# Switch to the "releases" branch, merge this change and tag it. +echo "Switching branches to do the release." +git checkout releases +git merge --no-ff $branch + COMMIT=$(git rev-parse HEAD) echo "Tagging commit $COMMIT as version $VERSION" -git tag -m "Release of version $VERSION" -git push +git tag -a "v$VERSION" -m "Release of version $VERSION" +git push --tags echo "Release was successful!" -echo "Don't forget to merge changes on this branch back into master." +echo "Pushing the new version to dygraphs.com..." +./push-to-web.sh dygraphs.com:dygraphs.com + +echo "Success!\n" +echo "Don't forget to merge changes on this branch back into master:" +echo "git merge --no-ff $branch" + +# Discourage users from working on the "releases" branch. +git checkout master