forked from ungleich-public/cdist
		
	Unify build-helper scripts
This commit is contained in:
		
					parent
					
						
							
								2f93320627
							
						
					
				
			
			
				commit
				
					
						d242f1e758
					
				
			
		
					 3 changed files with 63 additions and 454 deletions
				
			
		| 
						 | 
					@ -1,6 +1,7 @@
 | 
				
			||||||
#!/bin/sh
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
 | 
					# 2016-2019 Darko Poljak (darko.poljak at gmail.com)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -18,10 +19,36 @@
 | 
				
			||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
					# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file contains the heavy lifting found usually in the Makefile
 | 
					# This file contains the heavy lifting found usually in the Makefile.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# vars for make
 | 
				
			||||||
 | 
					helper=$0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
basedir=${0%/*}/../
 | 
					basedir=${0%/*}/../
 | 
				
			||||||
 | 
					# run_as is used to check how the script is called (by $0 value)
 | 
				
			||||||
 | 
					# currently supported sufixes for $0 are:
 | 
				
			||||||
 | 
					# .darko - run as darko
 | 
				
			||||||
 | 
					basename=${0##*/}
 | 
				
			||||||
 | 
					run_as=${basename#*.}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					to_a=cdist-configuration-management
 | 
				
			||||||
 | 
					to_d=googlegroups.com
 | 
				
			||||||
 | 
					case "$run_as" in
 | 
				
			||||||
 | 
					    darko)
 | 
				
			||||||
 | 
					        from_a=darko.poljak
 | 
				
			||||||
 | 
					        from_d=gmail.com
 | 
				
			||||||
 | 
					        ml_name="Darko Poljak"
 | 
				
			||||||
 | 
					        ml_sig_name="Darko"
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
 | 
					    *)
 | 
				
			||||||
 | 
					        from_a=nico.schottelius
 | 
				
			||||||
 | 
					        from_d=ungleich.ch
 | 
				
			||||||
 | 
					        ml_name="Nico Schottelius"
 | 
				
			||||||
 | 
					        ml_sig_name="Nico"
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
 | 
					esac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Change to checkout directory
 | 
					# Change to checkout directory
 | 
				
			||||||
cd "$basedir"
 | 
					cd "$basedir"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -30,6 +57,12 @@ version=$(git describe)
 | 
				
			||||||
option=$1; shift
 | 
					option=$1; shift
 | 
				
			||||||
 | 
					
 | 
				
			||||||
case "$option" in
 | 
					case "$option" in
 | 
				
			||||||
 | 
					    print-make-vars)
 | 
				
			||||||
 | 
					        printf "helper: ${helper}\n"
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
 | 
					    print-runas)
 | 
				
			||||||
 | 
					        printf "run_as: $run_as\n"
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
    changelog-changes)
 | 
					    changelog-changes)
 | 
				
			||||||
        if [ "$#" -eq 1 ]; then
 | 
					        if [ "$#" -eq 1 ]; then
 | 
				
			||||||
            start=$1
 | 
					            start=$1
 | 
				
			||||||
