Refactor a little to accomodate overriding packaging using directories

pull/4245/head
Matt Keeler 2018-06-18 11:23:32 -04:00
parent 82857b2121
commit ca1a0619bd
3 changed files with 211 additions and 59 deletions

View File

@ -753,4 +753,53 @@ function commit_dev_mode {
popd >/dev/null popd >/dev/null
return ${ret} return ${ret}
} }
function gpg_detach_sign {
# Arguments:
# $1 - File to sign
# $2 - Alternative GPG key to use for signing
#
# Returns:
# 0 - success
# * - failure
# determine whether the gpg key to use is being overridden
local gpg_key=${HASHICORP_GPG_KEY}
if test -n "$2"
then
gpg_key=$2
fi
gpg --default-key "${gpg_key}" --detach-sig --yes -v "$1"
return $?
}
function shasum_directory {
# Arguments:
# $1 - Path to directory containing the files to shasum
# $2 - File to output sha sums to
#
# Returns:
# 0 - success
# * - failure
if ! test -d "$1"
then
err "ERROR: '$1' is not a directory and shasum_release requires passing a directory as the first argument"
return 1
fi
if test -z "$2"
then
err "ERROR: shasum_release requires a second argument to be the filename to output the shasums to but none was given"
return 1
fi
pushd $1 > /dev/null
shasum -a256 * > "$2"
ret=$?
popd >/dev/null
return $ret
}

View File

