make+build: call release script from makefile

This commit is contained in:
Oliver Gugger 2020-04-21 10:19:58 +02:00
parent ce00f52ca2
commit 317ccb2cc9
No known key found for this signature in database
GPG Key ID: 8E4256593F177720
2 changed files with 155 additions and 128 deletions

@ -49,17 +49,25 @@ MAKE := make
XARGS := xargs -L 1 XARGS := xargs -L 1
include make/testing_flags.mk include make/testing_flags.mk
include make/release_flags.mk
DEV_TAGS := $(if ${tags},$(DEV_TAGS) ${tags},$(DEV_TAGS)) DEV_TAGS := $(if ${tags},$(DEV_TAGS) ${tags},$(DEV_TAGS))
make_ldflags = -ldflags "$(shell echo -X $(PKG)/build.Commit=$(COMMIT) \ # We only return the part inside the double quote here to avoid escape issues
# when calling the external release script. The second parameter can be used to
# add additional ldflags if needed (currently only used for the release).
make_ldflags = $(2) -X $(PKG)/build.Commit=$(COMMIT) \
-X $(PKG)/build.CommitHash=$(COMMIT_HASH) \ -X $(PKG)/build.CommitHash=$(COMMIT_HASH) \
-X $(PKG)/build.GoVersion=$(GOVERSION) \ -X $(PKG)/build.GoVersion=$(GOVERSION) \
-X $(PKG)/build.RawTags=$(shell echo $(1) | sed -e 's/ /,/g'))" -X $(PKG)/build.RawTags=$(shell echo $(1) | sed -e 's/ /,/g')
LDFLAGS := $(call make_ldflags, ${tags}) LDFLAGS := -ldflags "$(call make_ldflags, ${tags})"
DEV_LDFLAGS := $(call make_ldflags, $(DEV_TAGS)) DEV_LDFLAGS := -ldflags "$(call make_ldflags, $(DEV_TAGS))"
ITEST_LDFLAGS := $(call make_ldflags, $(ITEST_TAGS)) ITEST_LDFLAGS := -ldflags "$(call make_ldflags, $(ITEST_TAGS))"
# For the release, we want to remove the symbol table and debug information (-s)
# and omit the DWARF symbol table (-w). Also we clear the build ID.
RELEASE_LDFLAGS := $(call make_ldflags, $(RELEASE_TAGS), -s -w -buildid=)
# Linting uses a lot of memory, so keep it under control by limiting the number # Linting uses a lot of memory, so keep it under control by limiting the number
# of workers if requested. # of workers if requested.
@ -118,6 +126,11 @@ install:
$(GOINSTALL) -tags="${tags}" $(LDFLAGS) $(PKG)/cmd/lnd $(GOINSTALL) -tags="${tags}" $(LDFLAGS) $(PKG)/cmd/lnd
$(GOINSTALL) -tags="${tags}" $(LDFLAGS) $(PKG)/cmd/lncli $(GOINSTALL) -tags="${tags}" $(LDFLAGS) $(PKG)/cmd/lncli
release:
@$(call print, "Releasing lnd and lncli binaries.")
$(VERSION_CHECK)
./build/release/release.sh build-release "$(VERSION_TAG)" "$(BUILD_SYSTEM)" "$(RELEASE_TAGS)" "$(RELEASE_LDFLAGS)"
scratch: build scratch: build