| 
						 | 
					@ -84,19 +117,14 @@ case "$option" in
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        version=$1; shift
 | 
					        version=$1; shift
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        to_a=cdist
 | 
					 | 
				
			||||||
        to_d=l.schottelius.org
 | 
					 | 
				
			||||||
        to=${to_a}@${to_d}
 | 
					        to=${to_a}@${to_d}
 | 
				
			||||||
 | 
					 | 
				
			||||||
        from_a=nico-cdist
 | 
					 | 
				
			||||||
        from_d=schottelius.org
 | 
					 | 
				
			||||||
        from=${from_a}@${from_d}
 | 
					        from=${from_a}@${from_d}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        ( 
 | 
					        ( 
 | 
				
			||||||
        cat << eof
 | 
					        cat << eof
 | 
				
			||||||
From: Nico -telmich- Schottelius <$from>
 | 
					From: ${ml_name} <$from>
 | 
				
			||||||
To: cdist mailing list <$to>
 | 
					To: cdist mailing list <$to>
 | 
				
			||||||
Subject: cdist $version released
 | 
					Subject: cdist $version has been released
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Hello .*,
 | 
					Hello .*,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -108,15 +136,18 @@ eof
 | 
				
			||||||
        cat << eof
 | 
					        cat << eof
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Cheers,
 | 
					Cheers,
 | 
				
			||||||
 | 
					${ml_sig_name}
 | 
				
			||||||
Nico
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- 
 | 
					-- 
 | 
				
			||||||
Automatisation at its best level. With cdist.
 | 
					Automatisation at its best level. With cdist.
 | 
				
			||||||
eof
 | 
					eof
 | 
				
			||||||
        ) | /usr/sbin/sendmail -f "$from" "$to"
 | 
					        ) > mailinglist.tmp
 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if [ "$run_as" = "build-helper" ]
 | 
				
			||||||
 | 
					        then
 | 
				
			||||||
 | 
					            /usr/sbin/sendmail -f "$from" "$to" < mailinglist.tmp && rm -f mailinglist.tmp
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    release-git-tag)
 | 
					    release-git-tag)
 | 
				
			||||||
        target_version=$($0 changelog-version)
 | 
					        target_version=$($0 changelog-version)
 | 
				
			||||||
| 
						 | 
					@ -213,7 +244,6 @@ eof
 | 
				
			||||||
            "https://code.ungleich.ch/api/v4/projects/${project}/repository/tags/${tag}/release" \
 | 
					            "https://code.ungleich.ch/api/v4/projects/${project}/repository/tags/${tag}/release" \
 | 
				
			||||||
            || exit 1
 | 
					            || exit 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
        # remove generated files (archive and asc)
 | 
					        # remove generated files (archive and asc)
 | 
				
			||||||
        if [ $# -eq 2 ]
 | 
					        if [ $# -eq 2 ]
 | 
				
			||||||
        then
 | 
					        then
 | 
				
			||||||
| 
						 | 
					@ -276,8 +306,8 @@ eof
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Generate documentation (man and html)
 | 
					        # Generate documentation (man and html)
 | 
				
			||||||
        # First, clean old generated docs
 | 
					        # First, clean old generated docs
 | 
				
			||||||
        make docs-clean
 | 
					        make helper=${helper} docs-clean
 | 
				
			||||||
        make docs
 | 
					        make helper=${helper} docs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        ############################################################# 
 | 
					        ############################################################# 
 | 
				
			||||||
        # Everything green, let's do the release
 | 
					        # Everything green, let's do the release
 | 
				
			||||||
| 
						 | 
					@ -292,16 +322,27 @@ eof
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Publish git changes
 | 
					        # Publish git changes
 | 
				
			||||||
        make pub
 | 
					        if [ "$run_as" = "build-helper" ]
 | 
				
			||||||
 | 
					        then
 | 
				
			||||||
 | 
					            make helper=${helper} pub
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
 | 
					            # if we are not Nico :) then just push, no mirror
 | 
				
			||||||
 | 
					            git push
 | 
				
			||||||
 | 
					            # push also new branch and set up tracking
 | 
				
			||||||
 | 
					            git push -u origin "${target_branch}"
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Ensure that pypi release has the right version
 | 
					        # Ensure that pypi release has the right version
 | 
				
			||||||
        "$0" version
 | 
					        "$0" version
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Create and publish package for pypi
 | 
					        # Create and publish package for pypi
 | 
				
			||||||
        make pypi-release
 | 
					        make helper=${helper} pypi-release
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Archlinux release is based on pypi
 | 
					        if [ "$run_as" = "build-helper" ]
 | 
				
			||||||
        make archlinux-release
 | 
					        then
 | 
				
			||||||
 | 
					            # Archlinux release is based on pypi
 | 
				
			||||||
 | 
					            make helper=${helper} archlinux-release
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # sign git tag
 | 
					        # sign git tag
 | 
				
			||||||
        printf "Enter upstream repository authentication token: "
 | 
					        printf "Enter upstream repository authentication token: "
 | 
				
			||||||
| 
						 | 
					@ -309,19 +350,13 @@ eof
 | 
				
			||||||
        "$0" sign-git-release "${target_version}" "${token}"
 | 
					        "$0" sign-git-release "${target_version}" "${token}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Announce change on ML
 | 
					        # Announce change on ML
 | 
				
			||||||
        make ml-release
 | 
					        make helper=${helper} ml-release
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        cat << eof
 | 
					        cat << eof
 | 
				
			||||||
Manual steps post release:
 | 
					Manual steps post release:
 | 
				
			||||||
 | 
					 | 
				
			||||||
    - cdist-web
 | 
					    - cdist-web
 | 
				
			||||||
    - linkedin
 | 
					 | 
				
			||||||
    - hackernews
 | 
					 | 
				
			||||||
    - reddit
 | 
					 | 
				
			||||||
    - twitter
 | 
					    - twitter
 | 
				
			||||||
 | 
					 | 
				
			||||||
eof
 | 
					eof
 | 
				
			||||||
 | 
					 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    test)
 | 
					    test)
 | 
				
			||||||
