]> Raphaƫl G. Git Repositories - youtubedl/blob - devscripts/release.sh
debian/control: Massive update of supported sites.
[youtubedl] / devscripts / release.sh
1 #!/bin/bash
2
3 # IMPORTANT: the following assumptions are made
4 # * the GH repo is on the origin remote
5 # * the gh-pages branch is named so locally
6 # * the git config user.signingkey is properly set
7
8 # You will need
9 # pip install coverage nose rsa
10
11 # TODO
12 # release notes
13 # make hash on local files
14
15 set -e
16
17 skip_tests=false
18 if [ "$1" = '--skip-test' ]; then
19 skip_tests=true
20 shift
21 fi
22
23 if [ -z "$1" ]; then echo "ERROR: specify version number like this: $0 1994.09.06"; exit 1; fi
24 version="$1"
25 if [ ! -z "`git tag | grep "$version"`" ]; then echo 'ERROR: version already present'; exit 1; fi
26 if [ ! -z "`git status --porcelain | grep -v CHANGELOG`" ]; then echo 'ERROR: the working directory is not clean; commit or stash changes'; exit 1; fi
27 useless_files=$(find youtube_dl -type f -not -name '*.py')
28 if [ ! -z "$useless_files" ]; then echo "ERROR: Non-.py files in youtube_dl: $useless_files"; exit 1; fi
29 if [ ! -f "updates_key.pem" ]; then echo 'ERROR: updates_key.pem missing'; exit 1; fi
30
31 /bin/echo -e "\n### First of all, testing..."
32 make cleanall
33 if $skip_tests ; then
34 echo 'SKIPPING TESTS'
35 else
36 nosetests --verbose --with-coverage --cover-package=youtube_dl --cover-html test --stop || exit 1
37 fi
38
39 /bin/echo -e "\n### Changing version in version.py..."
40 sed -i "s/__version__ = '.*'/__version__ = '$version'/" youtube_dl/version.py
41
42 /bin/echo -e "\n### Committing CHANGELOG README.md and youtube_dl/version.py..."
43 make README.md
44 git add CHANGELOG README.md youtube_dl/version.py
45 git commit -m "release $version"
46
47 /bin/echo -e "\n### Now tagging, signing and pushing..."
48 git tag -s -m "Release $version" "$version"
49 git show "$version"
50 read -p "Is it good, can I push? (y/n) " -n 1
51 if [[ ! $REPLY =~ ^[Yy]$ ]]; then exit 1; fi
52 echo
53 MASTER=$(git rev-parse --abbrev-ref HEAD)
54 git push origin $MASTER:master
55 git push origin "$version"
56
57 /bin/echo -e "\n### OK, now it is time to build the binaries..."
58 REV=$(git rev-parse HEAD)
59 make youtube-dl youtube-dl.tar.gz
60 read -p "VM running? (y/n) " -n 1
61 wget "http://localhost:8142/build/rg3/youtube-dl/youtube-dl.exe?rev=$REV" -O youtube-dl.exe
62 mkdir -p "build/$version"
63 mv youtube-dl youtube-dl.exe "build/$version"
64 mv youtube-dl.tar.gz "build/$version/youtube-dl-$version.tar.gz"
65 RELEASE_FILES="youtube-dl youtube-dl.exe youtube-dl-$version.tar.gz"
66 (cd build/$version/ && md5sum $RELEASE_FILES > MD5SUMS)
67 (cd build/$version/ && sha1sum $RELEASE_FILES > SHA1SUMS)
68 (cd build/$version/ && sha256sum $RELEASE_FILES > SHA2-256SUMS)
69 (cd build/$version/ && sha512sum $RELEASE_FILES > SHA2-512SUMS)
70 git checkout HEAD -- youtube-dl youtube-dl.exe
71
72 /bin/echo -e "\n### Signing and uploading the new binaries to yt-dl.org ..."
73 for f in $RELEASE_FILES; do gpg --detach-sig "build/$version/$f"; done
74 scp -r "build/$version" ytdl@yt-dl.org:html/tmp/
75 ssh ytdl@yt-dl.org "mv html/tmp/$version html/downloads/"
76 ssh ytdl@yt-dl.org "sh html/update_latest.sh $version"
77
78 /bin/echo -e "\n### Now switching to gh-pages..."
79 git clone --branch gh-pages --single-branch . build/gh-pages
80 ROOT=$(pwd)
81 (
82 set -e
83 ORIGIN_URL=$(git config --get remote.origin.url)
84 cd build/gh-pages
85 "$ROOT/devscripts/gh-pages/add-version.py" $version
86 "$ROOT/devscripts/gh-pages/update-feed.py"
87 "$ROOT/devscripts/gh-pages/sign-versions.py" < "$ROOT/updates_key.pem"
88 "$ROOT/devscripts/gh-pages/generate-download.py"
89 "$ROOT/devscripts/gh-pages/update-copyright.py"
90 "$ROOT/devscripts/gh-pages/update-sites.py"
91 git add *.html *.html.in update
92 git commit -m "release $version"
93 git push "$ROOT" gh-pages
94 git push "$ORIGIN_URL" gh-pages
95 )
96 rm -rf build
97
98 make pypi-files
99 echo "Uploading to PyPi ..."
100 python setup.py sdist upload
101 make clean
102
103 /bin/echo -e "\n### DONE!"