mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-25 20:38:08 +01:00
a5a21bbe78
Before release check that there are no uncommitted changes and that there are no files in working directory that possibly should have been added to the repository. Amended by db: remove --ignored, since that seems like too much trouble.
228 lines
5.6 KiB
Bash
Executable file
228 lines
5.6 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
set -eu
|
|
#set -x # or enter bash -x ... on command line
|
|
|
|
if [ x"${BASH_VERSION-}" = x ]
|
|
then echo
|
|
echo "Please execute this script using 'bash' interpreter"
|
|
echo
|
|
exit 1
|
|
fi
|
|
|
|
set -o posix
|
|
set -o pipefail # bash feature
|
|
|
|
readonly DEFAULT_IFS="$IFS" # Note: In this particular case quotes are needed.
|
|
|
|
# Avoid locale-specific differences in output of executed commands
|
|
LANG=C LC_ALL=C; export LANG LC_ALL
|
|
|
|
readonly PV_FILE='bindings/python/notmuch/version.py'
|
|
|
|
# Using array here turned out to be unnecessarily complicated
|
|
emsgs=''
|
|
emsg_count=0
|
|
append_emsg ()
|
|
{
|
|
emsg_count=$((emsg_count + 1))
|
|
emsgs="${emsgs:+$emsgs\n} $1"
|
|
}
|
|
|
|
for f in ./version debian/changelog NEWS "$PV_FILE"
|
|
do
|
|
if [ ! -f "$f" ]; then append_emsg "File '$f' is missing"
|
|
elif [ ! -r "$f" ]; then append_emsg "File '$f' is unreadable"
|
|
elif [ ! -s "$f" ]; then append_emsg "File '$f' is empty"
|
|
fi
|
|
done
|
|
|
|
if [ -n "$emsgs" ]
|
|
then
|
|
echo 'Release files problems; fix these and try again:'
|
|
echo -e "$emsgs"
|
|
exit 1
|
|
fi
|
|
|
|
if read VERSION
|
|
then
|
|
if read rest
|
|
then echo "'version' file contains more than one line"
|
|
exit 1
|
|
fi
|
|
else
|
|
echo "Reading './version' file failed (suprisingly!)"
|
|
exit 1
|
|
fi < ./version
|
|
|
|
readonly VERSION
|
|
|
|
# In the rest of this file, tests collect list of errors to be fixed
|
|
|
|
echo -n "Checking that git working directory is clean... "
|
|
git_status=`git status --porcelain`
|
|
if [ "$git_status" = '' ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
append_emsg "Git working directory is not clean (git status --porcelain)."
|
|
fi
|
|
unset git_status
|
|
|
|
verfail ()
|
|
{
|
|
echo No.
|
|
append_emsg "$@"
|
|
append_emsg " Please follow the instructions in RELEASING to choose a version"
|
|
}
|
|
|
|
echo -n "Checking that '$VERSION' is good with digits and periods... "
|
|
case $VERSION in
|
|
*[!0-9.]*)
|
|
verfail "'$VERSION' contains other characters than digits and periods" ;;
|
|
.*) verfail "'$VERSION' begins with a period" ;;
|
|
*.) verfail "'$VERSION' ends with a period" ;;
|
|
*..*) verfail "'$VERSION' contains two consecutive periods" ;;
|
|
*.*) echo Yes. ;;
|
|
*) verfail "'$VERSION' is a single number" ;;
|
|
esac
|
|
|
|
echo -n "Checking that LIBNOTMUCH version macros & variables match ... "
|
|
# lib/notmuch.h
|
|
LIBNOTMUCH_MAJOR_VERSION=broken
|
|
LIBNOTMUCH_MINOR_VERSION=broken
|
|
LIBNOTMUCH_MICRO_VERSION=broken
|
|
# lib/Makefile.local
|
|
LIBNOTMUCH_VERSION_MAJOR=borken
|
|
LIBNOTMUCH_VERSION_MINOR=borken
|
|
LIBNOTMUCH_VERSION_RELEASE=borken
|
|
|
|
eval `awk 'NF == 3 && $1 == "#define" && $2 ~ /^LIBNOTMUCH_[A-Z]+_VERSION$/ \
|
|
&& $3 ~ /^[0-9]+$/ { print $2 "=" $3 }' lib/notmuch.h`
|
|
|
|
eval `awk 'NF == 3 && $1 ~ /^LIBNOTMUCH_VERSION_[A-Z]+$/ && $2 == "=" \
|
|
&& $3 ~ /^[0-9]+$/ { print $1 "=" $3 }' lib/Makefile.local`
|
|
|
|
|
|
check_version_component ()
|
|
{
|
|
eval local v1=\$LIBNOTMUCH_$1_VERSION
|
|
eval local v2=\$LIBNOTMUCH_VERSION_$2
|
|
if [ $v1 != $v2 ]
|
|
then append_emsg "LIBNOTMUCH_$1_VERSION ($v1) does not equal LIBNOTMUCH_VERSION_$2 ($v2)"
|
|
fi
|
|
}
|
|
|
|
old_emsg_count=$emsg_count
|
|
check_version_component MAJOR MAJOR
|
|
check_version_component MINOR MINOR
|
|
check_version_component MICRO RELEASE
|
|
[ $old_emsg_count = $emsg_count ] && echo Yes. || echo No.
|
|
|
|
echo -n "Checking that this is Debian package for notmuch... "
|
|
read deb_notmuch deb_version rest < debian/changelog
|
|
if [ "$deb_notmuch" = 'notmuch' ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
append_emsg "Package name '$deb_notmuch' is not 'notmuch' in debian/changelog"
|
|
fi
|
|
|
|
echo -n "Checking that Debian package version is $VERSION-1... "
|
|
|
|
if [ "$deb_version" = "($VERSION-1)" ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
append_emsg "Version '$deb_version' is not '($VERSION-1)' in debian/changelog"
|
|
fi
|
|
|
|
echo -n "Checking that python bindings version is $VERSION... "
|
|
py_version=`python -c "with open('$PV_FILE') as vf: exec(vf.read()); print __VERSION__"`
|
|
if [ "$py_version" = "$VERSION" ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
append_emsg "Version '$py_version' is not '$VERSION' in $PV_FILE"
|
|
fi
|
|
|
|
echo -n "Checking that NEWS header is tidy... "
|
|
if [ "`exec sed 's/./=/g; 1q' NEWS`" = "`exec sed '1d; 2q' NEWS`" ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
if [ "`exec sed '1d; s/=//g; 2q' NEWS`" != '' ]
|
|
then
|
|
append_emsg "Line 2 in NEWS file is not all '=':s"
|
|
else
|
|
append_emsg "Line 2 in NEWS file does not have the same length as line 1"
|
|
fi
|
|
fi
|
|
|
|
echo -n "Checking that this is Notmuch NEWS... "
|
|
read news_notmuch news_version news_date < NEWS
|
|
if [ "$news_notmuch" = "Notmuch" ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
append_emsg "First word '$news_notmuch' is not 'Notmuch' in NEWS file"
|
|
fi
|
|
|
|
echo -n "Checking that NEWS version is $VERSION... "
|
|
if [ "$news_version" = "$VERSION" ]
|
|
then
|
|
echo Yes.
|
|
else
|
|
echo No.
|
|
append_emsg "Version '$news_version' in NEWS file is not '$VERSION'"
|
|
fi
|
|
|
|
#eval `date '+year=%Y mon=%m day=%d'`
|
|
today0utc=`date --date=0Z +%s` # gnu date feature
|
|
|
|
echo -n "Checking that NEWS date is right... "
|
|
case $news_date in
|
|
'('[2-9][0-9][0-9][0-9]-[01][0-9]-[0123][0-9]')')
|
|
newsdate0utc=`nd=${news_date#\\(}; date --date="${nd%)} 0Z" +%s`
|
|
ddiff=$((newsdate0utc - today0utc))
|
|
if [ $ddiff -lt -86400 ] # since beginning of yesterday...
|
|
then
|
|
echo No.
|
|
append_emsg "Date $news_date in NEWS file is too much in the past"
|
|
elif [ $ddiff -gt 172800 ] # up to end of tomorrow...
|
|
then
|
|
echo No.
|
|
append_emsg "Date $news_date in NEWS file is too much in the future"
|
|
else
|
|
echo Yes.
|
|
fi ;;
|
|
*)
|
|
echo No.
|
|
append_emsg "Date '$news_date' in NEWS file is not in format (yyyy-mm-dd)"
|
|
esac
|
|
|
|
if [ -n "$emsgs" ]
|
|
then
|
|
echo
|
|
echo 'Release check failed; check these issues:'
|
|
echo -e "$emsgs"
|
|
exit 1
|
|
fi
|
|
|
|
echo 'All checks this script executed completed successfully.'
|
|
echo 'Make sure that everything else mentioned in RELEASING'
|
|
echo 'file is in order, too.'
|
|
|
|
|
|
# Local variables:
|
|
# mode: shell-script
|
|
# sh-basic-offset: 8
|
|
# tab-width: 8
|
|
# End:
|
|
# vi: set sw=8 ts=8
|