| 
						 | 
					@ -366,7 +401,7 @@ eof
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    shellcheck)
 | 
					    shellcheck)
 | 
				
			||||||
        make shellcheck
 | 
					        make helper=${helper} shellcheck
 | 
				
			||||||
        printf "\\nPlease review shellcheck report.\\n"
 | 
					        printf "\\nPlease review shellcheck report.\\n"
 | 
				
			||||||
        while true
 | 
					        while true
 | 
				
			||||||
        do
 | 
					        do
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								bin/build-helper.darko
									
										
									
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								bin/build-helper.darko
									
										
									
									
									
										Symbolic link
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					build-helper
 | 
				
			||||||
| 
						 | 
					@ -1,427 +0,0 @@
 | 
				
			||||||
#!/bin/sh
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					 | 
				
			||||||
# 2016 Darko Poljak (darko.poljak at gmail.com)
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# This file is part of cdist.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# cdist is free software: you can redistribute it and/or modify
 | 
					 | 
				
			||||||
# it under the terms of the GNU General Public License as published by
 | 
					 | 
				
			||||||
# the Free Software Foundation, either version 3 of the License, or
 | 
					 | 
				
			||||||
# (at your option) any later version.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# cdist is distributed in the hope that it will be useful,
 | 
					 | 
				
			||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					 | 
				
			||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					 | 
				
			||||||
# GNU General Public License for more details.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# You should have received a copy of the GNU General Public License
 | 
					 | 
				
			||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# This file contains the heavy lifting found usually in the Makefile
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vars for make
 | 
					 | 
				
			||||||
helper=$0
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
basedir=${0%/*}/../
 | 
					 | 
				
			||||||
# run_as is used to check how the script is called (by $0 value)
 | 
					 | 
				
			||||||
# currently supported sufixes for $0 are:
 | 
					 | 
				
			||||||
# .freebsd - run as freebsd
 | 
					 | 
				
			||||||
basename=${0##*/}
 | 
					 | 
				
			||||||