@ -9,138 +9,152 @@
set -e set -e
# If no tag specified, use date + version otherwise use tag. LND_VERSION_REGEX="lnd version (.+) commit"
if [[ $1x = x ]]; then PKG="github.com/lightningnetwork/lnd"
DATE=`date +%Y%m%d` PACKAGE=lnd
VERSION="01"
TAG=$DATE-$VERSION # green prints one line of green text (if the terminal supports it).
else function green() {
TAG=$1 echo -e "\e[0;32m${1}\e[0m"
}
# red prints one line of red text (if the terminal supports it).
function red() {
echo -e "\e[0;31m${1}\e[0m"
}
# check_tag_correct makes sure the given git tag is checked out and the git tree
# is not dirty.
# arguments: <version-tag>
function check_tag_correct() {
local tag=$1
# If a tag is specified, ensure that that tag is present and checked out. # If a tag is specified, ensure that that tag is present and checked out.
if [[ $TAG != $(git describe) ]]; then if [[ $tag != $(git describe) ]]; then
echo "tag $TAG not checked out" red "tag $tag not checked out"
exit 1 exit 1
fi fi
# Build lnd to extract version. # Build lnd to extract version.
go build github.com/lightningnetwork/lnd/cmd/lnd go build ${PKG}/cmd/lnd
# Extract version command output. # Extract version command output.
LND_VERSION_OUTPUT=`./lnd --version` lnd_version_output=$(./lnd --version)
# Use a regex to isolate the version string. # Use a regex to isolate the version string.
LND_VERSION_REGEX="lnd version (.+) commit" if [[ $lnd_version_output =~ $LND_VERSION_REGEX ]]; then
if [[ $LND_VERSION_OUTPUT =~ $LND_VERSION_REGEX ]]; then
# Prepend 'v' to match git tag naming scheme. # Prepend 'v' to match git tag naming scheme.
LND_VERSION="v${BASH_REMATCH[1]}" lnd_version="v${BASH_REMATCH[1]}"
echo "version: $LND_VERSION" green "version: $lnd_version"
# If tag contains a release candidate suffix, append this suffix to the # If tag contains a release candidate suffix, append this suffix to the
# lnd reported version before we compare. # lnd reported version before we compare.
RC_REGEX="-rc[0-9]+$" RC_REGEX="-rc[0-9]+$"
if [[ $TAG =~ $RC_REGEX ]]; then if [[ $tag =~ $RC_REGEX ]]; then
LND_VERSION+=${BASH_REMATCH[0]} lnd_version+=${BASH_REMATCH[0]}
fi fi
# Match git tag with lnd version. # Match git tag with lnd version.
if [[ $TAG != $LND_VERSION ]]; then if [[ $tag != "${lnd_version}" ]]; then
echo "lnd version $LND_VERSION does not match tag $TAG" red "lnd version $lnd_version does not match tag $tag"
exit 1 exit 1
fi fi
else else
echo "malformed lnd version output" red "malformed lnd version output"
exit 1 exit 1
fi fi
fi }
# build_release builds the actual release binaries.
# arguments: <version-tag> <build-system(s)> <build-tags> <ldflags>
function build_release() {
local tag=$1
local sys=$2
local buildtags=$3
local ldflags=$4
green " - Packaging vendor"
go mod vendor go mod vendor
tar -cvzf vendor.tar.gz vendor tar -czf vendor.tar.gz vendor
PACKAGE=lnd maindir=$PACKAGE-$tag
MAINDIR=$PACKAGE-$TAG mkdir -p $maindir
mkdir -p $MAINDIR
cp vendor.tar.gz $MAINDIR/ cp vendor.tar.gz $maindir/
rm vendor.tar.gz rm vendor.tar.gz
rm -r vendor rm -r vendor
PACKAGESRC="$MAINDIR/$PACKAGE-source-$TAG.tar" package_source="${maindir}/${PACKAGE}-source-${tag}.tar"
git archive -o $PACKAGESRC HEAD git archive -o "${package_source}" HEAD
gzip -f $PACKAGESRC > "$PACKAGESRC.gz" gzip -f "${package_source}" >"${package_source}.gz"
cd $MAINDIR cd "${maindir}"
# If LNDBUILDSYS is set the default list is ignored. Useful to release for i in $sys; do
# for a subset of systems/architectures. os=$(echo $i | cut -f1 -d-)
SYS=${LNDBUILDSYS:-" arch=$(echo $i | cut -f2 -d-)
darwin-386 arm=
darwin-amd64
dragonfly-amd64
freebsd-386
freebsd-amd64
freebsd-arm
illumos-amd64
linux-386
linux-amd64
linux-armv6
linux-armv7
linux-arm64
linux-ppc64
linux-ppc64le
linux-mips
linux-mipsle
linux-mips64
linux-mips64le
linux-s390x
netbsd-386
netbsd-amd64
netbsd-arm
netbsd-arm64
openbsd-386
openbsd-amd64
openbsd-arm
openbsd-arm64
solaris-amd64
windows-386
windows-amd64
windows-arm
"}
# Use the first element of $GOPATH in the case where GOPATH is a list if [[ $arch == "armv6" ]]; then
# (something that is totally allowed). arch=arm
PKG="github.com/lightningnetwork/lnd" arm=6
COMMIT=$(git describe --abbrev=40 --dirty) elif [[ $arch == "armv7" ]]; then
COMMITFLAGS="-X $PKG/build.Commit=$COMMIT" arch=arm
arm=7
for i in $SYS; do
OS=$(echo $i | cut -f1 -d-)
ARCH=$(echo $i | cut -f2 -d-)
ARM=
if [[ $ARCH = "armv6" ]]; then
ARCH=arm
ARM=6
elif [[ $ARCH = "armv7" ]]; then
ARCH=arm
ARM=7
fi fi
mkdir $PACKAGE-$i-$TAG dir="${PACKAGE}-${i}-${tag}"
cd $PACKAGE-$i-$TAG mkdir "${dir}"
pushd "${dir}"
echo "Building:" $OS $ARCH $ARM green " - Building: ${os} ${arch} ${arm} with build tags '${buildtags}'"
env CGO_ENABLED=0 GOOS=$OS GOARCH=$ARCH GOARM=$ARM go build -v -trimpath -ldflags="-s -w -buildid= $COMMITFLAGS" -tags="autopilotrpc signrpc walletrpc chainrpc invoicesrpc watchtowerrpc" github.com/lightningnetwork/lnd/cmd/lnd env CGO_ENABLED=0 GOOS=$os GOARCH=$arch GOARM=$arm go build -v -trimpath -ldflags="${ldflags}" -tags="${buildtags}" ${PKG}/cmd/lnd
env CGO_ENABLED=0 GOOS=$OS GOARCH=$ARCH GOARM=$ARM go build -v -trimpath -ldflags="-s -w -buildid= $COMMITFLAGS" -tags="autopilotrpc invoicesrpc walletrpc watchtowerrpc" github.com/lightningnetwork/lnd/cmd/lncli env CGO_ENABLED=0 GOOS=$os GOARCH=$arch GOARM=$arm go build -v -trimpath -ldflags="${ldflags}" -tags="${buildtags}" ${PKG}/cmd/lncli
cd .. popd
if [[ $OS = "windows" ]]; then if [[ $os == "windows" ]]; then
zip -r $PACKAGE-$i-$TAG.zip $PACKAGE-$i-$TAG zip -r "${dir}.zip" "${dir}"
else else
tar -cvzf $PACKAGE-$i-$TAG.tar.gz $PACKAGE-$i-$TAG tar -cvzf "${dir}.tar.gz" "${dir}"
fi fi
rm -r $PACKAGE-$i-$TAG rm -r "${dir}"
done done
shasum -a 256 * > manifest-$TAG.txt shasum -a 256 * >manifest-$tag.txt
}
# usage prints the usage of the whole script.
function usage() {
red "Usage: "
red "release.sh check-tag <version-tag>"
red "release.sh build-release <version-tag> <build-system(s)> <build-tags> <ldflags>"
}
# Whatever sub command is passed in, we need at least 2 arguments.
if [ "$#" -lt 2 ]; then
usage
exit 1
fi
# Extract the sub command and remove it from the list of parameters by shifting
# them to the left.
SUBCOMMAND=$1
shift
# Call the function corresponding to the specified sub command or print the
# usage if the sub command was not found.
case $SUBCOMMAND in
check-tag)
green "Checking if version tag exists"
check_tag_correct "$@"
;;
build-release)
green "Building release"
build_release "$@"
;;
*)
usage
exit 1
;;
esac