Merge pull request #2092 from jbeda/1729-hack-build
Rationalize `build` and `hack` directories
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -37,4 +37,4 @@ network_closure.sh
|
|||||||
/third_party/pkg
|
/third_party/pkg
|
||||||
|
|
||||||
# also ignore etcd installed by hack/install-etcd.sh
|
# also ignore etcd installed by hack/install-etcd.sh
|
||||||
/third_party/etcd
|
/third_party/etcd*
|
||||||
|
@@ -6,17 +6,17 @@ go:
|
|||||||
|
|
||||||
install:
|
install:
|
||||||
- go get code.google.com/p/go.tools/cmd/cover
|
- go get code.google.com/p/go.tools/cmd/cover
|
||||||
- ./hack/install-etcd.sh
|
- ./hack/travis/install-etcd.sh
|
||||||
- ./hack/verify-gofmt.sh
|
- ./hack/verify-gofmt.sh
|
||||||
- ./hack/verify-boilerplate.sh
|
- ./hack/verify-boilerplate.sh
|
||||||
- ./hack/install-std-race.sh
|
- ./hack/travis/install-std-race.sh
|
||||||
- ./hack/build-go.sh
|
- ./hack/build-go.sh
|
||||||
- go get ./contrib/podex
|
- go get ./contrib/podex
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- KUBE_TIMEOUT='-timeout 60s' ./hack/test-go.sh
|
- KUBE_TIMEOUT='-timeout 60s' ./hack/test-go.sh
|
||||||
- PATH=$HOME/gopath/bin:./third_party/etcd/bin:$PATH ./hack/test-cmd.sh
|
- PATH=$HOME/gopath/bin:./third_party/etcd:$PATH ./hack/test-cmd.sh
|
||||||
- PATH=$HOME/gopath/bin:./third_party/etcd/bin:$PATH ./hack/test-integration.sh
|
- PATH=$HOME/gopath/bin:./third_party/etcd:$PATH ./hack/test-integration.sh
|
||||||
- ./hack/benchmark-go.sh
|
- ./hack/benchmark-go.sh
|
||||||
|
|
||||||
notifications:
|
notifications:
|
||||||
|
11
Makefile
11
Makefile
@@ -9,7 +9,8 @@
|
|||||||
OUT_DIR = _output
|
OUT_DIR = _output
|
||||||
GODEPS_PKG_DIR = Godeps/_workspace/pkg
|
GODEPS_PKG_DIR = Godeps/_workspace/pkg
|
||||||
|
|
||||||
export GOFLAGS
|
KUBE_GOFLAGS = $(GOFLAGS)
|
||||||
|
export KUBE_GOFLAGS
|
||||||
|
|
||||||
# Build code.
|
# Build code.
|
||||||
#
|
#
|
||||||
@@ -49,7 +50,7 @@ check test:
|
|||||||
# make test_integration
|
# make test_integration
|
||||||
test_integration test_integ:
|
test_integration test_integ:
|
||||||
hack/test-integration.sh
|
hack/test-integration.sh
|
||||||
.PHONY: integration
|
.PHONY: test_integration test_integ
|
||||||
|
|
||||||
# Build and run end-to-end tests.
|
# Build and run end-to-end tests.
|
||||||
#
|
#
|
||||||
@@ -94,10 +95,10 @@ release:
|
|||||||
.PHONY: release
|
.PHONY: release
|
||||||
|
|
||||||
# Build a release, but skip tests
|
# Build a release, but skip tests
|
||||||
#
|
#
|
||||||
# Example:
|
# Example:
|
||||||
# make release-skip-tests
|
# make release-skip-tests
|
||||||
release-skip-tests:
|
release-skip-tests quick-release:
|
||||||
KUBE_RELEASE_RUN_TESTS=n build/release.sh
|
KUBE_RELEASE_RUN_TESTS=n build/release.sh
|
||||||
.PHONY: release-skip-tests
|
.PHONY: release-skip-tests quick-release
|
||||||
|
|
||||||
|
@@ -18,12 +18,13 @@ There is also early support for building Docker "run" containers
|
|||||||
|
|
||||||
## Key scripts
|
## Key scripts
|
||||||
|
|
||||||
* `make-server.sh`: This will compile all of the Kubernetes server binaries for linux/amd64
|
* `run.sh`: Run a command in a build docker container. Common invocations:
|
||||||
* `make-client.sh`: This will make all cross-compiled client binaries
|
* `run.sh hack/build-go.sh`: Build just linux binaries in the container. Pass options and packages as necessary.
|
||||||
* `run-tests.sh`: This will run the Kubernetes unit tests
|
* `run.sh hack/build-cross.sh`: Build all binaries for all platforms
|
||||||
* `run-integration.sh`: This will build and run the integration test
|
* `run.sh hack/test-go.sh`: Run all unit tests
|
||||||
* `copy-output.sh`: This will copy the contents of `_output/build` from any remote Docker container to the local `_output/build`. Right now this is only necessary on Mac OS X with `boot2docker`.
|
* `run.sh hack/test-integration.sh`: Run integration test
|
||||||
* `make-clean.sh`: Clean out the contents of `_output/build` and remove any local built container images.
|
* `copy-output.sh`: This will copy the contents of `_output/dockerized/bin` from any remote Docker container to the local `_output/dockerized/bin`. Right now this is only necessary on Mac OS X with `boot2docker` when your git repo isn't under `/Users`.
|
||||||
|
* `make-clean.sh`: Clean out the contents of `_output/dockerized` and remove any local built container images.
|
||||||
* `shell.sh`: Drop into a `bash` shell in a build container with a snapshot of the current repo code.
|
* `shell.sh`: Drop into a `bash` shell in a build container with a snapshot of the current repo code.
|
||||||
* `release.sh`: Build everything, test it, and (optionally) upload the results to a GCS bucket.
|
* `release.sh`: Build everything, test it, and (optionally) upload the results to a GCS bucket.
|
||||||
|
|
||||||
@@ -81,10 +82,10 @@ If the release script is set to upload to GCS, it'll do the following:
|
|||||||
|
|
||||||
These are in no particular order
|
These are in no particular order
|
||||||
|
|
||||||
* [ ] Harmonize with scripts in `hack/`. How much do we support building outside of Docker and these scripts?
|
* [X] Harmonize with scripts in `hack/`. How much do we support building outside of Docker and these scripts?
|
||||||
* [ ] Get a cluster up and running with the Docker images. Perhaps start with a local cluster and move up to a GCE cluster.
|
* [ ] Get a cluster up and running with the Docker images. Perhaps start with a local cluster and move up to a GCE cluster.
|
||||||
* [ ] Implement (#186)[https://github.com/GoogleCloudPlatform/kubernetes/issues/186]. This will make it easier to develop Kubernetes.
|
* [ ] Implement (#186)[https://github.com/GoogleCloudPlatform/kubernetes/issues/186]. This will make it easier to develop Kubernetes.
|
||||||
* [ ] Deprecate/replace most of the stuff in the hack/
|
* [X] Deprecate/replace most of the stuff in the hack/
|
||||||
* [ ] Create an install script that'll let us do a `curl https://[URL] | bash` to get that tarball down and ensure that other dependencies (cloud SDK?) are installed and configured correctly.
|
* [ ] Create an install script that'll let us do a `curl https://[URL] | bash` to get that tarball down and ensure that other dependencies (cloud SDK?) are installed and configured correctly.
|
||||||
* [ ] Support/test Windows as a client.
|
* [ ] Support/test Windows as a client.
|
||||||
* [ ] Finish support for the Dockerized runtime. Issue (#19)[https://github.com/GoogleCloudPlatform/kubernetes/issues/19]. A key issue here is to make this fast/light enough that we can use it for development workflows.
|
* [ ] Finish support for the Dockerized runtime. Issue (#19)[https://github.com/GoogleCloudPlatform/kubernetes/issues/19]. A key issue here is to make this fast/light enough that we can use it for development workflows.
|
||||||
|
@@ -25,6 +25,10 @@ ENV GOARCH amd64
|
|||||||
# Get the code coverage tool and godep
|
# Get the code coverage tool and godep
|
||||||
RUN go get code.google.com/p/go.tools/cmd/cover github.com/tools/godep
|
RUN go get code.google.com/p/go.tools/cmd/cover github.com/tools/godep
|
||||||
|
|
||||||
|
# We use rsync to copy some binaries around. It is faster (0.3s vs. 1.1s) on my
|
||||||
|
# machine vs. `install`
|
||||||
|
RUN apt-get update && apt-get install -y rsync
|
||||||
|
|
||||||
# Download and symlink etcd. We need this for our integration tests.
|
# Download and symlink etcd. We need this for our integration tests.
|
||||||
RUN mkdir -p /usr/local/src/etcd &&\
|
RUN mkdir -p /usr/local/src/etcd &&\
|
||||||
cd /usr/local/src/etcd &&\
|
cd /usr/local/src/etcd &&\
|
||||||
@@ -39,6 +43,10 @@ WORKDIR /go/src/github.com/GoogleCloudPlatform/kubernetes
|
|||||||
|
|
||||||
# Propagate the git tree version into the build image
|
# Propagate the git tree version into the build image
|
||||||
ADD kube-version-defs /kube-version-defs
|
ADD kube-version-defs /kube-version-defs
|
||||||
|
ENV KUBE_GIT_VERSION_FILE /kube-version-defs
|
||||||
|
|
||||||
|
# Make output from the dockerized build go someplace else
|
||||||
|
ENV KUBE_OUTPUT_SUBPATH _output/dockerized
|
||||||
|
|
||||||
# Upload Kubernetes source
|
# Upload Kubernetes source
|
||||||
ADD kube-source.tar.gz /go/src/github.com/GoogleCloudPlatform/kubernetes
|
ADD kube-source.tar.gz /go/src/github.com/GoogleCloudPlatform/kubernetes
|
||||||
|
@@ -1,81 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# This script sets up a go workspace locally and builds all go components.
|
|
||||||
# You can 'source' this file if you want to set up GOPATH in your local shell.
|
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
|
||||||
cd "${KUBE_ROOT}"
|
|
||||||
|
|
||||||
readonly KUBE_TARGET="${KUBE_ROOT}/_output/build"
|
|
||||||
readonly KUBE_GO_PACKAGE=github.com/GoogleCloudPlatform/kubernetes
|
|
||||||
|
|
||||||
server_targets=(
|
|
||||||
cmd/proxy
|
|
||||||
cmd/apiserver
|
|
||||||
cmd/controller-manager
|
|
||||||
cmd/kubelet
|
|
||||||
plugin/cmd/scheduler
|
|
||||||
)
|
|
||||||
|
|
||||||
client_targets=(
|
|
||||||
cmd/kubecfg
|
|
||||||
cmd/kubectl
|
|
||||||
cmd/e2e
|
|
||||||
)
|
|
||||||
|
|
||||||
mkdir -p "${KUBE_TARGET}"
|
|
||||||
|
|
||||||
if [[ ! -f "/kube-build-image" ]]; then
|
|
||||||
echo "WARNING: This script should be run in the kube-build container image!" >&2
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -f "/kube-version-defs" ]]; then
|
|
||||||
source "/kube-version-defs"
|
|
||||||
else
|
|
||||||
echo "WARNING: No version information provided in build image"
|
|
||||||
fi
|
|
||||||
|
|
||||||
function kube::build::make_binary() {
|
|
||||||
local -r gopkg=$1
|
|
||||||
local -r bin=${gopkg##*/}
|
|
||||||
|
|
||||||
echo "+++ Building ${bin} for ${GOOS}/${GOARCH}"
|
|
||||||
pushd "${KUBE_ROOT}" >/dev/null
|
|
||||||
godep go build -ldflags "${KUBE_LD_FLAGS-}" -o "${ARCH_TARGET}/${bin}" "${gopkg}"
|
|
||||||
popd >/dev/null
|
|
||||||
}
|
|
||||||
|
|
||||||
function kube::build::make_binaries() {
|
|
||||||
[[ $# -gt 0 ]] || {
|
|
||||||
echo "!!! Internal error. kube::build::make_binaries called with no targets."
|
|
||||||
}
|
|
||||||
|
|
||||||
local -a targets=("$@")
|
|
||||||
local -a binaries=()
|
|
||||||
local target
|
|
||||||
for target in "${targets[@]}"; do
|
|
||||||
binaries+=("${KUBE_GO_PACKAGE}/${target}")
|
|
||||||
done
|
|
||||||
|
|
||||||
ARCH_TARGET="${KUBE_TARGET}/${GOOS}/${GOARCH}"
|
|
||||||
mkdir -p "${ARCH_TARGET}"
|
|
||||||
|
|
||||||
local b
|
|
||||||
for b in "${binaries[@]}"; do
|
|
||||||
kube::build::make_binary "$b"
|
|
||||||
done
|
|
||||||
}
|
|
@@ -1,39 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
|
||||||
source "${KUBE_ROOT}/build/build-image/common.sh"
|
|
||||||
|
|
||||||
platforms=(linux/amd64 $KUBE_CROSSPLATFORMS)
|
|
||||||
targets=("${client_targets[@]}")
|
|
||||||
|
|
||||||
if [[ $# -gt 0 ]]; then
|
|
||||||
targets=("$@")
|
|
||||||
fi
|
|
||||||
|
|
||||||
for platform in "${platforms[@]}"; do
|
|
||||||
(
|
|
||||||
# Subshell to contain these exports
|
|
||||||
export GOOS=${platform%/*}
|
|
||||||
export GOARCH=${platform##*/}
|
|
||||||
|
|
||||||
kube::build::make_binaries "${targets[@]}"
|
|
||||||
)
|
|
||||||
done
|
|
@@ -1,29 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
|
||||||
source "${KUBE_ROOT}/build/build-image/common.sh"
|
|
||||||
|
|
||||||
targets=("${server_targets[@]}")
|
|
||||||
if [[ $# -gt 0 ]]; then
|
|
||||||
targets=("$@")
|
|
||||||
fi
|
|
||||||
|
|
||||||
kube::build::make_binaries "${targets[@]}"
|
|
140
build/common.sh
140
build/common.sh
@@ -25,7 +25,7 @@ cd "${KUBE_ROOT}"
|
|||||||
# This'll canonicalize the path
|
# This'll canonicalize the path
|
||||||
KUBE_ROOT=$PWD
|
KUBE_ROOT=$PWD
|
||||||
|
|
||||||
source hack/config-go.sh
|
source hack/lib/init.sh
|
||||||
|
|
||||||
# Incoming options
|
# Incoming options
|
||||||
#
|
#
|
||||||
@@ -49,37 +49,38 @@ readonly KUBE_BUILD_IMAGE_REPO=kube-build
|
|||||||
readonly KUBE_BUILD_IMAGE_CROSS_TAG=cross
|
readonly KUBE_BUILD_IMAGE_CROSS_TAG=cross
|
||||||
readonly KUBE_BUILD_IMAGE_CROSS="${KUBE_BUILD_IMAGE_REPO}:${KUBE_BUILD_IMAGE_CROSS_TAG}"
|
readonly KUBE_BUILD_IMAGE_CROSS="${KUBE_BUILD_IMAGE_REPO}:${KUBE_BUILD_IMAGE_CROSS_TAG}"
|
||||||
readonly KUBE_BUILD_GOLANG_VERSION=1.3
|
readonly KUBE_BUILD_GOLANG_VERSION=1.3
|
||||||
|
# KUBE_BUILD_DATA_CONTAINER_NAME=kube-build-data-<hash>
|
||||||
|
|
||||||
readonly KUBE_GO_PACKAGE="github.com/GoogleCloudPlatform/kubernetes"
|
# Here we map the output directories across both the local and remote _output
|
||||||
|
# directories:
|
||||||
# We set up a volume so that we have the same _output directory from one run of
|
|
||||||
# the container to the next.
|
|
||||||
#
|
#
|
||||||
# Note that here "LOCAL" is local to the docker daemon. In the boot2docker case
|
# *_OUTPUT_ROOT - the base of all output in that environment.
|
||||||
# this is still inside the VM. We use the same directory in both cases though.
|
# *_OUTPUT_SUBPATH - location where golang stuff is built/cached. Also
|
||||||
|
# persisted across docker runs with a volume mount.
|
||||||
|
# *_OUTPUT_BINPATH - location where final binaries are placed. If the remote
|
||||||
|
# is really remote, this is the stuff that has to be copied
|
||||||
|
# back.
|
||||||
readonly LOCAL_OUTPUT_ROOT="${KUBE_ROOT}/_output"
|
readonly LOCAL_OUTPUT_ROOT="${KUBE_ROOT}/_output"
|
||||||
readonly LOCAL_OUTPUT_BUILD="${LOCAL_OUTPUT_ROOT}/build"
|
readonly LOCAL_OUTPUT_SUBPATH="${LOCAL_OUTPUT_ROOT}/dockerized"
|
||||||
|
readonly LOCAL_OUTPUT_BINPATH="${LOCAL_OUTPUT_SUBPATH}/bin"
|
||||||
readonly LOCAL_OUTPUT_IMAGE_STAGING="${LOCAL_OUTPUT_ROOT}/images"
|
readonly LOCAL_OUTPUT_IMAGE_STAGING="${LOCAL_OUTPUT_ROOT}/images"
|
||||||
|
|
||||||
readonly REMOTE_OUTPUT_ROOT="/go/src/${KUBE_GO_PACKAGE}/_output"
|
readonly REMOTE_OUTPUT_ROOT="/go/src/${KUBE_GO_PACKAGE}/_output"
|
||||||
readonly REMOTE_OUTPUT_DIR="${REMOTE_OUTPUT_ROOT}/build"
|
readonly REMOTE_OUTPUT_SUBPATH="${REMOTE_OUTPUT_ROOT}/dockerized"
|
||||||
readonly DOCKER_MOUNT_ARGS=(--volume "${LOCAL_OUTPUT_BUILD}:${REMOTE_OUTPUT_DIR}")
|
readonly REMOTE_OUTPUT_BINPATH="${REMOTE_OUTPUT_SUBPATH}/bin"
|
||||||
|
|
||||||
readonly KUBE_CLIENT_BINARIES=(
|
readonly DOCKER_MOUNT_ARGS_BASE=(--volume "${LOCAL_OUTPUT_BINPATH}:${REMOTE_OUTPUT_BINPATH}")
|
||||||
kubecfg
|
# DOCKER_MOUNT_ARGS=("${DOCKER_MOUNT_ARGS_BASE[@]}" --volumes-from "${KUBE_BUILD_DATA_CONTAINER_NAME}")
|
||||||
kubectl
|
|
||||||
|
# We create a Docker data container to cache incremental build artifacts. We
|
||||||
|
# need to cache both the go tree in _output and the go tree under Godeps.
|
||||||
|
readonly REMOTE_OUTPUT_GOPATH="${REMOTE_OUTPUT_SUBPATH}/go"
|
||||||
|
readonly REMOTE_GODEP_GOPATH="/go/src/${KUBE_GO_PACKAGE}/Godeps/_workspace/pkg"
|
||||||
|
readonly DOCKER_DATA_MOUNT_ARGS=(
|
||||||
|
--volume "${REMOTE_OUTPUT_GOPATH}"
|
||||||
|
--volume "${REMOTE_GODEP_GOPATH}"
|
||||||
)
|
)
|
||||||
|
|
||||||
readonly KUBE_SERVER_BINARIES=(
|
|
||||||
apiserver
|
|
||||||
controller-manager
|
|
||||||
kubelet
|
|
||||||
proxy
|
|
||||||
scheduler
|
|
||||||
)
|
|
||||||
|
|
||||||
readonly KUBE_SERVER_PLATFORMS=(
|
|
||||||
linux/amd64
|
|
||||||
)
|
|
||||||
|
|
||||||
readonly KUBE_RUN_IMAGE_BASE="kubernetes"
|
readonly KUBE_RUN_IMAGE_BASE="kubernetes"
|
||||||
readonly KUBE_RUN_IMAGES=(
|
readonly KUBE_RUN_IMAGES=(
|
||||||
@@ -102,26 +103,32 @@ readonly RELEASE_DIR="${LOCAL_OUTPUT_ROOT}/release-tars"
|
|||||||
# up some dynamic constants.
|
# up some dynamic constants.
|
||||||
#
|
#
|
||||||
# Vars set:
|
# Vars set:
|
||||||
|
# KUBE_ROOT_HASH
|
||||||
# KUBE_BUILD_IMAGE_TAG
|
# KUBE_BUILD_IMAGE_TAG
|
||||||
# KUBE_BUILD_IMAGE
|
# KUBE_BUILD_IMAGE
|
||||||
# KUBE_BUILD_CONTAINER_NAME
|
# KUBE_BUILD_CONTAINER_NAME
|
||||||
# KUBE_ROOT_HASH
|
# KUBE_BUILD_DATA_CONTAINER_NAME
|
||||||
|
# DOCKER_MOUNT_ARGS
|
||||||
function kube::build::verify_prereqs() {
|
function kube::build::verify_prereqs() {
|
||||||
if [[ -z "$(which docker)" ]]; then
|
if [[ -z "$(which docker)" ]]; then
|
||||||
echo "Can't find 'docker' in PATH, please fix and retry." >&2
|
echo "Can't find 'docker' in PATH, please fix and retry." >&2
|
||||||
echo "See https://docs.docker.com/installation/#installation for installation instructions." >&2
|
echo "See https://docs.docker.com/installation/#installation for installation instructions." >&2
|
||||||
return 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if kube::build::is_osx; then
|
if kube::build::is_osx; then
|
||||||
if [[ -z "$(which boot2docker)" ]]; then
|
if [[ -z "$(which boot2docker)" ]]; then
|
||||||
echo "It looks like you are running on Mac OS X and boot2docker can't be found." >&2
|
echo "It looks like you are running on Mac OS X and boot2docker can't be found." >&2
|
||||||
echo "See: https://docs.docker.com/installation/mac/" >&2
|
echo "See: https://docs.docker.com/installation/mac/" >&2
|
||||||
return 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if [[ $(boot2docker status) != "running" ]]; then
|
if [[ $(boot2docker status) != "running" ]]; then
|
||||||
echo "boot2docker VM isn't started. Please run 'boot2docker start'" >&2
|
echo "boot2docker VM isn't started. Please run 'boot2docker start'" >&2
|
||||||
return 1
|
exit 1
|
||||||
|
else
|
||||||
|
# Reach over and set the clock. After sleep/resume the clock will skew.
|
||||||
|
echo "+++ Setting boot2docker clock"
|
||||||
|
boot2docker ssh sudo date -u -D "%Y%m%d%H%M.%S" --set "$(date -u +%Y%m%d%H%M.%S)" >/dev/null
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -130,20 +137,23 @@ function kube::build::verify_prereqs() {
|
|||||||
echo "Can't connect to 'docker' daemon. please fix and retry."
|
echo "Can't connect to 'docker' daemon. please fix and retry."
|
||||||
echo
|
echo
|
||||||
echo "Possible causes:"
|
echo "Possible causes:"
|
||||||
echo " - On Mac OS X, boot2docker VM isn't started"
|
echo " - On Mac OS X, boot2docker VM isn't installed or started"
|
||||||
echo " - On Mac OS X, DOCKER_HOST env variable isn't set approriately"
|
echo " - On Mac OS X, docker env variable isn't set approriately. Run:"
|
||||||
|
echo " \$(boot2docker shellinit)"
|
||||||
echo " - On Linux, user isn't in 'docker' group. Add and relogin."
|
echo " - On Linux, user isn't in 'docker' group. Add and relogin."
|
||||||
echo " - Something like 'sudo usermod -a -G docker ${USER-user}'"
|
echo " - Something like 'sudo usermod -a -G docker ${USER-user}'"
|
||||||
echo " - RHEL7 bug and workaround: https://bugzilla.redhat.com/show_bug.cgi?id=1119282#c8"
|
echo " - RHEL7 bug and workaround: https://bugzilla.redhat.com/show_bug.cgi?id=1119282#c8"
|
||||||
echo " - On Linux, Docker daemon hasn't been started or has crashed"
|
echo " - On Linux, Docker daemon hasn't been started or has crashed"
|
||||||
} >&2
|
} >&2
|
||||||
return 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
KUBE_ROOT_HASH=$(kube::build::short_hash "$KUBE_ROOT")
|
KUBE_ROOT_HASH=$(kube::build::short_hash "$KUBE_ROOT")
|
||||||
KUBE_BUILD_IMAGE_TAG="build-${KUBE_ROOT_HASH}"
|
KUBE_BUILD_IMAGE_TAG="build-${KUBE_ROOT_HASH}"
|
||||||
KUBE_BUILD_IMAGE="${KUBE_BUILD_IMAGE_REPO}:${KUBE_BUILD_IMAGE_TAG}"
|
KUBE_BUILD_IMAGE="${KUBE_BUILD_IMAGE_REPO}:${KUBE_BUILD_IMAGE_TAG}"
|
||||||
KUBE_BUILD_CONTAINER_NAME="kube-build-${KUBE_ROOT_HASH}"
|
KUBE_BUILD_CONTAINER_NAME="kube-build-${KUBE_ROOT_HASH}"
|
||||||
|
KUBE_BUILD_DATA_CONTAINER_NAME="kube-build-data-${KUBE_ROOT_HASH}"
|
||||||
|
DOCKER_MOUNT_ARGS=("${DOCKER_MOUNT_ARGS_BASE[@]}" --volumes-from "${KUBE_BUILD_DATA_CONTAINER_NAME}")
|
||||||
}
|
}
|
||||||
|
|
||||||
# ---------------------------------------------------------------------------
|
# ---------------------------------------------------------------------------
|
||||||
@@ -156,19 +166,22 @@ function kube::build::is_osx() {
|
|||||||
function kube::build::clean_output() {
|
function kube::build::clean_output() {
|
||||||
# Clean out the output directory if it exists.
|
# Clean out the output directory if it exists.
|
||||||
if kube::build::build_image_built ; then
|
if kube::build::build_image_built ; then
|
||||||
echo "+++ Cleaning out _output/build via docker build image"
|
echo "+++ Cleaning out _output/dockerized/bin/ via docker build image"
|
||||||
kube::build::run_build_command bash -c "rm -rf '${REMOTE_OUTPUT_DIR}'/*"
|
kube::build::run_build_command bash -c "rm -rf '${REMOTE_OUTPUT_BINPATH}'/*"
|
||||||
else
|
else
|
||||||
echo "!!! Build image not built. Cannot clean via docker build image."
|
echo "!!! Build image not built. Cannot clean via docker build image."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echo "+++ Removing data container"
|
||||||
|
docker rm "${KUBE_BUILD_DATA_CONTAINER_NAME}" >/dev/null 2>&1 || true
|
||||||
|
|
||||||
echo "+++ Cleaning out local _output directory"
|
echo "+++ Cleaning out local _output directory"
|
||||||
rm -rf "${LOCAL_OUTPUT_ROOT}"
|
rm -rf "${LOCAL_OUTPUT_ROOT}"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Make sure the _output directory is created and mountable by docker
|
# Make sure the _output directory is created and mountable by docker
|
||||||
function kube::build::prepare_output() {
|
function kube::build::prepare_output() {
|
||||||
mkdir -p "${LOCAL_OUTPUT_ROOT}"
|
mkdir -p "${LOCAL_OUTPUT_SUBPATH}"
|
||||||
|
|
||||||
# On RHEL/Fedora SELinux is enabled by default and currently breaks docker
|
# On RHEL/Fedora SELinux is enabled by default and currently breaks docker
|
||||||
# volume mounts. We can work around this by explicitly adding a security
|
# volume mounts. We can work around this by explicitly adding a security
|
||||||
@@ -249,13 +262,14 @@ function kube::build::build_image() {
|
|||||||
build
|
build
|
||||||
cmd
|
cmd
|
||||||
examples
|
examples
|
||||||
Godeps/Godeps.json
|
|
||||||
Godeps/_workspace/src
|
Godeps/_workspace/src
|
||||||
|
Godeps/Godeps.json
|
||||||
hack
|
hack
|
||||||
LICENSE
|
LICENSE
|
||||||
pkg
|
pkg
|
||||||
plugin
|
plugin
|
||||||
README.md
|
README.md
|
||||||
|
test
|
||||||
third_party
|
third_party
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -263,9 +277,10 @@ function kube::build::build_image() {
|
|||||||
|
|
||||||
mkdir -p "${build_context_dir}"
|
mkdir -p "${build_context_dir}"
|
||||||
tar czf "${build_context_dir}/kube-source.tar.gz" "${source[@]}"
|
tar czf "${build_context_dir}/kube-source.tar.gz" "${source[@]}"
|
||||||
cat >"${build_context_dir}/kube-version-defs" <<EOF
|
|
||||||
KUBE_LD_FLAGS="$(kube::version_ldflags)"
|
kube::version::get_version_vars
|
||||||
EOF
|
kube::version::save_version_vars "${build_context_dir}/kube-version-defs"
|
||||||
|
|
||||||
cp build/build-image/Dockerfile ${build_context_dir}/Dockerfile
|
cp build/build-image/Dockerfile ${build_context_dir}/Dockerfile
|
||||||
kube::build::docker_build "${KUBE_BUILD_IMAGE}" "${build_context_dir}"
|
kube::build::docker_build "${KUBE_BUILD_IMAGE}" "${build_context_dir}"
|
||||||
}
|
}
|
||||||
@@ -281,7 +296,7 @@ function kube::build::build_image_cross() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Builds the runtime image. Assumes that the appropriate binaries are already
|
# Builds the runtime image. Assumes that the appropriate binaries are already
|
||||||
# built and in _output/build/.
|
# built and in $LOCAL_OUTPUT_BINPATH.
|
||||||
function kube::build::run_image() {
|
function kube::build::run_image() {
|
||||||
[[ ${KUBE_BUILD_RUN_IMAGES} =~ ^[yY]$ ]] || return 0
|
[[ ${KUBE_BUILD_RUN_IMAGES} =~ ^[yY]$ ]] || return 0
|
||||||
|
|
||||||
@@ -290,7 +305,7 @@ function kube::build::run_image() {
|
|||||||
# First build the base image. This one brings in all of the binaries.
|
# First build the base image. This one brings in all of the binaries.
|
||||||
mkdir -p "${build_context_base}"
|
mkdir -p "${build_context_base}"
|
||||||
tar czf "${build_context_base}/kube-bins.tar.gz" \
|
tar czf "${build_context_base}/kube-bins.tar.gz" \
|
||||||
-C "${LOCAL_OUTPUT_ROOT}/build/linux/amd64" \
|
-C "${LOCAL_OUTPUT_BINPATH}/linux/amd64" \
|
||||||
"${KUBE_RUN_IMAGES[@]}"
|
"${KUBE_RUN_IMAGES[@]}"
|
||||||
cp -R build/run-images/base/* "${build_context_base}/"
|
cp -R build/run-images/base/* "${build_context_base}/"
|
||||||
kube::build::docker_build "${KUBE_RUN_IMAGE_BASE}" "${build_context_base}"
|
kube::build::docker_build "${KUBE_RUN_IMAGE_BASE}" "${build_context_base}"
|
||||||
@@ -350,11 +365,26 @@ function kube::build::clean_images() {
|
|||||||
docker rmi $(docker images -q --filter 'dangling=true') 2> /dev/null || true
|
docker rmi $(docker images -q --filter 'dangling=true') 2> /dev/null || true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function kube::build::ensure_data_container() {
|
||||||
|
if ! docker inspect "${KUBE_BUILD_DATA_CONTAINER_NAME}" >/dev/null 2>&1; then
|
||||||
|
echo "+++ Creating data container"
|
||||||
|
local -ra docker_cmd=(
|
||||||
|
docker run
|
||||||
|
"${DOCKER_DATA_MOUNT_ARGS[@]}"
|
||||||
|
--name "${KUBE_BUILD_DATA_CONTAINER_NAME}"
|
||||||
|
"${KUBE_BUILD_IMAGE}"
|
||||||
|
true
|
||||||
|
)
|
||||||
|
"${docker_cmd[@]}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# Run a command in the kube-build image. This assumes that the image has
|
# Run a command in the kube-build image. This assumes that the image has
|
||||||
# already been built. This will sync out all output data from the build.
|
# already been built. This will sync out all output data from the build.
|
||||||
function kube::build::run_build_command() {
|
function kube::build::run_build_command() {
|
||||||
[[ $# != 0 ]] || { echo "Invalid input." >&2; return 4; }
|
[[ $# != 0 ]] || { echo "Invalid input." >&2; return 4; }
|
||||||
|
|
||||||
|
kube::build::ensure_data_container
|
||||||
kube::build::prepare_output
|
kube::build::prepare_output
|
||||||
|
|
||||||
local -a docker_run_opts=(
|
local -a docker_run_opts=(
|
||||||
@@ -389,10 +419,10 @@ function kube::build::run_build_command() {
|
|||||||
# docker) or if it is "local" and we can access the output without going through
|
# docker) or if it is "local" and we can access the output without going through
|
||||||
# docker.
|
# docker.
|
||||||
function kube::build::is_output_remote() {
|
function kube::build::is_output_remote() {
|
||||||
rm -f "${LOCAL_OUTPUT_BUILD}/test_for_remote"
|
rm -f "${LOCAL_OUTPUT_SUBPATH}/test_for_remote"
|
||||||
kube::build::run_build_command touch "${REMOTE_OUTPUT_DIR}/test_for_remote"
|
kube::build::run_build_command touch "${REMOTE_OUTPUT_BINPATH}/test_for_remote"
|
||||||
|
|
||||||
[[ ! -e "${LOCAL_OUTPUT_BUILD}/test_for_remote" ]]
|
[[ ! -e "${LOCAL_OUTPUT_BINPATH}/test_for_remote" ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
# If the Docker server is remote, copy the results back out.
|
# If the Docker server is remote, copy the results back out.
|
||||||
@@ -409,14 +439,14 @@ function kube::build::copy_output() {
|
|||||||
# container pointed at the same volume, tar the output directory and ship
|
# container pointed at the same volume, tar the output directory and ship
|
||||||
# that tar over stdout.
|
# that tar over stdout.
|
||||||
|
|
||||||
echo "+++ Syncing back _output directory from boot2docker VM"
|
echo "+++ Syncing back _output/dockerized/bin directory from remote Docker"
|
||||||
rm -rf "${LOCAL_OUTPUT_BUILD}"
|
rm -rf "${LOCAL_OUTPUT_BINPATH}"
|
||||||
mkdir -p "${LOCAL_OUTPUT_BUILD}"
|
mkdir -p "${LOCAL_OUTPUT_BINPATH}"
|
||||||
|
|
||||||
# The '</dev/null' here makes us run docker in a "non-interactive" mode. Not
|
# The '</dev/null' here makes us run docker in a "non-interactive" mode. Not
|
||||||
# doing this corrupts the output stream.
|
# doing this corrupts the output stream.
|
||||||
kube::build::run_build_command sh -c "tar c -C ${REMOTE_OUTPUT_DIR} . ; sleep 1" </dev/null \
|
kube::build::run_build_command sh -c "tar c -C ${REMOTE_OUTPUT_BINPATH} . ; sleep 1" </dev/null \
|
||||||
| tar xv -C "${LOCAL_OUTPUT_BUILD}"
|
| tar xv -C "${LOCAL_OUTPUT_BINPATH}"
|
||||||
|
|
||||||
# I (jbeda) also tried getting rsync working using 'docker run' as the
|
# I (jbeda) also tried getting rsync working using 'docker run' as the
|
||||||
# 'remote shell'. This mostly worked but there was a hang when
|
# 'remote shell'. This mostly worked but there was a hang when
|
||||||
@@ -424,7 +454,7 @@ function kube::build::copy_output() {
|
|||||||
#
|
#
|
||||||
# local DOCKER="docker run -i --rm --name=${KUBE_BUILD_CONTAINER_NAME} ${DOCKER_MOUNT} ${KUBE_BUILD_IMAGE}"
|
# local DOCKER="docker run -i --rm --name=${KUBE_BUILD_CONTAINER_NAME} ${DOCKER_MOUNT} ${KUBE_BUILD_IMAGE}"
|
||||||
# DOCKER+=" bash -c 'shift ; exec \"\$@\"' --"
|
# DOCKER+=" bash -c 'shift ; exec \"\$@\"' --"
|
||||||
# rsync --blocking-io -av -e "${DOCKER}" foo:${REMOTE_OUTPUT_DIR}/ ${LOCAL_OUTPUT_BUILD}
|
# rsync --blocking-io -av -e "${DOCKER}" foo:${REMOTE_OUTPUT_BINPATH}/ ${LOCAL_OUTPUT_BINPATH}
|
||||||
else
|
else
|
||||||
echo "+++ Output directory is local. No need to copy results out."
|
echo "+++ Output directory is local. No need to copy results out."
|
||||||
fi
|
fi
|
||||||
@@ -448,7 +478,7 @@ function kube::release::package_tarballs() {
|
|||||||
function kube::release::package_client_tarballs() {
|
function kube::release::package_client_tarballs() {
|
||||||
# Find all of the built kubecfg binaries
|
# Find all of the built kubecfg binaries
|
||||||
local platform platforms
|
local platform platforms
|
||||||
platforms=($(cd "${LOCAL_OUTPUT_ROOT}/build" ; echo */*))
|
platforms=($(cd "${LOCAL_OUTPUT_BINPATH}" ; echo */*))
|
||||||
for platform in "${platforms[@]}" ; do
|
for platform in "${platforms[@]}" ; do
|
||||||
local platform_tag=${platform/\//-} # Replace a "/" for a "-"
|
local platform_tag=${platform/\//-} # Replace a "/" for a "-"
|
||||||
echo "+++ Building tarball: client $platform_tag"
|
echo "+++ Building tarball: client $platform_tag"
|
||||||
@@ -458,9 +488,9 @@ function kube::release::package_client_tarballs() {
|
|||||||
mkdir -p "${release_stage}/client/bin"
|
mkdir -p "${release_stage}/client/bin"
|
||||||
|
|
||||||
# This fancy expression will expand to prepend a path
|
# This fancy expression will expand to prepend a path
|
||||||
# (${LOCAL_OUTPUT_ROOT}/build/${platform}/) to every item in the
|
# (${LOCAL_OUTPUT_BINPATH}/${platform}/) to every item in the
|
||||||
# KUBE_CLIENT_BINARIES array.
|
# KUBE_CLIENT_BINARIES array.
|
||||||
cp "${KUBE_CLIENT_BINARIES[@]/#/${LOCAL_OUTPUT_ROOT}/build/${platform}/}" \
|
cp "${KUBE_CLIENT_BINARIES[@]/#/${LOCAL_OUTPUT_BINPATH}/${platform}/}" \
|
||||||
"${release_stage}/client/bin/"
|
"${release_stage}/client/bin/"
|
||||||
|
|
||||||
local package_name="${RELEASE_DIR}/kubernetes-client-${platform_tag}.tar.gz"
|
local package_name="${RELEASE_DIR}/kubernetes-client-${platform_tag}.tar.gz"
|
||||||
@@ -480,9 +510,9 @@ function kube::release::package_server_tarballs() {
|
|||||||
mkdir -p "${release_stage}/server/bin"
|
mkdir -p "${release_stage}/server/bin"
|
||||||
|
|
||||||
# This fancy expression will expand to prepend a path
|
# This fancy expression will expand to prepend a path
|
||||||
# (${LOCAL_OUTPUT_ROOT}/build/${platform}/) to every item in the
|
# (${LOCAL_OUTPUT_BINPATH}/${platform}/) to every item in the
|
||||||
# KUBE_SERVER_BINARIES array.
|
# KUBE_SERVER_BINARIES array.
|
||||||
cp "${KUBE_SERVER_BINARIES[@]/#/${LOCAL_OUTPUT_ROOT}/build/${platform}/}" \
|
cp "${KUBE_SERVER_BINARIES[@]/#/${LOCAL_OUTPUT_BINPATH}/${platform}/}" \
|
||||||
"${release_stage}/server/bin/"
|
"${release_stage}/server/bin/"
|
||||||
|
|
||||||
local package_name="${RELEASE_DIR}/kubernetes-server-${platform_tag}.tar.gz"
|
local package_name="${RELEASE_DIR}/kubernetes-server-${platform_tag}.tar.gz"
|
||||||
@@ -517,7 +547,7 @@ function kube::release::package_full_tarball() {
|
|||||||
rm -rf "${release_stage}"
|
rm -rf "${release_stage}"
|
||||||
mkdir -p "${release_stage}"
|
mkdir -p "${release_stage}"
|
||||||
|
|
||||||
cp -R "${LOCAL_OUTPUT_ROOT}/build" "${release_stage}/platforms"
|
cp -R "${LOCAL_OUTPUT_BINPATH}" "${release_stage}/platforms"
|
||||||
|
|
||||||
# We want everything in /cluster except saltbase. That is only needed on the
|
# We want everything in /cluster except saltbase. That is only needed on the
|
||||||
# server.
|
# server.
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,5 +1,19 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
set -x
|
set -x
|
||||||
|
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,31 +0,0 @@
|
|||||||
#! /bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# Make all of the Kubernetes server binaries.
|
|
||||||
#
|
|
||||||
# This makes the docker build image, builds the binaries and copies them out
|
|
||||||
# of the docker container.
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
|
||||||
source "$KUBE_ROOT/build/common.sh"
|
|
||||||
|
|
||||||
kube::build::verify_prereqs
|
|
||||||
kube::build::build_image
|
|
||||||
kube::build::run_build_command build/build-image/make-server.sh "$@"
|
|
||||||
kube::build::copy_output
|
|
@@ -1,5 +1,19 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
set -x
|
set -x
|
||||||
|
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -29,12 +29,11 @@ KUBE_RELEASE_RUN_TESTS=${KUBE_RELEASE_RUN_TESTS-y}
|
|||||||
|
|
||||||
kube::build::verify_prereqs
|
kube::build::verify_prereqs
|
||||||
kube::build::build_image
|
kube::build::build_image
|
||||||
kube::build::run_build_command build/build-image/make-client.sh
|
kube::build::run_build_command hack/build-cross.sh
|
||||||
kube::build::run_build_command build/build-image/make-server.sh
|
|
||||||
|
|
||||||
if [[ $KUBE_RELEASE_RUN_TESTS =~ ^[yY]$ ]]; then
|
if [[ $KUBE_RELEASE_RUN_TESTS =~ ^[yY]$ ]]; then
|
||||||
kube::build::run_build_command build/build-image/run-tests.sh
|
kube::build::run_build_command hack/test-go.sh
|
||||||
kube::build::run_build_command build/build-image/run-integration.sh
|
kube::build::run_build_command hack/test-integration.sh
|
||||||
fi
|
fi
|
||||||
|
|
||||||
kube::build::copy_output
|
kube::build::copy_output
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
|
@@ -1,28 +0,0 @@
|
|||||||
#! /bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# Run all of the golang unit tests.
|
|
||||||
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
|
||||||
source "$KUBE_ROOT/build/common.sh"
|
|
||||||
|
|
||||||
kube::build::verify_prereqs
|
|
||||||
kube::build::build_image
|
|
||||||
kube::build::run_build_command build/build-image/run-tests.sh "$@"
|
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -14,7 +14,9 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
# Run the integration test.
|
# Run a command in the docker build container. Typically this will be one of
|
||||||
|
# the commands in `hack/`. When running in the build container the user is sure
|
||||||
|
# to have a consistent reproducible build environment.
|
||||||
|
|
||||||
set -o errexit
|
set -o errexit
|
||||||
set -o nounset
|
set -o nounset
|
||||||
@@ -25,5 +27,8 @@ source "$KUBE_ROOT/build/common.sh"
|
|||||||
|
|
||||||
kube::build::verify_prereqs
|
kube::build::verify_prereqs
|
||||||
kube::build::build_image
|
kube::build::build_image
|
||||||
kube::build::run_build_command build/build-image/make-binaries.sh "./cmd/integration"
|
kube::build::run_build_command "$@"
|
||||||
kube::build::run_build_command build/build-image/run-integration.sh
|
|
||||||
|
if [[ ${KUBE_RUN_COPY_OUTPUT:-y} =~ ^[yY]$ ]]; then
|
||||||
|
kube::build::copy_output
|
||||||
|
fi
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -27,4 +27,4 @@ source "$KUBE_ROOT/build/common.sh"
|
|||||||
|
|
||||||
kube::build::verify_prereqs
|
kube::build::verify_prereqs
|
||||||
kube::build::build_image
|
kube::build::build_image
|
||||||
kube::build::run_build_command bash
|
kube::build::run_build_command bash || true
|
||||||
|
@@ -58,17 +58,21 @@ case "$(uname -m)" in
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
kubecfg="${KUBE_ROOT}/_output/build/${host_os}/${host_arch}/kubecfg"
|
# Gather up the list of likely places and use ls to find the latest one.
|
||||||
if [[ ! -x "$kubecfg" ]]; then
|
locations=(
|
||||||
kubecfg="${KUBE_ROOT}/platforms/${host_os}/${host_arch}/kubecfg"
|
"${KUBE_ROOT}/_output/dockerized/bin/${host_os}/${host_arch}/kubecfg"
|
||||||
fi
|
"${KUBE_ROOT}/_output/local/bin/${host_os}/${host_arch}/kubecfg"
|
||||||
|
"${KUBE_ROOT}/platforms/${host_os}/${host_arch}/kubecfg"
|
||||||
|
)
|
||||||
|
kubecfg=$( (ls -t "${locations[@]}" 2>/dev/null || true) | head -1 )
|
||||||
|
|
||||||
if [[ ! -x "$kubecfg" ]]; then
|
if [[ ! -x "$kubecfg" ]]; then
|
||||||
{
|
{
|
||||||
echo "It looks as if you don't have a compiled kubecfg binary."
|
echo "It looks as if you don't have a compiled kubecfg binary."
|
||||||
echo
|
echo
|
||||||
echo "If you are running from a clone of the git repo, please run"
|
echo "If you are running from a clone of the git repo, please run"
|
||||||
echo "'./build/make-client.sh'. Note that this requires having Docker installed."
|
echo "'./build/run.sh hack/build-cross.sh'. Note that this requires having"
|
||||||
|
echo "Docker installed."
|
||||||
echo
|
echo
|
||||||
echo "If you are running from a binary release tarball, something is wrong. "
|
echo "If you are running from a binary release tarball, something is wrong. "
|
||||||
echo "Look at http://kubernetes.io/ for information on how to contact the "
|
echo "Look at http://kubernetes.io/ for information on how to contact the "
|
||||||
|
@@ -58,17 +58,21 @@ case "$(uname -m)" in
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
kubectl="${KUBE_ROOT}/_output/build/${host_os}/${host_arch}/kubectl"
|
# Gather up the list of likely places and use ls to find the latest one.
|
||||||
if [[ ! -x "$kubectl" ]]; then
|
locations=(
|
||||||
kubectl="${KUBE_ROOT}/platforms/${host_os}/${host_arch}/kubectl"
|
"${KUBE_ROOT}/_output/dockerized/bin/${host_os}/${host_arch}/kubectl"
|
||||||
fi
|
"${KUBE_ROOT}/_output/local/bin/${host_os}/${host_arch}/kubectl"
|
||||||
|
"${KUBE_ROOT}/platforms/${host_os}/${host_arch}/kubectl"
|
||||||
|
)
|
||||||
|
kubectl=$( (ls -t "${locations[@]}" 2>/dev/null || true) | head -1 )
|
||||||
|
|
||||||
if [[ ! -x "$kubectl" ]]; then
|
if [[ ! -x "$kubectl" ]]; then
|
||||||
{
|
{
|
||||||
echo "It looks as if you don't have a compiled kubectl binary."
|
echo "It looks as if you don't have a compiled kubectl binary."
|
||||||
echo
|
echo
|
||||||
echo "If you are running from a clone of the git repo, please run"
|
echo "If you are running from a clone of the git repo, please run"
|
||||||
echo "'./build/make-client'. Note that this requires having Docker installed."
|
echo "'./build/run.sh hack/build-cross.sh'. Note that this requires having"
|
||||||
|
echo "Docker installed."
|
||||||
echo
|
echo
|
||||||
echo "If you are running from a binary release tarball, something is wrong. "
|
echo "If you are running from a binary release tarball, something is wrong. "
|
||||||
echo "Look at http://kubernetes.io/ for information on how to contact the "
|
echo "Look at http://kubernetes.io/ for information on how to contact the "
|
||||||
|
@@ -124,7 +124,8 @@ function kube-push {
|
|||||||
|
|
||||||
# Execute prior to running tests to build a release if required for env
|
# Execute prior to running tests to build a release if required for env
|
||||||
function test-build-release {
|
function test-build-release {
|
||||||
echo "Vagrant provider can skip release build"
|
# Make a release
|
||||||
|
"${KUBE_ROOT}/build/release.sh"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Execute prior to running tests to initialize required structure
|
# Execute prior to running tests to initialize required structure
|
||||||
|
@@ -18,4 +18,6 @@ set -o errexit
|
|||||||
set -o nounset
|
set -o nounset
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_COVER=" " KUBE_RACE=" " hack/test-go.sh "" -test.run="^X" -benchtime=1s -bench=. -benchmem
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
|
|
||||||
|
KUBE_COVER=" " KUBE_RACE=" " "${KUBE_ROOT}/hack/test-go.sh" "" -test.run="^X" -benchtime=1s -bench=. -benchmem
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#! /bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -14,19 +14,20 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
# Make all of the client Kubernetes binaries for cross compile targets
|
# This script sets up a go workspace locally and builds all for all appropriate
|
||||||
#
|
# platforms.
|
||||||
# This makes the docker build image, builds the cross binaries and copies them
|
|
||||||
# out of the docker container.
|
|
||||||
|
|
||||||
set -o errexit
|
set -o errexit
|
||||||
set -o nounset
|
set -o nounset
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
source "$KUBE_ROOT/build/common.sh"
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||||||
|
|
||||||
kube::build::verify_prereqs
|
KUBE_BUILD_PLATFORMS=("${KUBE_SERVER_PLATFORMS[@]}")
|
||||||
kube::build::build_image
|
kube::golang::build_binaries "${KUBE_SERVER_TARGETS[@]}"
|
||||||
kube::build::run_build_command build/build-image/make-client.sh "$@"
|
|
||||||
kube::build::copy_output
|
KUBE_BUILD_PLATFORMS=("${KUBE_CLIENT_PLATFORMS[@]}")
|
||||||
|
kube::golang::build_binaries "${KUBE_CLIENT_TARGETS[@]}" "${KUBE_TEST_TARGETS[@]}"
|
||||||
|
|
||||||
|
kube::golang::place_bins
|
@@ -21,42 +21,7 @@ set -o nounset
|
|||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||||||
|
|
||||||
# Set the environment variables required by the build.
|
kube::golang::build_binaries "$@"
|
||||||
source "${KUBE_ROOT}/hack/config-go.sh"
|
kube::golang::place_bins
|
||||||
|
|
||||||
# Go to the top of the tree.
|
|
||||||
cd "${KUBE_ROOT}"
|
|
||||||
|
|
||||||
# Check for `go` binary and set ${GOPATH}.
|
|
||||||
kube::setup_go_environment
|
|
||||||
|
|
||||||
# Fetch the version.
|
|
||||||
version_ldflags=$(kube::version_ldflags)
|
|
||||||
|
|
||||||
# Use eval to preserve embedded quoted strings.
|
|
||||||
eval "goflags=(${GOFLAGS:-})"
|
|
||||||
|
|
||||||
targets=()
|
|
||||||
for arg; do
|
|
||||||
if [[ "${arg}" == -* ]]; then
|
|
||||||
# Assume arguments starting with a dash are flags to pass to go.
|
|
||||||
goflags+=("${arg}")
|
|
||||||
else
|
|
||||||
targets+=("${arg}")
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
if [[ ${#targets[@]} -eq 0 ]]; then
|
|
||||||
targets=($(kube::default_build_targets))
|
|
||||||
fi
|
|
||||||
|
|
||||||
binaries=($(kube::binaries_from_targets "${targets[@]}"))
|
|
||||||
|
|
||||||
echo "Building local go components"
|
|
||||||
# Note that the flags to 'go build' are duplicated in the dockerized build setup
|
|
||||||
# (build/build-image/common.sh). If we add more command line options to our
|
|
||||||
# standard build we'll want to duplicate them there. This needs to be fixed
|
|
||||||
go install "${goflags[@]:+${goflags[@]}}" \
|
|
||||||
-ldflags "${version_ldflags}" \
|
|
||||||
"${binaries[@]}"
|
|
||||||
|
@@ -1,212 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# This script sets up a go workspace locally and builds all go components.
|
|
||||||
# You can 'source' this file if you want to set up GOPATH in your local shell.
|
|
||||||
|
|
||||||
|
|
||||||
# --- Environment Variables used as inputs by config-go.sh ---
|
|
||||||
# Function: kube::version_ldflags()
|
|
||||||
# These variables are only needed if you are not building from a clone of the
|
|
||||||
# full kubernetes repository.
|
|
||||||
# KUBE_GIT_COMMIT - Used to set the git commit id corresponding to this
|
|
||||||
# source code.
|
|
||||||
# KUBE_GIT_TREE_STATE - "clean" indicates no changes since the git commit id
|
|
||||||
# "dirty" indicates source code changes after the git
|
|
||||||
# commit id
|
|
||||||
# KUBE_GIT_VERSION - "vX.Y" used to indicate the last release version.
|
|
||||||
#
|
|
||||||
# Function: kube::setup_go_environment
|
|
||||||
# KUBE_EXTRA_GOPATH - Value will be appended to the GOPATH after this project
|
|
||||||
# but before the Godeps.
|
|
||||||
# KUBE_NO_GODEPS - If set to any value the Godeps will not be included in
|
|
||||||
# the final GOPATH.
|
|
||||||
|
|
||||||
# --- Environment Variables set by sourcing config-go.sh ---
|
|
||||||
# KUBE_ROOT - Path to the top of the build tree.
|
|
||||||
# KUBE_TARGET - Path where output Go files are saved.
|
|
||||||
# KUBE_GO_PACKAGE - Full name of the Kubernetes Go package.
|
|
||||||
|
|
||||||
# --- Environment Variables set by running functions ---
|
|
||||||
# Function: kube::setup_go_environment
|
|
||||||
# GOPATH - Will be set to include this project, anything you have you set in
|
|
||||||
# in ${KUBE_EXTRA_GOPATH}, and the Godeps if ${KUBE_NO_GODEPS} is
|
|
||||||
# unset.
|
|
||||||
|
|
||||||
|
|
||||||
# --- Helper Functions ---
|
|
||||||
|
|
||||||
# Function kube::version_ldflags() prints the value that needs to be passed to
|
|
||||||
# the -ldflags parameter of go build in order to set the Kubernetes based on the
|
|
||||||
# git tree status.
|
|
||||||
kube::version_ldflags() {
|
|
||||||
(
|
|
||||||
# Run this in a subshell to prevent settings/variables from leaking.
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
unset CDPATH
|
|
||||||
|
|
||||||
cd "${KUBE_ROOT}"
|
|
||||||
|
|
||||||
declare -a ldflags=()
|
|
||||||
if [[ -n ${KUBE_GIT_COMMIT-} ]] || KUBE_GIT_COMMIT=$(git rev-parse "HEAD^{commit}" 2>/dev/null); then
|
|
||||||
ldflags+=(-X "${KUBE_GO_PACKAGE}/pkg/version.gitCommit" "${KUBE_GIT_COMMIT}")
|
|
||||||
|
|
||||||
if [[ -z ${KUBE_GIT_TREE_STATE-} ]]; then
|
|
||||||
# Check if the tree is dirty. default to dirty
|
|
||||||
if git_status=$(git status --porcelain 2>/dev/null) && [[ -z ${git_status} ]]; then
|
|
||||||
KUBE_GIT_TREE_STATE="clean"
|
|
||||||
else
|
|
||||||
KUBE_GIT_TREE_STATE="dirty"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
ldflags+=(-X "${KUBE_GO_PACKAGE}/pkg/version.gitTreeState" "${KUBE_GIT_TREE_STATE}")
|
|
||||||
|
|
||||||
# Use git describe to find the version based on annotated tags.
|
|
||||||
if [[ -n ${KUBE_GIT_VERSION-} ]] || KUBE_GIT_VERSION=$(git describe --tag --abbrev=14 "${KUBE_GIT_COMMIT}^{commit}" 2>/dev/null); then
|
|
||||||
if [[ "${KUBE_GIT_TREE_STATE}" == "dirty" ]]; then
|
|
||||||
# git describe --dirty only considers changes to existing files, but
|
|
||||||
# that is problematic since new untracked .go files affect the build,
|
|
||||||
# so use our idea of "dirty" from git status instead.
|
|
||||||
KUBE_GIT_VERSION+="-dirty"
|
|
||||||
fi
|
|
||||||
ldflags+=(-X "${KUBE_GO_PACKAGE}/pkg/version.gitVersion" "${KUBE_GIT_VERSION}")
|
|
||||||
|
|
||||||
# Try to match the "git describe" output to a regex to try to extract
|
|
||||||
# the "major" and "minor" versions and whether this is the exact tagged
|
|
||||||
# version or whether the tree is between two tagged versions.
|
|
||||||
if [[ "${KUBE_GIT_VERSION}" =~ ^v([0-9]+)\.([0-9]+)([.-].*)?$ ]]; then
|
|
||||||
git_major=${BASH_REMATCH[1]}
|
|
||||||
git_minor=${BASH_REMATCH[2]}
|
|
||||||
if [[ -n "${BASH_REMATCH[3]}" ]]; then
|
|
||||||
git_minor+="+"
|
|
||||||
fi
|
|
||||||
ldflags+=(
|
|
||||||
-X "${KUBE_GO_PACKAGE}/pkg/version.gitMajor" "${git_major}"
|
|
||||||
-X "${KUBE_GO_PACKAGE}/pkg/version.gitMinor" "${git_minor}"
|
|
||||||
)
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# The -ldflags parameter takes a single string, so join the output.
|
|
||||||
echo "${ldflags[*]-}"
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
# kube::setup_go_environment will check that the `go` commands is available in
|
|
||||||
# ${PATH}. If not running on Travis, it will also check that the Go version is
|
|
||||||
# good enough for the Kubernetes build.
|
|
||||||
#
|
|
||||||
# Also set ${GOPATH} and environment variables needed by Go.
|
|
||||||
kube::setup_go_environment() {
|
|
||||||
if [[ -z "$(which go)" ]]; then
|
|
||||||
echo "Can't find 'go' in PATH, please fix and retry." >&2
|
|
||||||
echo "See http://golang.org/doc/install for installation instructions." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Travis continuous build uses a head go release that doesn't report
|
|
||||||
# a version number, so we skip this check on Travis. Its unnecessary
|
|
||||||
# there anyway.
|
|
||||||
if [[ "${TRAVIS:-}" != "true" ]]; then
|
|
||||||
local go_version
|
|
||||||
go_version=($(go version))
|
|
||||||
if [[ "${go_version[2]}" < "go1.2" ]]; then
|
|
||||||
echo "Detected go version: ${go_version[*]}." >&2
|
|
||||||
echo "Kubernetes requires go version 1.2 or greater." >&2
|
|
||||||
echo "Please install Go version 1.2 or later" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
GOPATH=${KUBE_TARGET}
|
|
||||||
# Append KUBE_EXTRA_GOPATH to the GOPATH if it is defined.
|
|
||||||
if [[ -n ${KUBE_EXTRA_GOPATH:-} ]]; then
|
|
||||||
GOPATH=${GOPATH}:${KUBE_EXTRA_GOPATH}
|
|
||||||
fi
|
|
||||||
# Append the tree maintained by `godep` to the GOPATH unless KUBE_NO_GODEPS
|
|
||||||
# is defined.
|
|
||||||
if [[ -z ${KUBE_NO_GODEPS:-} ]]; then
|
|
||||||
GOPATH="${GOPATH}:${KUBE_ROOT}/Godeps/_workspace"
|
|
||||||
fi
|
|
||||||
export GOPATH
|
|
||||||
|
|
||||||
# Unset GOBIN in case it already exists in the current session.
|
|
||||||
unset GOBIN
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
# kube::default_build_targets return list of all build targets
|
|
||||||
kube::default_build_targets() {
|
|
||||||
echo "cmd/proxy"
|
|
||||||
echo "cmd/apiserver"
|
|
||||||
echo "cmd/controller-manager"
|
|
||||||
echo "cmd/e2e"
|
|
||||||
echo "cmd/kubelet"
|
|
||||||
echo "cmd/kubecfg"
|
|
||||||
echo "cmd/kubectl"
|
|
||||||
echo "plugin/cmd/scheduler"
|
|
||||||
}
|
|
||||||
|
|
||||||
# kube::binaries_from_targets take a list of build targets and return the
|
|
||||||
# full go package to be built
|
|
||||||
kube::binaries_from_targets() {
|
|
||||||
local target
|
|
||||||
for target; do
|
|
||||||
echo "${KUBE_GO_PACKAGE}/${target}"
|
|
||||||
done
|
|
||||||
}
|
|
||||||
# --- Environment Variables ---
|
|
||||||
|
|
||||||
# Make ${KUBE_ROOT} an absolute path.
|
|
||||||
KUBE_ROOT=$(
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
unset CDPATH
|
|
||||||
kube_root=$(dirname "${BASH_SOURCE}")/..
|
|
||||||
cd "${kube_root}"
|
|
||||||
pwd
|
|
||||||
)
|
|
||||||
export KUBE_ROOT
|
|
||||||
|
|
||||||
KUBE_TARGET="${KUBE_ROOT}/_output/go"
|
|
||||||
mkdir -p "${KUBE_TARGET}"
|
|
||||||
export KUBE_TARGET
|
|
||||||
|
|
||||||
KUBE_GO_PACKAGE=github.com/GoogleCloudPlatform/kubernetes
|
|
||||||
export KUBE_GO_PACKAGE
|
|
||||||
|
|
||||||
(
|
|
||||||
# Create symlink named ${KUBE_GO_PACKAGE} under _output/go/src.
|
|
||||||
# So that Go knows how to import Kubernetes sources by full path.
|
|
||||||
# Use a subshell to avoid leaking these variables.
|
|
||||||
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
go_pkg_dir="${KUBE_TARGET}/src/${KUBE_GO_PACKAGE}"
|
|
||||||
go_pkg_basedir=$(dirname "${go_pkg_dir}")
|
|
||||||
mkdir -p "${go_pkg_basedir}"
|
|
||||||
rm -f "${go_pkg_dir}"
|
|
||||||
# TODO: This symlink should be relative.
|
|
||||||
ln -s "${KUBE_ROOT}" "${go_pkg_dir}"
|
|
||||||
)
|
|
||||||
|
|
@@ -19,4 +19,49 @@ source "${KUBE_ROOT}/cluster/kube-env.sh"
|
|||||||
source "${KUBE_ROOT}/cluster/$KUBERNETES_PROVIDER/util.sh"
|
source "${KUBE_ROOT}/cluster/$KUBERNETES_PROVIDER/util.sh"
|
||||||
|
|
||||||
detect-master > /dev/null
|
detect-master > /dev/null
|
||||||
${KUBE_ROOT}/_output/go/bin/e2e -host="https://${KUBE_MASTER_IP-}"
|
|
||||||
|
# Detect the OS name/arch so that we can find our binary
|
||||||
|
case "$(uname -s)" in
|
||||||
|
Darwin)
|
||||||
|
host_os=darwin
|
||||||
|
;;
|
||||||
|
Linux)
|
||||||
|
host_os=linux
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unsupported host OS. Must be Linux or Mac OS X." >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$(uname -m)" in
|
||||||
|
x86_64*)
|
||||||
|
host_arch=amd64
|
||||||
|
;;
|
||||||
|
i?86_64*)
|
||||||
|
host_arch=amd64
|
||||||
|
;;
|
||||||
|
amd64*)
|
||||||
|
host_arch=amd64
|
||||||
|
;;
|
||||||
|
arm*)
|
||||||
|
host_arch=arm
|
||||||
|
;;
|
||||||
|
i?86*)
|
||||||
|
host_arch=x86
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unsupported host arch. Must be x86_64, 386 or arm." >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Gather up the list of likely places and use ls to find the latest one.
|
||||||
|
locations=(
|
||||||
|
"${KUBE_ROOT}/_output/dockerized/bin/${host_os}/${host_arch}/e2e"
|
||||||
|
"${KUBE_ROOT}/_output/local/bin/${host_os}/${host_arch}/e2e"
|
||||||
|
)
|
||||||
|
e2e=$( (ls -t "${locations[@]}" 2>/dev/null || true) | head -1 )
|
||||||
|
|
||||||
|
|
||||||
|
"${e2e}" -host="https://${KUBE_MASTER_IP-}"
|
||||||
|
@@ -72,9 +72,6 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if *build {
|
if *build {
|
||||||
if !run("build-local", "hack/build-go.sh") {
|
|
||||||
log.Fatal("Error building. Aborting.")
|
|
||||||
}
|
|
||||||
if !runBash("build-release", `test-build-release`) {
|
if !runBash("build-release", `test-build-release`) {
|
||||||
log.Fatal("Error building. Aborting.")
|
log.Fatal("Error building. Aborting.")
|
||||||
}
|
}
|
||||||
|
44
hack/lib/etcd.sh
Normal file
44
hack/lib/etcd.sh
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
# A set of helpers for starting/running etcd for tests
|
||||||
|
|
||||||
|
kube::etcd::start() {
|
||||||
|
local host=${ETCD_HOST:-127.0.0.1}
|
||||||
|
local port=${ETCD_PORT:-4001}
|
||||||
|
|
||||||
|
which etcd >/dev/null || {
|
||||||
|
kube::log::usage "etcd must be in your PATH"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
if pgrep etcd >/dev/null 2>&1; then
|
||||||
|
kube::log::usage "etcd appears to already be running on this machine. Please kill and restart the test."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Start etcd
|
||||||
|
ETCD_DIR=$(mktemp -d -t test-etcd.XXXXXX)
|
||||||
|
etcd -name test -data-dir ${ETCD_DIR} -addr ${host}:${port} >/dev/null 2>/dev/null &
|
||||||
|
ETCD_PID=$!
|
||||||
|
|
||||||
|
kube::util::wait_for_url "http://${host}:${port}/v2/keys/" "etcd: "
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::etcd::cleanup() {
|
||||||
|
kill "${ETCD_PID-}" >/dev/null 2>&1 || :
|
||||||
|
rm -rf "${ETCD_DIR-}"
|
||||||
|
}
|
272
hack/lib/golang.sh
Normal file
272
hack/lib/golang.sh
Normal file
@@ -0,0 +1,272 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
# The golang package that we are building.
|
||||||
|
readonly KUBE_GO_PACKAGE=github.com/GoogleCloudPlatform/kubernetes
|
||||||
|
readonly KUBE_GOPATH="${KUBE_OUTPUT}/go"
|
||||||
|
|
||||||
|
# The set of server targets that we are only building for Linux
|
||||||
|
readonly KUBE_SERVER_TARGETS=(
|
||||||
|
cmd/proxy
|
||||||
|
cmd/apiserver
|
||||||
|
cmd/controller-manager
|
||||||
|
cmd/kubelet
|
||||||
|
plugin/cmd/scheduler
|
||||||
|
)
|
||||||
|
readonly KUBE_SERVER_BINARIES=("${KUBE_SERVER_TARGETS[@]##*/}")
|
||||||
|
|
||||||
|
# The server platform we are building on.
|
||||||
|
readonly KUBE_SERVER_PLATFORMS=(
|
||||||
|
linux/amd64
|
||||||
|
)
|
||||||
|
|
||||||
|
# The set of client targets that we are building for all platforms
|
||||||
|
readonly KUBE_CLIENT_TARGETS=(
|
||||||
|
cmd/kubecfg
|
||||||
|
cmd/kubectl
|
||||||
|
)
|
||||||
|
readonly KUBE_CLIENT_BINARIES=("${KUBE_CLIENT_TARGETS[@]##*/}")
|
||||||
|
|
||||||
|
# The set of test targets that we are building for all platforms
|
||||||
|
readonly KUBE_TEST_TARGETS=(
|
||||||
|
cmd/e2e
|
||||||
|
cmd/integration
|
||||||
|
)
|
||||||
|
readonly KUBE_TEST_BINARIES=("${KUBE_TEST_TARGETS[@]##*/}")
|
||||||
|
|
||||||
|
# If we update this we need to also update the set of golang compilers we build
|
||||||
|
# in 'build/build-image/Dockerfile'
|
||||||
|
readonly KUBE_CLIENT_PLATFORMS=(
|
||||||
|
linux/amd64
|
||||||
|
linux/386
|
||||||
|
linux/arm
|
||||||
|
darwin/amd64
|
||||||
|
darwin/386
|
||||||
|
)
|
||||||
|
|
||||||
|
readonly KUBE_ALL_TARGETS=(
|
||||||
|
"${KUBE_SERVER_TARGETS[@]}"
|
||||||
|
"${KUBE_CLIENT_TARGETS[@]}"
|
||||||
|
"${KUBE_TEST_TARGETS[@]}"
|
||||||
|
)
|
||||||
|
readonly KUBE_ALL_BINARIES=("${KUBE_ALL_TARGETS[@]##*/}")
|
||||||
|
|
||||||
|
|
||||||
|
# kube::binaries_from_targets take a list of build targets and return the
|
||||||
|
# full go package to be built
|
||||||
|
kube::golang::binaries_from_targets() {
|
||||||
|
local target
|
||||||
|
for target; do
|
||||||
|
echo "${KUBE_GO_PACKAGE}/${target}"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# Asks golang what it thinks the host platform is. The go tool chain does some
|
||||||
|
# slightly different things when the target platform matches the host platform.
|
||||||
|
kube::golang::host_platform() {
|
||||||
|
echo "$(go env GOHOSTOS)/$(go env GOHOSTARCH)"
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::golang::current_platform() {
|
||||||
|
local os="${GOOS-}"
|
||||||
|
if [[ -z $os ]]; then
|
||||||
|
os=$(go env GOHOSTOS)
|
||||||
|
fi
|
||||||
|
|
||||||
|
local arch="${GOARCH-}"
|
||||||
|
if [[ -z $arch ]]; then
|
||||||
|
arch=$(go env GOHOSTARCH)
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$os/$arch"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Takes the the platform name ($1) and sets the appropriate golang env variables
|
||||||
|
# for that platform.
|
||||||
|
kube::golang::set_platform_envs() {
|
||||||
|
[[ -n ${1-} ]] || {
|
||||||
|
kube::log::error_exit "!!! Internal error. No platform set in kube::golang::set_platform_envs"
|
||||||
|
}
|
||||||
|
|
||||||
|
export GOOS=${platform%/*}
|
||||||
|
export GOARCH=${platform##*/}
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::golang::unset_platform_envs() {
|
||||||
|
unset GOOS
|
||||||
|
unset GOARCH
|
||||||
|
}
|
||||||
|
|
||||||
|
# Create the GOPATH tree under $KUBE_OUTPUT
|
||||||
|
kube::golang::create_gopath_tree() {
|
||||||
|
local go_pkg_dir="${KUBE_GOPATH}/src/${KUBE_GO_PACKAGE}"
|
||||||
|
local go_pkg_basedir=$(dirname "${go_pkg_dir}")
|
||||||
|
|
||||||
|
mkdir -p "${go_pkg_basedir}"
|
||||||
|
rm -f "${go_pkg_dir}"
|
||||||
|
|
||||||
|
# TODO: This symlink should be relative.
|
||||||
|
ln -s "${KUBE_ROOT}" "${go_pkg_dir}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# kube::golang::setup_env will check that the `go` commands is available in
|
||||||
|
# ${PATH}. If not running on Travis, it will also check that the Go version is
|
||||||
|
# good enough for the Kubernetes build.
|
||||||
|
#
|
||||||
|
# Input Vars:
|
||||||
|
# KUBE_EXTRA_GOPATH - If set, this is included in created GOPATH
|
||||||
|
# KUBE_NO_GODEPS - If set, we don't add 'Godeps/_workspace' to GOPATH
|
||||||
|
#
|
||||||
|
# Output Vars:
|
||||||
|
# export GOPATH - A modified GOPATH to our created tree along with extra
|
||||||
|
# stuff.
|
||||||
|
# export GOBIN - This is actively unset if already set as we want binaries
|
||||||
|
# placed in a predictable place.
|
||||||
|
kube::golang::setup_env() {
|
||||||
|
kube::golang::create_gopath_tree
|
||||||
|
|
||||||
|
if [[ -z "$(which go)" ]]; then
|
||||||
|
kube::log::usage_from_stdin <<EOF
|
||||||
|
|
||||||
|
Can't find 'go' in PATH, please fix and retry.
|
||||||
|
See http://golang.org/doc/install for installation instructions.
|
||||||
|
|
||||||
|
EOF
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Travis continuous build uses a head go release that doesn't report
|
||||||
|
# a version number, so we skip this check on Travis. It's unnecessary
|
||||||
|
# there anyway.
|
||||||
|
if [[ "${TRAVIS:-}" != "true" ]]; then
|
||||||
|
local go_version
|
||||||
|
go_version=($(go version))
|
||||||
|
if [[ "${go_version[2]}" < "go1.2" ]]; then
|
||||||
|
kube::log::usage_from_stdin <<EOF
|
||||||
|
|
||||||
|
Detected go version: ${go_version[*]}.
|
||||||
|
Kubernetes requires go version 1.2 or greater.
|
||||||
|
Please install Go version 1.2 or later.
|
||||||
|
|
||||||
|
EOF
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
GOPATH=${KUBE_GOPATH}
|
||||||
|
|
||||||
|
# Append KUBE_EXTRA_GOPATH to the GOPATH if it is defined.
|
||||||
|
if [[ -n ${KUBE_EXTRA_GOPATH:-} ]]; then
|
||||||
|
GOPATH="${GOPATH}:${KUBE_EXTRA_GOPATH}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Append the tree maintained by `godep` to the GOPATH unless KUBE_NO_GODEPS
|
||||||
|
# is defined.
|
||||||
|
if [[ -z ${KUBE_NO_GODEPS:-} ]]; then
|
||||||
|
GOPATH="${GOPATH}:${KUBE_ROOT}/Godeps/_workspace"
|
||||||
|
fi
|
||||||
|
export GOPATH
|
||||||
|
|
||||||
|
# Unset GOBIN in case it already exists in the current session.
|
||||||
|
unset GOBIN
|
||||||
|
}
|
||||||
|
|
||||||
|
# This will take binaries from $GOPATH/bin and copy them to the appropriate
|
||||||
|
# place in ${KUBE_OUTPUT_BINDIR}
|
||||||
|
#
|
||||||
|
# Ideally this wouldn't be necessary and we could just set GOBIN to
|
||||||
|
# KUBE_OUTPUT_BINDIR but that won't work in the face of cross compilation. 'go
|
||||||
|
# install' will place binaries that match the host platform directly in $GOBIN
|
||||||
|
# while placing cross compiled binaries into `platform_arch` subdirs. This
|
||||||
|
# complicates pretty much everything else we do around packaging and such.
|
||||||
|
kube::golang::place_bins() {
|
||||||
|
local host_platform
|
||||||
|
host_platform=$(kube::golang::host_platform)
|
||||||
|
|
||||||
|
kube::log::status "Placing binaries"
|
||||||
|
|
||||||
|
local platform
|
||||||
|
for platform in "${KUBE_CLIENT_PLATFORMS[@]}"; do
|
||||||
|
# The substitution on platform_src below will replace all slashes with
|
||||||
|
# underscores. It'll transform darwin/amd64 -> darwin_amd64.
|
||||||
|
local platform_src="/${platform//\//_}"
|
||||||
|
if [[ $platform == $host_platform ]]; then
|
||||||
|
platform_src=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
local full_binpath_src="${KUBE_GOPATH}/bin${platform_src}"
|
||||||
|
if [[ -d "${full_binpath_src}" ]]; then
|
||||||
|
mkdir -p "${KUBE_OUTPUT_BINPATH}/${platform}"
|
||||||
|
find "${full_binpath_src}" -maxdepth 1 -type f -exec \
|
||||||
|
rsync -pt {} "${KUBE_OUTPUT_BINPATH}/${platform}" \;
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# Build binaries targets specified
|
||||||
|
#
|
||||||
|
# Input:
|
||||||
|
# $@ - targets and go flags. If no targets are set then all binaries targets
|
||||||
|
# are built.
|
||||||
|
# KUBE_BUILD_PLATFORMS - Incoming variable of targets to build for. If unset
|
||||||
|
# then just the host architecture is built.
|
||||||
|
kube::golang::build_binaries() {
|
||||||
|
# Create a sub-shell so that we don't pollute the outer environment
|
||||||
|
(
|
||||||
|
# Check for `go` binary and set ${GOPATH}.
|
||||||
|
kube::golang::setup_env
|
||||||
|
|
||||||
|
# Fetch the version.
|
||||||
|
local version_ldflags
|
||||||
|
version_ldflags=$(kube::version::ldflags)
|
||||||
|
|
||||||
|
# Use eval to preserve embedded quoted strings.
|
||||||
|
local goflags
|
||||||
|
eval "goflags=(${KUBE_GOFLAGS:-})"
|
||||||
|
|
||||||
|
local -a targets=()
|
||||||
|
local arg
|
||||||
|
for arg; do
|
||||||
|
if [[ "${arg}" == -* ]]; then
|
||||||
|
# Assume arguments starting with a dash are flags to pass to go.
|
||||||
|
goflags+=("${arg}")
|
||||||
|
else
|
||||||
|
targets+=("${arg}")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [[ ${#targets[@]} -eq 0 ]]; then
|
||||||
|
targets=("${KUBE_ALL_TARGETS[@]}")
|
||||||
|
fi
|
||||||
|
|
||||||
|
local -a platforms=("${KUBE_BUILD_PLATFORMS[@]:+${KUBE_BUILD_PLATFORMS[@]}}")
|
||||||
|
if [[ ${#platforms[@]} -eq 0 ]]; then
|
||||||
|
platforms=("$(kube::golang::host_platform)")
|
||||||
|
fi
|
||||||
|
|
||||||
|
local binaries
|
||||||
|
binaries=($(kube::golang::binaries_from_targets "${targets[@]}"))
|
||||||
|
|
||||||
|
local platform
|
||||||
|
for platform in "${platforms[@]}"; do
|
||||||
|
kube::golang::set_platform_envs "${platform}"
|
||||||
|
kube::log::status "Building go targets for ${platform}:" "${targets[@]}"
|
||||||
|
go install "${goflags[@]:+${goflags[@]}}" \
|
||||||
|
-ldflags "${version_ldflags}" \
|
||||||
|
"${binaries[@]}"
|
||||||
|
done
|
||||||
|
)
|
||||||
|
}
|
30
build/build-image/run-integration.sh → hack/lib/init.sh
Executable file → Normal file
30
build/build-image/run-integration.sh → hack/lib/init.sh
Executable file → Normal file
@@ -18,21 +18,25 @@ set -o errexit
|
|||||||
set -o nounset
|
set -o nounset
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
# The root of the build/dist directory
|
||||||
source "${KUBE_ROOT}/build/build-image/common.sh"
|
KUBE_ROOT=$(
|
||||||
|
unset CDPATH
|
||||||
|
kube_root=$(dirname "${BASH_SOURCE}")/../..
|
||||||
|
cd "${kube_root}"
|
||||||
|
pwd
|
||||||
|
)
|
||||||
|
|
||||||
kube::build::make_binaries "./cmd/integration"
|
KUBE_OUTPUT_SUBPATH="${KUBE_OUTPUT_SUBPATH:-_output/local}"
|
||||||
|
KUBE_OUTPUT="${KUBE_ROOT}/${KUBE_OUTPUT_SUBPATH}"
|
||||||
|
KUBE_OUTPUT_BINPATH="${KUBE_OUTPUT}/bin"
|
||||||
|
|
||||||
readonly ETCD_DIR="${KUBE_ROOT}/_output/etcd"
|
source "${KUBE_ROOT}/hack/lib/util.sh"
|
||||||
mkdir -p "${ETCD_DIR}"
|
source "${KUBE_ROOT}/hack/lib/logging.sh"
|
||||||
|
|
||||||
echo "+++ Running integration test"
|
kube::log::install_errexit
|
||||||
|
|
||||||
etcd -name test -data-dir ${ETCD_DIR} > "${KUBE_ROOT}/_output/etcd.log" &
|
source "${KUBE_ROOT}/hack/lib/version.sh"
|
||||||
readonly ETCD_PID=$!
|
source "${KUBE_ROOT}/hack/lib/golang.sh"
|
||||||
|
source "${KUBE_ROOT}/hack/lib/etcd.sh"
|
||||||
|
|
||||||
sleep 5
|
KUBE_OUTPUT_HOSTBIN="${KUBE_OUTPUT_BINPATH}/$(kube::golang::host_platform)"
|
||||||
|
|
||||||
"${KUBE_TARGET}/linux/amd64/integration"
|
|
||||||
|
|
||||||
kill $ETCD_PID
|
|
137
hack/lib/logging.sh
Normal file
137
hack/lib/logging.sh
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
# Handler for when we exit automatically on an error.
|
||||||
|
# Borrowed from https://gist.github.com/ahendrix/7030300
|
||||||
|
kube::log::errexit() {
|
||||||
|
local err="${PIPESTATUS[@]}"
|
||||||
|
|
||||||
|
# If the shell we are in doesn't have errexit set (common in subshells) then
|
||||||
|
# don't dump stacks.
|
||||||
|
set +o | grep -qe "-o errexit" || return
|
||||||
|
|
||||||
|
set +o xtrace
|
||||||
|
local code="${1:-1}"
|
||||||
|
kube::log::error_exit "'${BASH_COMMAND}' exited with status $err" "${1:-1}" 1
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::log::install_errexit() {
|
||||||
|
# trap ERR to provide an error handler whenever a command exits nonzero this
|
||||||
|
# is a more verbose version of set -o errexit
|
||||||
|
trap 'kube::log::errexit' ERR
|
||||||
|
|
||||||
|
# setting errtrace allows our ERR trap handler to be propagated to functions,
|
||||||
|
# expansions and subshells
|
||||||
|
set -o errtrace
|
||||||
|
}
|
||||||
|
|
||||||
|
# Print out the stack trace
|
||||||
|
#
|
||||||
|
# Args:
|
||||||
|
# $1 The number of stack frames to skip when printing.
|
||||||
|
kube::log::stack() {
|
||||||
|
local stack_skip=${1:-0}
|
||||||
|
stack_skip=$((stack_skip + 1))
|
||||||
|
if [[ ${#FUNCNAME[@]} -gt $stack_skip ]]; then
|
||||||
|
echo "Call stack:" >&2
|
||||||
|
local i
|
||||||
|
for ((i=1 ; i <= ${#FUNCNAME[@]} - $stack_skip ; i++))
|
||||||
|
do
|
||||||
|
local frame_no=$((i - 1 + stack_skip))
|
||||||
|
local source_file=${BASH_SOURCE[$frame_no]}
|
||||||
|
local source_lineno=${BASH_LINENO[$((frame_no - 1))]}
|
||||||
|
local funcname=${FUNCNAME[$frame_no]}
|
||||||
|
echo " $i: ${source_file}:${source_lineno} ${funcname}(...)" >&2
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Log an error and exit.
|
||||||
|
# Args:
|
||||||
|
# $1 Message to log with the error
|
||||||
|
# $2 The error code to return
|
||||||
|
# $3 The number of stack frames to skip when printing.
|
||||||
|
kube::log::error_exit() {
|
||||||
|
local message="${1:-}"
|
||||||
|
local code="${2:-1}"
|
||||||
|
local stack_skip="${3:-0}"
|
||||||
|
stack_skip=$((stack_skip + 1))
|
||||||
|
|
||||||
|
local source_file=${BASH_SOURCE[$stack_skip]}
|
||||||
|
local source_line=${BASH_LINENO[$((stack_skip - 1))]}
|
||||||
|
echo "!!! Error in ${source_file}:${source_line}" >&2
|
||||||
|
[[ -z ${1-} ]] || {
|
||||||
|
echo " ${1}" >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::log::stack $stack_skip
|
||||||
|
|
||||||
|
echo "Exiting with status ${code}" >&2
|
||||||
|
exit "${code}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Log an error but keep going. Don't dump the stack or exit.
|
||||||
|
kube::log::error() {
|
||||||
|
echo "!!! ${1-}" >&2
|
||||||
|
shift
|
||||||
|
for message; do
|
||||||
|
echo " $message" >&2
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# Print an usage message to stderr. The arguments are printed directly.
|
||||||
|
kube::log::usage() {
|
||||||
|
echo >&2
|
||||||
|
local message
|
||||||
|
for message; do
|
||||||
|
echo "$message" >&2
|
||||||
|
done
|
||||||
|
echo >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::log::usage_from_stdin() {
|
||||||
|
local messages=()
|
||||||
|
while read -r line; do
|
||||||
|
messages+=$line
|
||||||
|
done
|
||||||
|
|
||||||
|
kube::log::usage "${messages[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Print out some info that isn't a top level status line
|
||||||
|
kube::log::info() {
|
||||||
|
for message; do
|
||||||
|
echo "$message"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
kube::log::info_from_stdin() {
|
||||||
|
local messages=()
|
||||||
|
while read -r line; do
|
||||||
|
messages+=$line
|
||||||
|
done
|
||||||
|
|
||||||
|
kube::log::info "${messages[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Print a status line. Formatted to show up in a stream of output.
|
||||||
|
kube::log::status() {
|
||||||
|
echo "+++ $1"
|
||||||
|
shift
|
||||||
|
for message; do
|
||||||
|
echo " $message"
|
||||||
|
done
|
||||||
|
}
|
28
hack/install-etcd.sh → hack/lib/util.sh
Executable file → Normal file
28
hack/install-etcd.sh → hack/lib/util.sh
Executable file → Normal file
@@ -14,13 +14,25 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
set -o errexit
|
kube::util::sortable_date() {
|
||||||
set -o nounset
|
date "+%Y%m%d-%H%M%S"
|
||||||
set -o pipefail
|
}
|
||||||
|
|
||||||
cd third_party
|
kube::util::wait_for_url() {
|
||||||
git clone https://github.com/coreos/etcd.git
|
local url=$1
|
||||||
cd etcd
|
local prefix=${2:-}
|
||||||
git checkout ab4bcc18694644d12f0c038339d8d039072502b1
|
local wait=${3:-0.2}
|
||||||
./build
|
local times=${4:-10}
|
||||||
|
|
||||||
|
local i
|
||||||
|
for i in $(seq 1 $times); do
|
||||||
|
local out
|
||||||
|
if out=$(curl -fs $url 2>/dev/null); then
|
||||||
|
kube::log::status ${prefix}${out}
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
sleep $wait
|
||||||
|
done
|
||||||
|
kube::log::error "Timed out waiting for ${url}"
|
||||||
|
return 1
|
||||||
|
}
|
126
hack/lib/version.sh
Normal file
126
hack/lib/version.sh
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
# Version management helpers. These functions help to set, save and load the
|
||||||
|
# following variables:
|
||||||
|
#
|
||||||
|
# KUBE_GIT_COMMIT - The git commit id corresponding to this
|
||||||
|
# source code.
|
||||||
|
# KUBE_GIT_TREE_STATE - "clean" indicates no changes since the git commit id
|
||||||
|
# "dirty" indicates source code changes after the git commit id
|
||||||
|
# KUBE_GIT_VERSION - "vX.Y" used to indicate the last release version.
|
||||||
|
# KUBE_GIT_MAJOR - The major part of the version
|
||||||
|
# KUBE_GIT_MINOR - The minor component of the version
|
||||||
|
|
||||||
|
# Grovels through git to set a set of env variables.
|
||||||
|
#
|
||||||
|
# If KUBE_GIT_VERSION_FILE, this function will load from that file instead of
|
||||||
|
# querying git.
|
||||||
|
kube::version::get_version_vars() {
|
||||||
|
if [[ -n ${KUBE_GIT_VERSION_FILE-} ]]; then
|
||||||
|
kube::version::load_version_vars "${KUBE_GIT_VERSION_FILE}"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
local git=(git --work-tree "${KUBE_ROOT}")
|
||||||
|
|
||||||
|
if [[ -n ${KUBE_GIT_COMMIT-} ]] || KUBE_GIT_COMMIT=$("${git[@]}" rev-parse "HEAD^{commit}" 2>/dev/null); then
|
||||||
|
if [[ -z ${KUBE_GIT_TREE_STATE-} ]]; then
|
||||||
|
# Check if the tree is dirty. default to dirty
|
||||||
|
if git_status=$("${git[@]}" status --porcelain 2>/dev/null) && [[ -z ${git_status} ]]; then
|
||||||
|
KUBE_GIT_TREE_STATE="clean"
|
||||||
|
else
|
||||||
|
KUBE_GIT_TREE_STATE="dirty"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Use git describe to find the version based on annotated tags.
|
||||||
|
if [[ -n ${KUBE_GIT_VERSION-} ]] || KUBE_GIT_VERSION=$("${git[@]}" describe --abbrev=14 "${KUBE_GIT_COMMIT}^{commit}" 2>/dev/null); then
|
||||||
|
if [[ "${KUBE_GIT_TREE_STATE}" == "dirty" ]]; then
|
||||||
|
# git describe --dirty only considers changes to existing files, but
|
||||||
|
# that is problematic since new untracked .go files affect the build,
|
||||||
|
# so use our idea of "dirty" from git status instead.
|
||||||
|
KUBE_GIT_VERSION+="-dirty"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Try to match the "git describe" output to a regex to try to extract
|
||||||
|
# the "major" and "minor" versions and whether this is the exact tagged
|
||||||
|
# version or whether the tree is between two tagged versions.
|
||||||
|
if [[ "${KUBE_GIT_VERSION}" =~ ^v([0-9]+)\.([0-9]+)([.-].*)?$ ]]; then
|
||||||
|
KUBE_GIT_MAJOR=${BASH_REMATCH[1]}
|
||||||
|
KUBE_GIT_MINOR=${BASH_REMATCH[2]}
|
||||||
|
if [[ -n "${BASH_REMATCH[3]}" ]]; then
|
||||||
|
KUBE_GIT_MINOR+="+"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Saves the environment flags to $1
|
||||||
|
kube::version::save_version_vars() {
|
||||||
|
local version_file=${1-}
|
||||||
|
[[ -n ${version_file} ]] || {
|
||||||
|
echo "!!! Internal error. No file specified in kube::version::save_version_vars"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
cat <<EOF >"${version_file}"
|
||||||
|
KUBE_GIT_COMMIT='${KUBE_GIT_COMMIT-}'
|
||||||
|
KUBE_GIT_TREE_STATE='${KUBE_GIT_TREE_STATE-}'
|
||||||
|
KUBE_GIT_VERSION='${KUBE_GIT_VERSION-}'
|
||||||
|
KUBE_GIT_MAJOR='${KUBE_GIT_MAJOR-}'
|
||||||
|
KUBE_GIT_MINOR='${KUBE_GIT_MINOR-}'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
# Loads up the version variables from file $1
|
||||||
|
kube::version::load_version_vars() {
|
||||||
|
local version_file=${1-}
|
||||||
|
[[ -n ${version_file} ]] || {
|
||||||
|
echo "!!! Internal error. No file specified in kube::version::load_version_vars"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
source "${version_file}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Prints the value that needs to be passed to the -ldflags parameter of go build
|
||||||
|
# in order to set the Kubernetes based on the git tree status.
|
||||||
|
kube::version::ldflags() {
|
||||||
|
kube::version::get_version_vars
|
||||||
|
|
||||||
|
local -a ldflags=()
|
||||||
|
if [[ -n ${KUBE_GIT_COMMIT-} ]]; then
|
||||||
|
ldflags+=(-X "${KUBE_GO_PACKAGE}/pkg/version.gitCommit" "${KUBE_GIT_COMMIT}")
|
||||||
|
ldflags+=(-X "${KUBE_GO_PACKAGE}/pkg/version.gitTreeState" "${KUBE_GIT_TREE_STATE}")
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n ${KUBE_GIT_VERSION-} ]]; then
|
||||||
|
ldflags+=(-X "${KUBE_GO_PACKAGE}/pkg/version.gitVersion" "${KUBE_GIT_VERSION}")
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n ${KUBE_GIT_MAJOR-} && -n ${KUBE_GIT_MINOR-} ]]; then
|
||||||
|
ldflags+=(
|
||||||
|
-X "${KUBE_GO_PACKAGE}/pkg/version.gitMajor" "${KUBE_GIT_MAJOR}"
|
||||||
|
-X "${KUBE_GO_PACKAGE}/pkg/version.gitMinor" "${KUBE_GIT_MINOR}"
|
||||||
|
)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# The -ldflags parameter takes a single string, so join the output.
|
||||||
|
echo "${ldflags[*]-}"
|
||||||
|
}
|
@@ -22,8 +22,7 @@ set -o nounset
|
|||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
source "${KUBE_ROOT}/hack/util.sh"
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||||||
source "${KUBE_ROOT}/hack/config-go.sh"
|
|
||||||
|
|
||||||
function cleanup()
|
function cleanup()
|
||||||
{
|
{
|
||||||
@@ -31,18 +30,15 @@ function cleanup()
|
|||||||
[[ -n ${CTLRMGR_PID-} ]] && kill ${CTLRMGR_PID} 1>&2 2>/dev/null
|
[[ -n ${CTLRMGR_PID-} ]] && kill ${CTLRMGR_PID} 1>&2 2>/dev/null
|
||||||
[[ -n ${KUBELET_PID-} ]] && kill ${KUBELET_PID} 1>&2 2>/dev/null
|
[[ -n ${KUBELET_PID-} ]] && kill ${KUBELET_PID} 1>&2 2>/dev/null
|
||||||
[[ -n ${PROXY_PID-} ]] && kill ${PROXY_PID} 1>&2 2>/dev/null
|
[[ -n ${PROXY_PID-} ]] && kill ${PROXY_PID} 1>&2 2>/dev/null
|
||||||
[[ -n ${ETCD_PID-} ]] && kill ${ETCD_PID} 1>&2 2>/dev/null
|
|
||||||
rm -rf ${ETCD_DIR} 1>&2 2>/dev/null
|
kube::etcd::cleanup
|
||||||
echo
|
|
||||||
echo "Complete"
|
kube::log::status "Clean up complete"
|
||||||
}
|
}
|
||||||
|
|
||||||
trap cleanup EXIT SIGINT
|
trap cleanup EXIT SIGINT
|
||||||
|
|
||||||
set -e
|
kube::etcd::start
|
||||||
|
|
||||||
# Start etcd
|
|
||||||
start_etcd
|
|
||||||
|
|
||||||
ETCD_HOST=${ETCD_HOST:-127.0.0.1}
|
ETCD_HOST=${ETCD_HOST:-127.0.0.1}
|
||||||
ETCD_PORT=${ETCD_PORT:-4001}
|
ETCD_PORT=${ETCD_PORT:-4001}
|
||||||
@@ -50,24 +46,25 @@ API_PORT=${API_PORT:-8080}
|
|||||||
API_HOST=${API_HOST:-127.0.0.1}
|
API_HOST=${API_HOST:-127.0.0.1}
|
||||||
KUBELET_PORT=${KUBELET_PORT:-10250}
|
KUBELET_PORT=${KUBELET_PORT:-10250}
|
||||||
CTLRMGR_PORT=${CTLRMGR_PORT:-10252}
|
CTLRMGR_PORT=${CTLRMGR_PORT:-10252}
|
||||||
GO_OUT=${KUBE_TARGET}/bin
|
|
||||||
|
|
||||||
# Check kubectl
|
# Check kubectl
|
||||||
out=$("${GO_OUT}/kubectl")
|
kube::log::status "Running kubectl with no options"
|
||||||
echo kubectl: $out
|
"${KUBE_OUTPUT_HOSTBIN}/kubectl"
|
||||||
|
|
||||||
# Start kubelet
|
# Start kubelet
|
||||||
${GO_OUT}/kubelet \
|
kube::log::status "Starting kubelet"
|
||||||
|
"${KUBE_OUTPUT_HOSTBIN}/kubelet" \
|
||||||
--etcd_servers="http://${ETCD_HOST}:${ETCD_PORT}" \
|
--etcd_servers="http://${ETCD_HOST}:${ETCD_PORT}" \
|
||||||
--hostname_override="127.0.0.1" \
|
--hostname_override="127.0.0.1" \
|
||||||
--address="127.0.0.1" \
|
--address="127.0.0.1" \
|
||||||
--port="$KUBELET_PORT" 1>&2 &
|
--port="$KUBELET_PORT" 1>&2 &
|
||||||
KUBELET_PID=$!
|
KUBELET_PID=$!
|
||||||
|
|
||||||
wait_for_url "http://127.0.0.1:${KUBELET_PORT}/healthz" "kubelet: "
|
kube::util::wait_for_url "http://127.0.0.1:${KUBELET_PORT}/healthz" "kubelet: "
|
||||||
|
|
||||||
# Start apiserver
|
# Start apiserver
|
||||||
${GO_OUT}/apiserver \
|
kube::log::status "Starting apiserver"
|
||||||
|
"${KUBE_OUTPUT_HOSTBIN}/apiserver" \
|
||||||
--address="127.0.0.1" \
|
--address="127.0.0.1" \
|
||||||
--port="${API_PORT}" \
|
--port="${API_PORT}" \
|
||||||
--etcd_servers="http://${ETCD_HOST}:${ETCD_PORT}" \
|
--etcd_servers="http://${ETCD_HOST}:${ETCD_PORT}" \
|
||||||
@@ -75,33 +72,42 @@ ${GO_OUT}/apiserver \
|
|||||||
--portal_net="10.0.0.0/24" 1>&2 &
|
--portal_net="10.0.0.0/24" 1>&2 &
|
||||||
APISERVER_PID=$!
|
APISERVER_PID=$!
|
||||||
|
|
||||||
wait_for_url "http://127.0.0.1:${API_PORT}/healthz" "apiserver: "
|
kube::util::wait_for_url "http://127.0.0.1:${API_PORT}/healthz" "apiserver: "
|
||||||
|
|
||||||
|
kube_cmd=(
|
||||||
|
"${KUBE_OUTPUT_HOSTBIN}/kubectl"
|
||||||
|
)
|
||||||
|
|
||||||
|
kube_flags=(
|
||||||
|
-s "http://127.0.0.1:${API_PORT}"
|
||||||
|
--match-server-version
|
||||||
|
)
|
||||||
|
|
||||||
# Start controller manager
|
# Start controller manager
|
||||||
${GO_OUT}/controller-manager \
|
kube::log::status "Starting CONTROLLER-MANAGER"
|
||||||
|
"${KUBE_OUTPUT_HOSTBIN}/controller-manager" \
|
||||||
--machines="127.0.0.1" \
|
--machines="127.0.0.1" \
|
||||||
--master="127.0.0.1:${API_PORT}" 1>&2 &
|
--master="127.0.0.1:${API_PORT}" 1>&2 &
|
||||||
CTLRMGR_PID=$!
|
CTLRMGR_PID=$!
|
||||||
|
|
||||||
wait_for_url "http://127.0.0.1:${CTLRMGR_PORT}/healthz" "controller-manager: "
|
kube::util::wait_for_url "http://127.0.0.1:${CTLRMGR_PORT}/healthz" "controller-manager: "
|
||||||
|
|
||||||
KUBE_CMD="${GO_OUT}/kubectl"
|
kube::log::status "Testing kubectl(pods)"
|
||||||
KUBE_FLAGS="-s http://127.0.0.1:${API_PORT} --match-server-version"
|
"${kube_cmd[@]}" get pods "${kube_flags[@]}"
|
||||||
|
|
||||||
${KUBE_CMD} get pods ${KUBE_FLAGS}
|
kube::log::status "Testing kubectl(services)"
|
||||||
echo "kubectl(pods): ok"
|
"${kube_cmd[@]}" get services "${kube_flags[@]}"
|
||||||
|
"${kube_cmd[@]}" create -f examples/guestbook/frontend-service.json "${kube_flags[@]}"
|
||||||
|
"${kube_cmd[@]}" delete service frontend "${kube_flags[@]}"
|
||||||
|
|
||||||
${KUBE_CMD} get services ${KUBE_FLAGS}
|
kube::log::status "Testing kubectl(minions)"
|
||||||
${KUBE_CMD} create -f examples/guestbook/frontend-service.json ${KUBE_FLAGS}
|
"${kube_cmd[@]}" get minions "${kube_flags[@]}"
|
||||||
${KUBE_CMD} delete service frontend ${KUBE_FLAGS}
|
"${kube_cmd[@]}" get minions 127.0.0.1 "${kube_flags[@]}"
|
||||||
echo "kubectl(services): ok"
|
|
||||||
|
|
||||||
${KUBE_CMD} get minions ${KUBE_FLAGS}
|
kube::log::status "TEST PASSED"
|
||||||
${KUBE_CMD} get minions 127.0.0.1 ${KUBE_FLAGS}
|
|
||||||
echo "kubectl(minions): ok"
|
|
||||||
|
|
||||||
# Start proxy
|
# Start proxy
|
||||||
#PROXY_LOG=/tmp/kube-proxy.log
|
#PROXY_LOG=/tmp/kube-proxy.log
|
||||||
#${GO_OUT}/proxy \
|
#${KUBE_OUTPUT_HOSTBIN}/proxy \
|
||||||
# --etcd_servers="http://127.0.0.1:${ETCD_PORT}" 1>&2 &
|
# --etcd_servers="http://127.0.0.1:${ETCD_PORT}" 1>&2 &
|
||||||
#PROXY_PID=$!
|
#PROXY_PID=$!
|
||||||
|
@@ -19,30 +19,28 @@ set -o nounset
|
|||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
source "${KUBE_ROOT}/hack/config-go.sh"
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||||||
|
|
||||||
# Go to the top of the tree.
|
kube::golang::setup_env
|
||||||
cd "${KUBE_ROOT}"
|
|
||||||
|
|
||||||
# Check for `go` binary and set ${GOPATH}.
|
kube::test::find_dirs() {
|
||||||
kube::setup_go_environment
|
(
|
||||||
|
cd ${KUBE_ROOT}
|
||||||
find_test_dirs() {
|
find . -not \( \
|
||||||
cd src/${KUBE_GO_PACKAGE}
|
\( \
|
||||||
find . -not \( \
|
-wholename './output' \
|
||||||
\( \
|
-o -wholename './_output' \
|
||||||
-wholename './output' \
|
-o -wholename './release' \
|
||||||
-o -wholename './_output' \
|
-o -wholename './target' \
|
||||||
-o -wholename './release' \
|
-o -wholename '*/third_party/*' \
|
||||||
-o -wholename './target' \
|
-o -wholename '*/Godeps/*' \
|
||||||
-o -wholename '*/third_party/*' \
|
\) -prune \
|
||||||
-o -wholename '*/Godeps/*' \
|
\) -name '*_test.go' -print0 | xargs -0n1 dirname | sed 's|^\./||' | sort -u
|
||||||
\) -prune \
|
)
|
||||||
\) -name '*_test.go' -print0 | xargs -0n1 dirname | sed 's|^\./||' | sort -u
|
|
||||||
}
|
}
|
||||||
|
|
||||||
find_test_pkgs() {
|
kube::test::find_pkgs() {
|
||||||
find_test_dirs | xargs -n1 printf "${KUBE_GO_PACKAGE}/%s\n"
|
kube::test::find_dirs | xargs -n1 printf "${KUBE_GO_PACKAGE}/%s\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
# -covermode=atomic becomes default with -race in Go >=1.3
|
# -covermode=atomic becomes default with -race in Go >=1.3
|
||||||
@@ -50,10 +48,8 @@ KUBE_COVER=${KUBE_COVER:--cover -covermode=atomic}
|
|||||||
KUBE_TIMEOUT=${KUBE_TIMEOUT:--timeout 60s}
|
KUBE_TIMEOUT=${KUBE_TIMEOUT:--timeout 60s}
|
||||||
KUBE_RACE=${KUBE_RACE:--race}
|
KUBE_RACE=${KUBE_RACE:--race}
|
||||||
|
|
||||||
cd "${KUBE_TARGET}"
|
kube::test::usage() {
|
||||||
|
kube::log::usage_from_stdin <<EOF
|
||||||
usage() {
|
|
||||||
cat << EOF
|
|
||||||
usage: $0 [OPTIONS] [TARGETS]
|
usage: $0 [OPTIONS] [TARGETS]
|
||||||
|
|
||||||
OPTIONS:
|
OPTIONS:
|
||||||
@@ -69,24 +65,24 @@ iterations=1
|
|||||||
while getopts "hi:" opt ; do
|
while getopts "hi:" opt ; do
|
||||||
case $opt in
|
case $opt in
|
||||||
h)
|
h)
|
||||||
usage
|
kube::test::usage
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
i)
|
i)
|
||||||
iterations="$OPTARG"
|
iterations="$OPTARG"
|
||||||
if ! isnum "${iterations}" || [[ "${iterations}" -le 0 ]]; then
|
if ! isnum "${iterations}" || [[ "${iterations}" -le 0 ]]; then
|
||||||
echo "$0": argument to -i must be numeric and greater than 0 >&2
|
kube::log::usage "'$0': argument to -i must be numeric and greater than 0"
|
||||||
usage >&2
|
kube::test::usage
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
?)
|
?)
|
||||||
usage >&2
|
kube::test::usage
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
:)
|
:)
|
||||||
echo "Option -$OPTARG <value>" >&2
|
kube::log::usage "Option -$OPTARG <value>"
|
||||||
usage >&2
|
kube::test::usage
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
@@ -94,7 +90,7 @@ done
|
|||||||
shift $((OPTIND - 1))
|
shift $((OPTIND - 1))
|
||||||
|
|
||||||
# Use eval to preserve embedded quoted strings.
|
# Use eval to preserve embedded quoted strings.
|
||||||
eval "goflags=(${GOFLAGS:-})"
|
eval "goflags=(${KUBE_GOFLAGS:-})"
|
||||||
|
|
||||||
# Filter out arguments that start with "-" and move them to goflags.
|
# Filter out arguments that start with "-" and move them to goflags.
|
||||||
testcases=()
|
testcases=()
|
||||||
@@ -105,19 +101,18 @@ for arg; do
|
|||||||
testcases+=("${arg}")
|
testcases+=("${arg}")
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
set -- ${testcases[@]+"${testcases[@]}"}
|
set -- "${testcases[@]+${testcases[@]}}"
|
||||||
|
|
||||||
if [[ "${iterations}" -gt 1 ]]; then
|
if [[ $iterations -gt 1 ]]; then
|
||||||
if [[ $# -eq 0 ]]; then
|
if [[ $# -eq 0 ]]; then
|
||||||
set -- $(find_test_dirs)
|
set -- $(kube::test::find_dirs)
|
||||||
fi
|
fi
|
||||||
echo "Running ${iterations} times"
|
kube::log::status "Running ${iterations} times"
|
||||||
fails=0
|
fails=0
|
||||||
for arg; do
|
for arg; do
|
||||||
trap 'exit 1' SIGINT
|
trap 'exit 1' SIGINT
|
||||||
echo
|
|
||||||
pkg=${KUBE_GO_PACKAGE}/${arg}
|
pkg=${KUBE_GO_PACKAGE}/${arg}
|
||||||
echo "${pkg}"
|
kube::log::status "${pkg}"
|
||||||
# keep going, even if there are failures
|
# keep going, even if there are failures
|
||||||
pass=0
|
pass=0
|
||||||
count=0
|
count=0
|
||||||
@@ -130,7 +125,7 @@ if [[ "${iterations}" -gt 1 ]]; then
|
|||||||
fi
|
fi
|
||||||
count=$((count + 1))
|
count=$((count + 1))
|
||||||
done 2>&1
|
done 2>&1
|
||||||
echo "${pass}" / "${count}" passed
|
kube::log::status "${pass} / ${count} passed"
|
||||||
done
|
done
|
||||||
if [[ ${fails} -gt 0 ]]; then
|
if [[ ${fails} -gt 0 ]]; then
|
||||||
exit 1
|
exit 1
|
||||||
@@ -140,8 +135,8 @@ if [[ "${iterations}" -gt 1 ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -n "${1-}" ]]; then
|
if [[ -n "${1-}" ]]; then
|
||||||
covdir="/tmp/k8s_coverage/$(date "+%s")"
|
covdir="/tmp/k8s_coverage/$(kube::util::sortable_date)"
|
||||||
echo saving coverage output in "${covdir}"
|
kube::log::status "Saving coverage output in '${covdir}'"
|
||||||
for arg; do
|
for arg; do
|
||||||
trap 'exit 1' SIGINT
|
trap 'exit 1' SIGINT
|
||||||
mkdir -p "${covdir}/${arg}"
|
mkdir -p "${covdir}/${arg}"
|
||||||
@@ -155,7 +150,7 @@ if [[ -n "${1-}" ]]; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
find_test_pkgs | xargs go test "${goflags[@]:+${goflags[@]}}" \
|
kube::test::find_pkgs | xargs go test "${goflags[@]:+${goflags[@]}}" \
|
||||||
${KUBE_RACE} \
|
${KUBE_RACE} \
|
||||||
${KUBE_TIMEOUT} \
|
${KUBE_TIMEOUT} \
|
||||||
${KUBE_COVER}
|
${KUBE_COVER}
|
||||||
|
@@ -19,34 +19,28 @@ set -o nounset
|
|||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
source "${KUBE_ROOT}/hack/config-go.sh"
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||||||
source "${KUBE_ROOT}/hack/util.sh"
|
|
||||||
|
|
||||||
cleanup() {
|
cleanup() {
|
||||||
kill "${ETCD_PID-}" >/dev/null 2>&1 || :
|
kube::etcd::cleanup
|
||||||
rm -rf "${ETCD_DIR-}"
|
kube::log::status "Integration test cleanup complete"
|
||||||
echo ""
|
|
||||||
echo "Complete"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if [[ "${KUBE_NO_BUILD_INTEGRATION+set}" != "set" ]]; then
|
if [[ -z ${KUBE_NO_BUILD_INTEGRATION-} ]]; then
|
||||||
"${KUBE_ROOT}/hack/build-go.sh" cmd/integration
|
"${KUBE_ROOT}/hack/build-go.sh" cmd/integration
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Run cleanup to stop etcd on interrupt or other kill signal.
|
# Run cleanup to stop etcd on interrupt or other kill signal.
|
||||||
trap cleanup HUP INT QUIT TERM
|
trap cleanup HUP INT QUIT TERM
|
||||||
|
|
||||||
start_etcd
|
kube::etcd::start
|
||||||
|
|
||||||
echo ""
|
kube::log::status "Running integration test cases"
|
||||||
echo "Integration test cases..."
|
KUBE_GOFLAGS="-tags 'integration no-docker' -test.v" \
|
||||||
echo ""
|
|
||||||
GOFLAGS="-tags 'integration no-docker' -test.v" \
|
|
||||||
"${KUBE_ROOT}/hack/test-go.sh" test/integration
|
"${KUBE_ROOT}/hack/test-go.sh" test/integration
|
||||||
|
|
||||||
echo ""
|
kube::log::status "Running integration test scenario"
|
||||||
echo "Integration scenario ..."
|
|
||||||
echo ""
|
"${KUBE_OUTPUT_HOSTBIN}/integration"
|
||||||
"${KUBE_TARGET}/bin/integration"
|
|
||||||
|
|
||||||
cleanup
|
cleanup
|
||||||
|
@@ -19,13 +19,10 @@ set -o nounset
|
|||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
||||||
source "${KUBE_ROOT}/build/build-image/common.sh"
|
|
||||||
|
|
||||||
echo "+++ Running unit tests"
|
ETCD_VERSION=${ETCD_VERSION:-v0.4.6}
|
||||||
|
|
||||||
if [[ -n "${1-}" ]]; then
|
cd "${KUBE_ROOT}/third_party"
|
||||||
godep go test -cover -coverprofile=tmp.out "$KUBE_GO_PACKAGE/$1"
|
curl -sL https://github.com/coreos/etcd/releases/download/${ETCD_VERSION}/etcd-${ETCD_VERSION}-linux-amd64.tar.gz \
|
||||||
exit 0
|
| tar xzf -
|
||||||
fi
|
ln -sF etcd-${ETCD_VERSION}-linux-amd64 etcd
|
||||||
|
|
||||||
godep go test ./...
|
|
@@ -20,10 +20,10 @@ set -o errexit
|
|||||||
set -o nounset
|
set -o nounset
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
if [ "${TRAVIS}" == "true" ]; then
|
if [[ "${TRAVIS}" == "true" ]]; then
|
||||||
GO_VERSION=($(go version))
|
GO_VERSION=($(go version))
|
||||||
|
|
||||||
if [ ${GO_VERSION[2]} \< "go1.3" ]; then
|
if [[ ${GO_VERSION[2]} < "go1.3" ]]; then
|
||||||
echo "Installing the -race compatible version of the std go library"
|
echo "Installing the -race compatible version of the std go library"
|
||||||
go install -a -race std
|
go install -a -race std
|
||||||
fi
|
fi
|
66
hack/util.sh
66
hack/util.sh
@@ -1,66 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 Google Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# Provides simple utility functions
|
|
||||||
|
|
||||||
function wait_for_url {
|
|
||||||
url=$1
|
|
||||||
prefix=${2:-}
|
|
||||||
wait=${3:-0.2}
|
|
||||||
times=${4:-10}
|
|
||||||
|
|
||||||
set +e
|
|
||||||
for i in $(seq 1 $times); do
|
|
||||||
out=$(curl -fs $url 2>/dev/null)
|
|
||||||
if [ $? -eq 0 ]; then
|
|
||||||
set -e
|
|
||||||
echo ${prefix}${out}
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
sleep $wait
|
|
||||||
done
|
|
||||||
echo "ERROR: timed out for $url"
|
|
||||||
set -e
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
function start_etcd {
|
|
||||||
host=${ETCD_HOST:-127.0.0.1}
|
|
||||||
port=${ETCD_PORT:-4001}
|
|
||||||
|
|
||||||
set +e
|
|
||||||
|
|
||||||
if [ "$(which etcd)" == "" ]; then
|
|
||||||
echo "etcd must be in your PATH"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
running_etcd=$(ps -ef | grep etcd | grep -c name)
|
|
||||||
if [ "$running_etcd" != "0" ]; then
|
|
||||||
echo "etcd appears to already be running on this machine, please kill and restart the test."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Stop on any failures
|
|
||||||
set -e
|
|
||||||
|
|
||||||
# Start etcd
|
|
||||||
export ETCD_DIR=$(mktemp -d -t test-etcd.XXXXXX)
|
|
||||||
etcd -name test -data-dir ${ETCD_DIR} -addr ${host}:${port} >/dev/null 2>/dev/null &
|
|
||||||
export ETCD_PID=$!
|
|
||||||
|
|
||||||
wait_for_url "http://localhost:4001/v2/keys/" "etcd: "
|
|
||||||
}
|
|
@@ -20,20 +20,33 @@ set -o pipefail
|
|||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
|
|
||||||
result=0
|
cd ${KUBE_ROOT}
|
||||||
|
|
||||||
gofiles="$(find "${KUBE_ROOT}" -type f | grep "[.]go$" | grep -v "Godeps/\|third_party/\|release/\|_?output/|target/")"
|
result=0
|
||||||
for file in ${gofiles}; do
|
find_files() {
|
||||||
|
find . -not \( \
|
||||||
|
\( \
|
||||||
|
-wholename './output' \
|
||||||
|
-o -wholename './_output' \
|
||||||
|
-o -wholename './release' \
|
||||||
|
-o -wholename './target' \
|
||||||
|
-o -wholename '*/third_party/*' \
|
||||||
|
-o -wholename '*/Godeps/*' \
|
||||||
|
\) -prune \
|
||||||
|
\) -name '*.go'
|
||||||
|
}
|
||||||
|
|
||||||
|
for file in $(find_files); do
|
||||||
if [[ "$("${KUBE_ROOT}/hooks/boilerplate.sh" "${file}")" -eq "0" ]]; then
|
if [[ "$("${KUBE_ROOT}/hooks/boilerplate.sh" "${file}")" -eq "0" ]]; then
|
||||||
echo "Boilerplate header is wrong for: ${file}"
|
echo "Boilerplate header is wrong for: ${file}"
|
||||||
result=1
|
result=1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
dirs=("cluster" "hack" "hooks")
|
dirs=("cluster" "hack" "hooks" "build")
|
||||||
|
|
||||||
for dir in ${dirs[@]}; do
|
for dir in ${dirs[@]}; do
|
||||||
for file in $(grep -r -l "" "${KUBE_ROOT}/${dir}/" | grep "[.]sh"); do
|
for file in $(find "$dir" -name '*.sh'); do
|
||||||
if [[ "$("${KUBE_ROOT}/hooks/boilerplate.sh" "${file}")" -eq "0" ]]; then
|
if [[ "$("${KUBE_ROOT}/hooks/boilerplate.sh" "${file}")" -eq "0" ]]; then
|
||||||
echo "Boilerplate header is wrong for: ${file}"
|
echo "Boilerplate header is wrong for: ${file}"
|
||||||
result=1
|
result=1
|
||||||
|
@@ -20,6 +20,7 @@ set -o errexit
|
|||||||
set -o nounset
|
set -o nounset
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
|
|
||||||
GO_VERSION=($(go version))
|
GO_VERSION=($(go version))
|
||||||
|
|
||||||
@@ -28,11 +29,24 @@ if [[ -z $(echo "${GO_VERSION[2]}" | grep -E 'go1.2|go1.3') ]]; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
cd "${KUBE_ROOT}"
|
||||||
|
|
||||||
files="$(find "${KUBE_ROOT}" -type f | grep "[.]go$" | grep -v "third_party/\|release/\|_?output/\|target/\|Godeps/")"
|
find_files() {
|
||||||
bad=$(gofmt -s -l ${files})
|
find . -not \( \
|
||||||
if [[ -n "${bad}" ]]; then
|
\( \
|
||||||
echo "$bad"
|
-wholename './output' \
|
||||||
|
-o -wholename './_output' \
|
||||||
|
-o -wholename './release' \
|
||||||
|
-o -wholename './target' \
|
||||||
|
-o -wholename '*/third_party/*' \
|
||||||
|
-o -wholename '*/Godeps/*' \
|
||||||
|
\) -prune \
|
||||||
|
\) -name '*.go'
|
||||||
|
}
|
||||||
|
|
||||||
|
bad_files=$(find_files | xargs gofmt -s -l)
|
||||||
|
if [[ -n "${bad_files}" ]]; then
|
||||||
|
echo "!!! gofmt needs to be run on the following files: "
|
||||||
|
echo "${bad_files}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
@@ -19,19 +19,15 @@ set -o errexit
|
|||||||
set -o nounset
|
set -o nounset
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
KUBE_REPO_ROOT=$(dirname "${BASH_SOURCE}")/..
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||||||
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||||||
|
|
||||||
# Set the environment variables required by the build.
|
kube::golang::setup_env
|
||||||
source "${KUBE_REPO_ROOT}/hack/config-go.sh"
|
|
||||||
|
|
||||||
# Go to the top of the tree.
|
cd "${KUBE_ROOT}"
|
||||||
cd "${KUBE_REPO_ROOT}"
|
|
||||||
|
|
||||||
# Check for `go` binary and set ${GOPATH}.
|
|
||||||
kube::setup_go_environment
|
|
||||||
|
|
||||||
# Use eval to preserve embedded quoted strings.
|
# Use eval to preserve embedded quoted strings.
|
||||||
eval "goflags=(${GOFLAGS:-})"
|
eval "goflags=(${KUBE_GOFLAGS:-})"
|
||||||
|
|
||||||
# Filter out arguments that start with "-" and move them to goflags.
|
# Filter out arguments that start with "-" and move them to goflags.
|
||||||
targets=()
|
targets=()
|
||||||
@@ -43,19 +39,20 @@ for arg; do
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if [[ "${targets[@]+set}" != "set" ]]; then
|
if [[ ${#targets[@]} -eq 0 ]]; then
|
||||||
targets=("...")
|
targets=("...")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rc=0
|
|
||||||
# Filter silly "exit status 1" lines and send main output to stdout.
|
# Filter silly "exit status 1" lines and send main output to stdout.
|
||||||
|
#
|
||||||
# This is tricky - pipefail means any non-zero exit in a pipeline is reported,
|
# This is tricky - pipefail means any non-zero exit in a pipeline is reported,
|
||||||
# and errexit exits on error. Turning that into an || expression blocks the
|
# and errexit exits on error. Turning that into an || expression blocks the
|
||||||
# errexit. But $? is still not useful because grep will return an error when it
|
# errexit. But $? is still not useful because grep will return an error when it
|
||||||
# receives no input, which is exactly what go vet produces on success. In short,
|
# receives no input, which is exactly what go vet produces on success. In
|
||||||
# if go vet fails (produces output), grep will succeed, but if go vet succeeds
|
# short, if go vet fails (produces output), grep will succeed, but if go vet
|
||||||
# (produces no output) grep will fail. Then we just look at PIPESTATUS[0] which
|
# succeeds (produces no output) grep will fail. Then we just look at
|
||||||
# is go's exit code.
|
# PIPESTATUS[0] which is go's exit code.
|
||||||
|
rc=0
|
||||||
go vet "${goflags[@]:+${goflags[@]}}" "${targets[@]/#/./}" 2>&1 \
|
go vet "${goflags[@]:+${goflags[@]}}" "${targets[@]/#/./}" 2>&1 \
|
||||||
| grep -v "^exit status " \
|
| grep -v "^exit status " \
|
||||||
|| rc=${PIPESTATUS[0]}
|
|| rc=${PIPESTATUS[0]}
|
||||||
|
Reference in New Issue
Block a user