run_as=${basename#*.}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
to_a=cdist-configuration-management
 | 
					 | 
				
			||||||
to_d=googlegroups.com
 | 
					 | 
				
			||||||
from_a=darko.poljak
 | 
					 | 
				
			||||||
from_d=gmail.com
 | 
					 | 
				
			||||||
ml_name="Darko Poljak"
 | 
					 | 
				
			||||||
ml_sig_name="Darko"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Change to checkout directory
 | 
					 | 
				
			||||||
cd "$basedir"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
version=$(git describe)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
option=$1; shift
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
case "$option" in
 | 
					 | 
				
			||||||
    print-make-vars)
 | 
					 | 
				
			||||||
        printf "helper: ${helper}\n"
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
    print-runas)
 | 
					 | 
				
			||||||
        printf "run_as: $run_as\n"
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
    changelog-changes)
 | 
					 | 
				
			||||||
        if [ "$#" -eq 1 ]; then
 | 
					 | 
				
			||||||
            start=$1
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            start="[[:digit:]]"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        end="[[:digit:]]"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        awk -F: "BEGIN { start=0 }
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                if(start == 0) {
 | 
					 | 
				
			||||||
                    if (\$0 ~ /^$start/) {
 | 
					 | 
				
			||||||
                        start = 1
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                } else {
 | 
					 | 
				
			||||||
                    if (\$0 ~ /^$end/) {
 | 
					 | 
				
			||||||
                        exit
 | 
					 | 
				
			||||||
                    } else {
 | 
					 | 
				
			||||||
                        print \$0 
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }" "$basedir/docs/changelog"
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    changelog-version)
 | 
					 | 
				
			||||||
        # get version from changelog
 | 
					 | 
				
			||||||
        grep '^[[:digit:]]' "$basedir/docs/changelog" | head -n1 | sed 's/:.*//'
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    check-date)
 | 
					 | 
				
			||||||
        # verify date in changelog is today
 | 
					 | 
				
			||||||
        date_today="$(date +%Y-%m-%d)"
 | 
					 | 
				
			||||||
        date_changelog=$(grep '^[[:digit:]]' "$basedir/docs/changelog" | head -n1 | sed 's/.*: //')
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if [ "$date_today" != "$date_changelog" ]; then
 | 
					 | 
				
			||||||
            echo "Date in changelog is not today"
 | 
					 | 
				
			||||||
            echo "Changelog: $date_changelog"
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    check-unittest)
 | 
					 | 
				
			||||||
        "$0" test
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    ml-release)
 | 
					 | 
				
			||||||
        if [ $# -ne 1 ]; then
 | 
					 | 
				
			||||||
            echo "$0 ml-release version" >&2
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        version=$1; shift
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        to=${to_a}@${to_d}
 | 
					 | 
				
			||||||
        from=${from_a}@${from_d}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        ( 
 | 
					 | 
				
			||||||
        cat << eof
 | 
					 | 
				
			||||||
From: ${ml_name} <$from>
 | 
					 | 
				
			||||||
To: cdist mailing list <$to>
 | 
					 | 
				
			||||||
Subject: cdist $version has been released
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Hello .*,
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
cdist $version has been released with the following changes:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
eof
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        "$0" changelog-changes "$version"
 | 
					 | 
				
			||||||
        cat << eof
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Cheers,
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
${ml_sig_name}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- 
 | 
					 | 
				
			||||||
Automatisation at its best level. With cdist.
 | 
					 | 
				
			||||||
eof
 | 
					 | 
				
			||||||
        ) > mailinglist.tmp
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    release-git-tag)
 | 
					 | 
				
			||||||
        target_version=$($0 changelog-version)
 | 
					 | 
				
			||||||
        if git rev-parse --verify refs/tags/$target_version 2>/dev/null; then
 | 
					 | 
				
			||||||
            echo "Tag for $target_version exists, aborting"
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        printf "Enter tag description for ${target_version}: "
 | 
					 | 
				
			||||||
        read tagmessage
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # setup for signed tags:
 | 
					 | 
				
			||||||
        # gpg --fulL-gen-key
 | 
					 | 
				
			||||||
        # gpg --list-secret-keys --keyid-format LONG
 | 
					 | 
				
			||||||
        # git config --local user.signingkey <id>
 | 
					 | 
				
			||||||
        # for exporting pub key:
 | 
					 | 
				
			||||||
        #     gpg --armor --export <id> > pubkey.asc
 | 
					 | 
				
			||||||
        #     gpg --output pubkey.gpg --export <id>
 | 
					 | 
				
			||||||
        # show tag with signature
 | 
					 | 
				
			||||||
        # git show <tag>
 | 
					 | 
				
			||||||
        # verify tag signature
 | 
					 | 
				
			||||||
        # git tag -v <tag>
 | 
					 | 
				
			||||||
        #
 | 
					 | 
				
			||||||
        # gpg verify signature
 | 
					 | 
				
			||||||
        # gpg --verify <asc-file> <file>
 | 
					 | 
				
			||||||
        # gpg --no-default-keyring --keyring <pubkey.gpg> --verify <asc-file> <file>
 | 
					 | 
				
			||||||
        # Ensure gpg-agent is running.
 | 
					 | 
				
			||||||
        export GPG_TTY=$(tty)
 | 
					 | 
				
			||||||
        gpg-agent
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        git tag -s "$target_version" -m "$tagmessage"
 | 
					 | 
				
			||||||
        git push --tags
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    sign-git-release)
 | 
					 | 
				
			||||||
        if [ $# -lt 2 ]
 | 
					 | 
				
			||||||
        then
 | 
					 | 
				
			||||||
            printf "usage: $0 sign-git-release TAG TOKEN [ARCHIVE]\n"
 | 
					 | 
				
			||||||
            printf "    if ARCHIVE is not specified then it is created\n"
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        tag="$1"
 | 
					 | 
				
			||||||
        if ! git rev-parse -q --verify "${tag}" >/dev/null 2>&1
 | 
					 | 
				
			||||||
        then
 | 
					 | 
				
			||||||
            printf "Tag \"${tag}\" not found.\n"
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        token="$2"
 | 
					 | 
				
			||||||
        if [ $# -gt 2 ]
 | 
					 | 
				
			||||||
        then
 | 
					 | 
				
			||||||
            archivename="$3"
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            archivename="cdist-${tag}.tar"
 | 
					 | 
				
			||||||
            git archive --prefix="cdist-${tag}/" -o "${archivename}" "${tag}" \
 | 
					 | 
				
			||||||
                || exit 1
 | 
					 | 
				
			||||||
            # make sure target version is generated
 | 
					 | 
				
			||||||
            "$0" target-version
 | 
					 | 
				
			||||||
            tar -x -f "${archivename}" || exit 1
 | 
					 | 
				
			||||||
            cp cdist/version.py "cdist-${tag}/cdist/version.py" || exit 1
 | 
					 | 
				
			||||||
            tar -c -f "${archivename}" "cdist-${tag}/" || exit 1
 | 
					 | 
				
			||||||
            rm -r -f "cdist-${tag}/"
 | 
					 | 
				
			||||||
            gzip "${archivename}" || exit 1
 | 
					 | 
				
			||||||
            archivename="${archivename}.gz"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        gpg --armor --detach-sign "${archivename}" || exit 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        project="ungleich-public%2Fcdist"
 | 
					 | 
				
			||||||
        sed_cmd='s/^.*"markdown":"\([^"]*\)".*$/\1/'
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # upload archive
 | 
					 | 
				
			||||||
        response_archive=$(curl -f -X POST \
 | 
					 | 
				
			||||||
             --http1.1 \
 | 
					 | 
				
			||||||
             -H "PRIVATE-TOKEN: ${token}" \
 | 
					 | 
				
			||||||
             -F "file=@${archivename}" \
 | 
					 | 
				
			||||||
             "https://code.ungleich.ch/api/v4/projects/${project}/uploads" \
 | 
					 | 
				
			||||||
             | sed "${sed_cmd}") || exit 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # upload archive signature
 | 
					 | 
				
			||||||
        response_archive_sig=$(curl -f -X POST \
 | 
					 | 
				
			||||||
             --http1.1 \
 | 
					 | 
				
			||||||
             -H "PRIVATE-TOKEN: ${token}" \
 | 
					 | 
				
			||||||
             -F "file=@${archivename}.asc" \
 | 
					 | 
				
			||||||
            "https://code.ungleich.ch/api/v4/projects/${project}/uploads" \
 | 
					 | 
				
			||||||
             | sed "${sed_cmd}") || exit 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # make release
 | 
					 | 
				
			||||||
        changelog=$("$0" changelog-changes "$1" | sed 's/^[[:space:]]*//')
 | 
					 | 
				
			||||||
        release_notes=$(
 | 
					 | 
				
			||||||
            printf "Release %s\n\n%s\n\n%s\n\n**Changelog**\n\n%s\n" \
 | 
					 | 
				
			||||||
                "${tag}" "${response_archive}" "${response_archive_sig}" "${changelog}"
 | 
					 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
        curl -f -X POST \
 | 
					 | 
				
			||||||
             -H "PRIVATE-TOKEN: ${token}" \
 | 
					 | 
				
			||||||
             -F "description=${release_notes}" \
 | 
					 | 
				
			||||||
            "https://code.ungleich.ch/api/v4/projects/${project}/repository/tags/${tag}/release" \
 | 
					 | 
				
			||||||
            || exit 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # remove generated files (archive and asc)
 | 
					 | 
				
			||||||
        if [ $# -eq 2 ]
 | 
					 | 
				
			||||||
        then
 | 
					 | 
				
			||||||
            rm -f "${archivename}"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        rm -f "${archivename}.asc"
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    release)
 | 
					 | 
				
			||||||
        set -e
 | 
					 | 
				
			||||||
        target_version=$($0 changelog-version)
 | 
					 | 
				
			||||||
        target_branch=$($0 version-branch)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        echo "Beginning release process for $target_version"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # First check everything is sane
 | 
					 | 
				
			||||||
        "$0" check-date
 | 
					 | 
				
			||||||
        "$0" check-unittest
 | 
					 | 
				
			||||||
        "$0" check-pycodestyle
 | 
					 | 
				
			||||||
        "$0" shellcheck
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Generate version file to be included in packaging
 | 
					 | 
				
			||||||
        "$0" target-version
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Ensure the git status is clean, else abort
 | 
					 | 
				
			||||||
        if ! git diff-index --name-only --exit-code HEAD ; then
 | 
					 | 
				
			||||||
            echo "Unclean tree, see files above, aborting"
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Ensure we are on the master branch
 | 
					 | 
				
			||||||
        masterbranch=yes
 | 
					 | 
				
			||||||
        if [ "$(git rev-parse --abbrev-ref HEAD)" != "master" ]; then
 | 
					 | 
				
			||||||
            echo "Releases are happening from the master branch, aborting"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            echo "Enter the magic word to release anyway"
 | 
					 | 
				
			||||||
            read magicword
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            if [ "$magicword" = "iknowwhatido" ]; then
 | 
					 | 
				
			||||||
                masterbranch=no
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
                exit 1
 | 
					 | 
				
			||||||
            fi
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if [ "$masterbranch" = yes ]; then
 | 
					 | 
				
			||||||
            # Ensure version branch exists
 | 
					 | 
				
			||||||
            if ! git rev-parse --verify refs/heads/$target_branch 2>/dev/null; then
 | 
					 | 
				
			||||||
                git branch "$target_branch"
 | 
					 | 
				
			||||||
            fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            # Merge master branch into version branch
 | 
					 | 
				
			||||||
            git checkout "$target_branch"
 | 
					 | 
				
			||||||
            git merge master
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Verify that after the merge everything works
 | 
					 | 
				
			||||||
        "$0" check-date
 | 
					 | 
				
			||||||
        "$0" check-unittest
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Generate documentation (man and html)
 | 
					 | 
				
			||||||
        # First, clean old generated docs
 | 
					 | 
				
			||||||
        make helper=${helper} docs-clean
 | 
					 | 
				
			||||||
        make helper=${helper} docs
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        ############################################################# 
 | 
					 | 
				
			||||||
        # Everything green, let's do the release
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Tag the current commit
 | 
					 | 
				
			||||||
        "$0" release-git-tag
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Also merge back the version branch
 | 
					 | 
				
			||||||
        if [ "$masterbranch" = yes ]; then
 | 
					 | 
				
			||||||
            git checkout master
 | 
					 | 
				
			||||||
            git merge "$target_branch"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Publish git changes
 | 
					 | 
				
			||||||
        case "$run_as" in
 | 
					 | 
				
			||||||
            freebsd)
 | 
					 | 
				
			||||||
                # if we are not Nico :) then just push, no mirror
 | 
					 | 
				
			||||||
                git push
 | 
					 | 
				
			||||||
                # push also new branch and set up tracking
 | 
					 | 
				
			||||||
                git push -u origin "${target_branch}"
 | 
					 | 
				
			||||||
            ;;
 | 
					 | 
				
			||||||
            *)
 | 
					 | 
				
			||||||
                make helper=${helper} pub
 | 
					 | 
				
			||||||
            ;;
 | 
					 | 
				
			||||||
        esac
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Ensure that pypi release has the right version
 | 
					 | 
				
			||||||
        "$0" version
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Create and publish package for pypi
 | 
					 | 
				
			||||||
        make helper=${helper} pypi-release
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # sign git tag
 | 
					 | 
				
			||||||
        printf "Enter upstream repository authentication token: "
 | 
					 | 
				
			||||||
        read token
 | 
					 | 
				
			||||||
        "$0" sign-git-release "${target_version}" "${token}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # Announce change on ML
 | 
					 | 
				
			||||||
        make helper=${helper} ml-release
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        cat << eof
 | 
					 | 
				
			||||||
Manual steps post release:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    - cdist-web
 | 
					 | 
				
			||||||
    - twitter
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
eof
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    test)
 | 
					 | 
				
			||||||
        export PYTHONPATH="$(pwd -P)"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if [ $# -lt 1 ]; then
 | 
					 | 
				
			||||||
            python3 -m cdist.test
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            python3 -m unittest "$@"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    test-remote)
 | 
					 | 
				
			||||||
        export PYTHONPATH="$(pwd -P)"
 | 
					 | 
				
			||||||
        python3 -m cdist.test.exec.remote
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    pycodestyle|pep8)
 | 
					 | 
				
			||||||
        pycodestyle "${basedir}" "${basedir}/scripts/cdist" | less
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    check-pycodestyle)
 | 
					 | 
				
			||||||
        "$0" pycodestyle
 | 
					 | 
				
			||||||
        printf "\\nPlease review pycodestyle report.\\n"
 | 
					 | 
				
			||||||
        while true
 | 
					 | 
				
			||||||
        do
 | 
					 | 
				
			||||||
            echo "Continue (yes/no)?"
 | 
					 | 
				
			||||||
            any=
 | 
					 | 
				
			||||||
            read any
 | 
					 | 
				
			||||||
            case "$any" in
 | 
					 | 
				
			||||||
                yes)
 | 
					 | 
				
			||||||
                    break
 | 
					 | 
				
			||||||
                ;;
 | 
					 | 
				
			||||||
                no)
 | 
					 | 
				
			||||||
                    exit 1
 | 
					 | 
				
			||||||
                ;;
 | 
					 | 
				
			||||||
                *)
 | 
					 | 
				
			||||||
                    echo "Please answer with 'yes' or 'no' explicitly."
 | 
					 | 
				
			||||||
                ;;
 | 
					 | 
				
			||||||
        esac
 | 
					 | 
				
			||||||
        done
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    shellcheck)
 | 
					 | 
				
			||||||
        make helper=${helper} shellcheck
 | 
					 | 
				
			||||||
        printf "\\nPlease review shellcheck report.\\n"
 | 
					 | 
				
			||||||
        while true
 | 
					 | 
				
			||||||
        do
 | 
					 | 
				
			||||||
            echo "Continue (yes/no)?"
 | 
					 | 
				
			||||||
            any=
 | 
					 | 
				
			||||||
            read any
 | 
					 | 
				
			||||||
            case "$any" in
 | 
					 | 
				
			||||||
                yes)
 | 
					 | 
				
			||||||
                    break
 | 
					 | 
				
			||||||
                ;;
 | 
					 | 
				
			||||||
                no)
 | 
					 | 
				
			||||||
                    exit 1
 | 
					 | 
				
			||||||
                ;;
 | 
					 | 
				
			||||||
                *)
 | 
					 | 
				
			||||||
                    echo "Please answer with 'yes' or 'no' explicitly."
 | 
					 | 
				
			||||||
                ;;
 | 
					 | 
				
			||||||
        esac
 | 
					 | 
				
			||||||
        done
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    version-branch)
 | 
					 | 
				
			||||||
        "$0" changelog-version | cut -d. -f '1,2'
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    version)
 | 
					 | 
				
			||||||
        echo "VERSION = \"$(git describe)\"" > cdist/version.py
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    target-version)
 | 
					 | 
				
			||||||
        target_version=$($0 changelog-version)
 | 
					 | 
				
			||||||
        echo "VERSION = \"${target_version}\"" > cdist/version.py
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    *)
 | 
					 | 
				
			||||||
        echo "Unknown helper target $@ - aborting"
 | 
					 | 
				
			||||||
        exit 1
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
esac
 | 
					 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue