summaryrefslogtreecommitdiffhomepage
path: root/scripts/build.sh
diff options
context:
space:
mode:
authorgVisor bot <gvisor-bot@google.com>2019-09-09 13:21:41 -0700
committergVisor bot <gvisor-bot@google.com>2019-09-09 13:21:41 -0700
commit6af9a9850aff75e15c6f9ab577af5b818531d6ee (patch)
treed9f41fba55d4b9bc67c7f8ada20c3a8a073edd77 /scripts/build.sh
parenta8943325db43d04be8a10157f6d3f3180e5170a5 (diff)
parent1a0a940587e4db8923ca81b78d7bba395eb56ce1 (diff)
Merge pull request #824 from amscanne:fix_build2
PiperOrigin-RevId: 268062329
Diffstat (limited to 'scripts/build.sh')
-rwxr-xr-xscripts/build.sh32
1 files changed, 19 insertions, 13 deletions
diff --git a/scripts/build.sh b/scripts/build.sh
index ee2de3b94..d5dd14acc 100755
--- a/scripts/build.sh
+++ b/scripts/build.sh
@@ -24,16 +24,17 @@ pkg=$(build -c opt --host_force_python=py2 //runsc:runsc-debian)
# Build a repository, if the key is available.
if [[ -v KOKORO_REPO_KEY ]]; then
- repo=$(tools/make_repository.sh "${KOKORO_REPO_KEY}" gvisor-bot@google.com)
+ repo=$(tools/make_repository.sh "${KOKORO_REPO_KEY}" gvisor-bot@google.com ${pkg})
fi
# Install installs artifacts.
install() {
- mkdir -p $1
- cp "${runsc}" "$1"/runsc
- sha512sum "$1"/runsc | awk '{print $1 " runsc"}' > "$1"/runsc.sha512
+ local dir="$1"
+ mkdir -p "${dir}"
+ cp -f "${runsc}" "${dir}"/runsc
+ sha512sum "${dir}"/runsc | awk '{print $1 " runsc"}' > "${dir}"/runsc.sha512
if [[ -v repo ]]; then
- cp -a "${repo}" "${latest_dir}"/repo
+ rm -rf "${dir}"/repo && cp -a "${repo}" "$dir"/repo
fi
}
@@ -49,14 +50,19 @@ if [[ -v KOKORO_ARTIFACTS_DIR ]]; then
# Is it a tagged release? Build that instead. In that case, we also try to
# update the base release directory, in case this is an update. Finally, we
# update the "release" directory, which has the last released version.
- tag="$(git describe --exact-match --tags HEAD || true)"
- if ! [[ -z "${tag}" ]]; then
- install "${KOKORO_ARTIFACTS_DIR}/${tag}"
- base=$(echo "${tag}" | cut -d'.' -f1)
- if [[ "${base}" != "${tag}" ]]; then
- install "${KOKORO_ARTIFACTS_DIR}/${base}"
- fi
- install "${KOKORO_ARTIFACTS_DIR}/release"
+ tags="$(git tag --points-at HEAD)"
+ if ! [[ -z "${tags}" ]]; then
+ # Note that a given commit can match any number of tags. We have to
+ # iterate through all possible tags and produce associated artifacts.
+ for tag in ${tags}; do
+ name=$(echo "${tag}" | cut -d'-' -f2)
+ base=$(echo "${name}" | cut -d'.' -f1)
+ install "${KOKORO_ARTIFACTS_DIR}/release/${name}"
+ if [[ "${base}" != "${tag}" ]]; then
+ install "${KOKORO_ARTIFACTS_DIR}/release/${base}"
+ fi
+ install "${KOKORO_ARTIFACTS_DIR}/release/latest"
+ done
fi
fi
fi