@ -180,7 +180,7 @@ function build_assetfs {
function build_consul_post { function build_consul_post {
# Arguments # Arguments
# $1 - Path to the top level Consul source # $1 - Path to the top level Consul source
# $2 - build suffix (Optional) # $2 - Subdirectory under pkg/bin (Optional)
# #
# Returns: # Returns:
# 0 - success # 0 - success
@ -199,17 +199,25 @@ function build_consul_post {
local sdir="$1" local sdir="$1"
local extra_dir_name="$2"
local extra_dir=""
if test -n "${extra_dir_name}"
then
extra_dir="${extra_dir_name}/"
fi
pushd "${sdir}" > /dev/null pushd "${sdir}" > /dev/null
# recreate the pkg dir # recreate the pkg dir
rm -r pkg/bin/*${2} 2> /dev/null rm -r pkg/bin/${extra_dir}* 2> /dev/null
mkdir -p pkg/bin 2> /dev/null mkdir -p pkg/bin/${extra_dir} 2> /dev/null
# move all files in pkg.new into pkg # move all files in pkg.new into pkg
cp -r pkg.bin.new/* pkg/bin/ cp -r pkg.bin.new/${extra_dir}* pkg/bin/${extra_dir}
rm -r pkg.bin.new rm -r pkg.bin.new
DEV_PLATFORM="./pkg/bin/$(go env GOOS)_$(go env GOARCH)${2}" DEV_PLATFORM="./pkg/bin/${extra_dir}$(go env GOOS)_$(go env GOARCH)"
for F in $(find ${DEV_PLATFORM} -mindepth 1 -maxdepth 1 -type f) for F in $(find ${DEV_PLATFORM} -mindepth 1 -maxdepth 1 -type f)
do do
# recreate the bin dir # recreate the bin dir
@ -228,7 +236,7 @@ function build_consul_post {
function build_consul { function build_consul {
# Arguments: # Arguments:
# $1 - Path to the top level Consul source # $1 - Path to the top level Consul source
# $2 - build suffix (optional - must specify if needing to specify the docker image) # $2 - Subdirectory to put binaries in under pkg/bin (optional - must specify if needing to specify the docker image)
# $3 - The docker image to run the build within (optional) # $3 - The docker image to run the build within (optional)
# #
# Returns: # Returns:
@ -248,7 +256,8 @@ function build_consul {
fi fi
local sdir="$1" local sdir="$1"
local build_suffix="$2" local extra_dir_name="$2"
local extra_dir=""
local image_name=${GO_BUILD_CONTAINER_DEFAULT} local image_name=${GO_BUILD_CONTAINER_DEFAULT}
if test -n "$3" if test -n "$3"
then then
@ -271,15 +280,20 @@ function build_consul {
fi fi
XC_OS=${XC_OS:-"solaris darwin freebsd linux windows"} XC_OS=${XC_OS:-"solaris darwin freebsd linux windows"}
XC_ARCH=${XC_ARCH:-"386 amd64 arm arm64"} XC_ARCH=${XC_ARCH:-"386 amd64 arm arm64"}
if test -n "${extra_dir_name}"
then
extra_dir="${extra_dir_name}/"
fi
local container_id=$(docker create -it -e CGO_ENABLED=0 ${image_name} gox -os="${XC_OS}" -arch="${XC_ARCH}" -osarch="!darwin/arm !darwin/arm64" -ldflags "${GOLDFLAGS}" -output "pkg/bin/{{.OS}}_{{.Arch}}${build_suffix}/consul" -tags="${GOTAGS}") local container_id=$(docker create -it -e CGO_ENABLED=0 ${image_name} gox -os="${XC_OS}" -arch="${XC_ARCH}" -osarch="!darwin/arm !darwin/arm64" -ldflags "${GOLDFLAGS}" -output "pkg/bin/${extra_dir}{{.OS}}_{{.Arch}}/consul" -tags="${GOTAGS}")
ret=$? ret=$?
if test $ret -eq 0 if test $ret -eq 0
then then
status "Copying the source from '${sdir}' to /go/src/github.com/hashicorp/consul/pkg" status "Copying the source from '${sdir}' to /go/src/github.com/hashicorp/consul"
( (
tar -c $(ls | grep -v "ui\|ui-v2\|website\|bin\|.git") | docker cp - ${container_id}:/go/src/github.com/hashicorp/consul && tar -c $(ls | grep -v "^(ui\|ui-v2\|website\|bin\|pkg\|.git)") | docker cp - ${container_id}:/go/src/github.com/hashicorp/consul &&
status "Running build in container" && status "Running build in container" &&
docker start -i ${container_id} && docker start -i ${container_id} &&
status "Copying back artifacts" && status "Copying back artifacts" &&
@ -290,7 +304,7 @@ function build_consul {
if test $ret -eq 0 if test $ret -eq 0
then then
build_consul_post "${sdir}" "${build_suffix}" build_consul_post "${sdir}" "${extra_dir_name}"
ret=$? ret=$?
else else
rm -r pkg.bin.new 2> /dev/null rm -r pkg.bin.new 2> /dev/null
@ -305,7 +319,7 @@ function build_consul_local {
# $1 - Path to the top level Consul source # $1 - Path to the top level Consul source
# $2 - Space separated string of OSes to build. If empty will use env vars for determination. # $2 - Space separated string of OSes to build. If empty will use env vars for determination.
# $3 - Space separated string of architectures to build. If empty will use env vars for determination. # $3 - Space separated string of architectures to build. If empty will use env vars for determination.
# $4 - build suffix (optional) # $4 - Subdirectory to put binaries in under pkg/bin (optional)
# #
# Returns: # Returns:
# 0 - success # 0 - success
@ -326,7 +340,13 @@ function build_consul_local {
local sdir="$1" local sdir="$1"
local build_os="$2" local build_os="$2"
local build_arch="$3" local build_arch="$3"
local build_suffix="$4" local extra_dir_name="$4"
local extra_dir=""
if test -n "${extra_dir_name}"
then
extra_dir="${extra_dir_name}/"
fi
pushd ${sdir} > /dev/null pushd ${sdir} > /dev/null
if is_set "${CONSUL_DEV}" if is_set "${CONSUL_DEV}"
@ -361,7 +381,7 @@ function build_consul_local {
-arch="${build_arch}" \ -arch="${build_arch}" \
-osarch="!darwin/arm !darwin/arm64" \ -osarch="!darwin/arm !darwin/arm64" \
-ldflags="${GOLDFLAGS}" \ -ldflags="${GOLDFLAGS}" \
-output "pkg.bin.new/{{.OS}}_{{.Arch}}${build_suffix}/consul" \ -output "pkg.bin.new/${extra_dir}{{.OS}}_{{.Arch}}${build_suffix}/consul" \
-tags="${GOTAGS}" \ -tags="${GOTAGS}" \
. .
@ -372,7 +392,7 @@ function build_consul_local {
return 1 return 1
fi fi
build_consul_post "${sdir}" "${build_suffix}" build_consul_post "${sdir}" "${extra_dir_name}"
if test $? -ne 0 if test $? -ne 0
then then
err "ERROR: Failed postprocessing Consul binaries" err "ERROR: Failed postprocessing Consul binaries"

View File

@ -63,10 +63,54 @@ function tag_release {
return $ret return $ret
} }
function package_release { function package_binaries {
# Arguments:
# $1 - Path to the directory containing the built binaries
# $2 - Destination path of the packaged binaries
# $3 - Version
#
# Returns:
# 0 - success
# * - error
local sdir="$1"
local ddir="$2"
local vers="$3"
local ret=0
if ! test -d "${sdir}"
then
err "ERROR: '$1' is not a directory. package_binaries must be called with the path to the directory containing the binaries"
return 1
fi
rm -rf "${ddir}" > /dev/null 2>&1
mkdir -p "${ddir}" >/dev/null 2>&1
for platform in $(find "${sdir}" -mindepth 1 -maxdepth 1 -type d)
do
local os_arch=$(basename $platform)
local dest="${ddir}/${CONSUL_PKG_NAME}_${vers}_${os_arch}.zip"
status "Compressing ${os_arch} directory into ${dest}"
pushd "${platform}" > /dev/null
zip "${ddir}/${CONSUL_PKG_NAME}_${vers}_${os_arch}.zip" ./*
ret=$?
popd > /dev/null
if test "$ret" -ne 0
then
break
fi
done
return ${ret}
}
function package_release_one {
# Arguments: # Arguments:
# $1 - Path to the top level Consul source # $1 - Path to the top level Consul source
# $2 - Version to use in the names of the zip files (optional) # $2 - Version to use in the names of the zip files (optional)
# $3 - Subdirectory under pkg/dist to use (optional)
# #
# Returns: # Returns:
# 0 - success # 0 - success
@ -78,9 +122,16 @@ function package_release {
return 1 return 1
fi fi
local sdir="${1}" local sdir="$1"
local ret=0 local ret=0
local vers="${2}" local vers="$2"
local extra_dir_name="$3"
local extra_dir=""
if test -n "${extra_dir_name}"
then
extra_dir="${extra_dir_name}/"
fi
if test -z "${vers}" if test -z "${vers}"
then then
@ -93,81 +144,91 @@ function package_release {
fi fi
fi fi
rm -rf "${sdir}/pkg/dist" > /dev/null 2>&1 package_binaries "${sdir}/pkg/bin/${extra_dir}" "${sdir}/pkg/dist/${extra_dir}" "${vers}"
mkdir -p "${sdir}/pkg/dist" >/dev/null 2>&1 return $?
for platform in $(find "${sdir}/pkg/bin" -mindepth 1 -maxdepth 1 -type d) }
do
local os_arch=$(basename $platform) function package_release {
local dest="${sdir}/pkg/dist/${CONSUL_PKG_NAME}_${vers}_${os_arch}.zip" # Arguments:
status "Compressing ${os_arch} directory into ${dest}" # $1 - Path to the top level Consul source
pushd "${platform}" > /dev/null # $2 - Version to use in the names of the zip files (optional)
zip "${sdir}/pkg/dist/${CONSUL_PKG_NAME}_${vers}_${os_arch}.zip" ./* #
ret=$? # Returns:
popd > /dev/null # 0 - success
# * - error
if test "$ret" -ne 0
then
break
fi
done
return $ret package_release_one "$1" "$2" ""
return $?
} }
function shasum_release { function shasum_release {
# Arguments: # Arguments:
# $1 - Path to directory containing the files to shasum # $1 - Path to the dist directory
# $2 - File to output sha sums to # $2 - Version of the release
# #
# Returns: # Returns:
# 0 - success # 0 - success
# * - failure # * - failure
local sdir="$1"
local vers="$2"
if ! test -d "$1" if ! test -d "$1"
then then
err "ERROR: '$1' is not a directory and shasum_release requires passing a directory as the first argument" err "ERROR: sign_release requires a path to the dist dir as the first argument"
return 1 return 1
fi fi
if test -z "$2" if test -z "${vers}"
then then
err "ERROR: shasum_release requires a second argument to be the filename to output the shasums to but none was given" err "ERROR: sign_release requires a version to be specified as the second argument"
return 1 return 1
fi fi
pushd $1 > /dev/null local hfile="${CONSUL_PKG_NAME}_${vers}_SHA256SUMS"
shasum -a256 * > "$2"
ret=$?
popd >/dev/null
return $ret shasum_directory "${sdir}" "${sdir}/${hfile}"
return $?
} }
function sign_release { function sign_release {
# Arguments: # Arguments:
# $1 - File to sign # $1 - Path to distribution directory
# $2 - Version
# $2 - Alternative GPG key to use for signing # $2 - Alternative GPG key to use for signing
# #
# Returns: # Returns:
# 0 - success # 0 - success
# * - failure # * - failure
# determine whether the gpg key to use is being overridden local sdir="$1"
local gpg_key=${HASHICORP_GPG_KEY} local vers="$2"
if test -n "$2"
if ! test -d "${sdir}"
then then
gpg_key=$2 err "ERROR: sign_release requires a path to the dist dir as the first argument"
return 1
fi fi
gpg --default-key "${gpg_key}" --detach-sig --yes -v "$1" if test -z "${vers}"
return $? then
err "ERROR: sign_release requires a version to be specified as the second argument"
return 1
fi
local hfile="${CONSUL_PKG_NAME}_${vers}_SHA256SUMS"
status_stage "==> Signing ${hfile}"
gpg_detach_sign "${1}/${hfile}" "$2" || return 1
return 0
} }
function check_release { function check_release_one {
# Arguments: # Arguments:
# $1 - Path to the release files # $1 - Path to the release files
# $2 - Version to expect # $2 - Version to expect
# $3 - boolean whether to expect the signature file # $3 - boolean whether to expect the signature file
# $4 - Release Name (optional)
# #
# Returns: # Returns:
# 0 - success # 0 - success
@ -177,6 +238,13 @@ function check_release {
declare -a expected_files declare -a expected_files
declare log_extra=""
if test -n "$4"
then
log_extra="for $4 "
fi
expected_files+=("${CONSUL_PKG_NAME}_${2}_SHA256SUMS") expected_files+=("${CONSUL_PKG_NAME}_${2}_SHA256SUMS")
echo "check sig: $3" echo "check sig: $3"
if is_set "$3" if is_set "$3"
@ -199,7 +267,7 @@ function check_release {
declare -a found_files declare -a found_files
status_stage "==> Verifying release contents - ${2}" status_stage "==> Verifying release contents ${log_extra}- ${2}"
debug "Expecting Files:" debug "Expecting Files:"
for fname in "${expected_files[@]}" for fname in "${expected_files[@]}"
do do
@ -254,6 +322,21 @@ function check_release {
return $ret return $ret
} }
function check_release {
# Arguments:
# $1 - Path to the release files
# $2 - Version to expect
# $3 - boolean whether to expect the signature file
#
# Returns:
# 0 - success
# * - failure
check_release_one "$1" "$2" "$3"
return ${ret}
}
function build_consul_release { function build_consul_release {
build_consul "$1" "" "$2" build_consul "$1" "" "$2"
} }
@ -420,7 +503,7 @@ function build_release {
fi fi
status_stage "==> Generating SHA 256 Hashes for Binaries" status_stage "==> Generating SHA 256 Hashes for Binaries"
shasum_release "${sdir}/pkg/dist" "${CONSUL_PKG_NAME}_${vers}_SHA256SUMS" shasum_release "${sdir}/pkg/dist" "${vers}"
if test $? -ne 0 if test $? -ne 0
then then
err "ERROR: Failed to generate SHA 256 hashes for the release" err "ERROR: Failed to generate SHA 256 hashes for the release"
@ -429,7 +512,7 @@ function build_release {
if is_set "${do_sha256}" if is_set "${do_sha256}"
then then
sign_release "${sdir}/pkg/dist/${CONSUL_PKG_NAME}_${vers}_SHA256SUMS" "${gpg_key}" sign_release "${sdir}/pkg/dist" "${vers}" "${gpg_key}"
if test $? -ne 0 if test $? -ne 0
then then
err "ERROR: Failed to sign the SHA 256 hashes file" err "ERROR: Failed to sign the SHA 256 hashes file"