Merge pull request #337 from zmerlynn/build-from-source

Build: Build from source
This commit is contained in:
Justin Santa Barbara 2016-08-17 13:51:35 -04:00 committed by GitHub
commit 5591d8ba12
3 changed files with 34 additions and 19 deletions

3
.gitignore vendored
View File

@ -44,3 +44,6 @@ network_closure.sh
# Terraform plans get put here
/out/
# Docker _src sync
/docker/_src

View File

@ -1,7 +1,7 @@
FROM golang:1.6-alpine
# KOPS_GITISH: Modify to build at an explicit tag/gitish
ARG KOPS_GITISH=HEAD
ARG KOPS_SRC=_src
COPY $KOPS_SRC/ /go/src/k8s.io/kops/
# KUBECTL_SOURCE: Change to kubernetes-dev/ci for CI
ARG KUBECTL_SOURCE=kubernetes-release/release
@ -12,9 +12,7 @@ ARG KUBECTL_TRACK=latest.txt
ARG KUBECTL_ARCH=linux/amd64
RUN apk add --no-cache --update build-base curl git mercurial --virtual .kops-deps && \
go get -d k8s.io/kops && \
cd "${GOPATH}/src/k8s.io/kops" && git fetch origin && git reset --hard "${KOPS_GITISH}" && git clean -xdf && go get -d . && \
make && \
cd "${GOPATH}/src/k8s.io/kops" && make && ln -s /go/bin/kops /bin && \
MODELS=$(readlink "${GOPATH}/bin/models") && rm "${GOPATH}/bin/models" && mv "${MODELS}" "${GOPATH}/bin/models" && \
GITISH=$(git describe --always) && \
KUBECTL_VERSION=${KUBECTL_VERSION:-$(curl -SsL --retry 5 "https://storage.googleapis.com/${KUBECTL_SOURCE}/${KUBECTL_TRACK}")} && \
@ -22,7 +20,7 @@ RUN apk add --no-cache --update build-base curl git mercurial --virtual .kops-d
curl -SsL --retry 5 "https://storage.googleapis.com/${KUBECTL_SOURCE}/${KUBECTL_VERSION}/${KUBECTL_ARCH}/kubectl" > /usr/local/bin/kubectl && \
chmod +x /usr/local/bin/kubectl && \
/usr/local/bin/kubectl version --client && \
cd / && rm -rf "${GOPATH}/src" && rm -rf "${GOPATH}/pkg" && rm -rf "/usr/local/go" && apk del .kops-deps && \
cd / && rm -rf "${GOPATH}/src" && rm -rf "${GOPATH}/pkg" && rm -rf "/usr/local/go" && rm /usr/local/bin/go-wrapper && apk del .kops-deps && \
echo "=== Built kops at ${GITISH}, fetched kubectl ${KUBECTL_VERSION} ==="
CMD "/go/bin/kops"

View File

@ -5,11 +5,12 @@ set -o nounset
set -o pipefail
readonly DOCKER_ROOT=$(dirname "${BASH_SOURCE}")
readonly GITISH=${BUILD_GITISH:-"$(git describe --always)"}
readonly GITISH="$(git describe --always)"
readonly ARCH=${BUILD_ARCH:-"linux/amd64"}
readonly NAME=${BUILD_NAME:-"ci-${GITISH}-${ARCH/\//-}"} # e.g. ci-bef7faf-linux-amd64
readonly TMPNAME="${NAME}-$(date +%s)" # e.g. ci-bef7faf-linux-amd64-12345678
readonly TAG=${BUILD_DOCKER_TAG:-"b.gcr.io/kops-ci/kops:${NAME}"}
readonly PUSH_TAG=${BUILD_PUSH:-"no"}
readonly TMPTAG="${TAG}-$(date +%s)"
readonly LINK=${BUILD_LINK:-} # Also pushes to e.g. ci-{BUILD_LINK}-linux-amd64, i.e. for "latest"
readonly SYMBOLIC_TAG=${BUILD_SYMBOLIC_TAG:-"b.gcr.io/kops-ci/kops:ci-${LINK}-${ARCH/\//-}"}
@ -26,21 +27,29 @@ if [[ -z "${GITISH}" ]]; then
fi
echo
echo "=== Building at ${GITISH} for ${ARCH} (note: unable to build unpushed changes) ==="
echo "=== Copying src to docker/_src ==="
echo
rsync -a --exclude=/docker/ "${DOCKER_ROOT}/.." "${DOCKER_ROOT}/_src"
echo
echo "=== Building at ${GITISH} for ${ARCH} ==="
echo
# Build -> $TMPTAG
docker build -t "${TMPTAG}" --build-arg "KOPS_GITISH=${GITISH}" --build-arg "KUBECTL_ARCH=${ARCH}" --force-rm=true --rm=true --pull=true --no-cache=true "${DOCKER_ROOT}"
docker build -t "${TMPTAG}" --build-arg "KUBECTL_ARCH=${ARCH}" --force-rm=true --rm=true --pull=true --no-cache=true "${DOCKER_ROOT}"
# Squash -> $TAG
docker create --name="${TMPNAME}" "${TMPTAG}"
docker export "${TMPNAME}" | docker import - "${TAG}"
echo
echo "=== Pushing ${TAG} ==="
echo
if [[ "${PUSH_TAG}" == "yes" ]]; then
echo
echo "=== Pushing ${TAG} ==="
echo
gcloud docker push "${TAG}"
gcloud docker push "${TAG}"
fi
if [[ -n "${LINK}" ]]; then
echo
@ -48,15 +57,20 @@ if [[ -n "${LINK}" ]]; then
echo
docker tag "${TAG}" "${SYMBOLIC_TAG}"
gcloud docker push "${SYMBOLIC_TAG}"
echo
echo "=== Pushed ${SYMBOLIC_TAG} ==="
echo
fi
echo
echo "=== Cleaning up ==="
echo
docker rm "${TMPNAME}"
docker rmi -f "${TAG}" "${TMPTAG}"
docker rm "${TMPNAME}" || true
docker rmi -f "${TMPTAG}" || true
if [[ -n "${LINK}" ]]; then
docker rmi -f "${SYMBOLIC_TAG}"
docker rmi -f "${SYMBOLIC_TAG}" || true
fi
if [[ "${PUSH_TAG}" == "yes" ]]; then
docker rmi -f "${TAG}" || true
else
echo
echo "=== BUILD_PUSH not set, ${TAG} not removed ==="
echo
fi