test.bash: test harness improvements
Modify the test harness to run Go tests concurrently.
This vastly speeds up execution time on machines with many cores.
Other changes:
* Some stylistic changes to make the output colored and more readable.
* Add protoc and conformance-test-runner to the $PATH
* Check that Go source files were properly formatted
Change-Id: I5d7e14defeef32c587e6f8e2f66367143413a41f
Reviewed-on: https://go-review.googlesource.com/128415
Reviewed-by: Herbie Ong <herbie@google.com>
diff --git a/test.bash b/test.bash
index 87b1fe0..99c8a7f 100755
--- a/test.bash
+++ b/test.bash
@@ -5,11 +5,13 @@
REPO_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
+function print() { echo -e "\x1b[1m> $@\x1b[0m"; }
+
# Create a test directory.
# The Go and protobuf toolchains used for testing will be cached here.
TEST_DIR=/tmp/golang-protobuf-test
if [ ! -d $TEST_DIR ]; then
- echo "mkdir $TEST_DIR"
+ print "mkdir $TEST_DIR"
mkdir -p $TEST_DIR
fi
cd $TEST_DIR
@@ -20,10 +22,11 @@
PROTOBUF_VERSION=3.6.1
PROTOBUF_DIR="protobuf-$PROTOBUF_VERSION"
if [ ! -d $PROTOBUF_DIR ]; then
- echo "download and build $PROTOBUF_DIR"
+ print "download and build $PROTOBUF_DIR"
(curl -s -L https://github.com/google/protobuf/releases/download/v$PROTOBUF_VERSION/protobuf-all-$PROTOBUF_VERSION.tar.gz | tar -zxf -) || exit 1
(cd $PROTOBUF_DIR && ./configure && make && cd conformance && make) || exit 1
fi
+export PATH=$TEST_DIR/$PROTOBUF_DIR/src:$TEST_DIR/$PROTOBUF_DIR/conformance:$PATH
# Download each Go toolchain version.
GO_LATEST=1.11beta3
@@ -31,7 +34,7 @@
for GO_VERSION in ${GO_VERSIONS[@]}; do
GO_DIR=go$GO_VERSION
if [ ! -d $GO_DIR ]; then
- echo "download $GO_DIR"
+ print "download $GO_DIR"
GOOS=$(uname | tr '[:upper:]' '[:lower:]')
(mkdir $GO_DIR && curl -s -L https://dl.google.com/go/$GO_DIR.$GOOS-amd64.tar.gz | tar -zxf - -C $GO_DIR --strip-components 1) || exit 1
fi
@@ -56,35 +59,67 @@
export GOPATH=$TEST_DIR/gopath
# Run tests across every supported version of Go.
-FAIL=0
+LABELS=()
+PIDS=()
+OUTS=()
+function cleanup() { for OUT in ${OUTS[@]}; do rm $OUT; done; }
+trap cleanup EXIT
for GO_VERSION in ${GO_VERSIONS[@]}; do
- GO_BIN=go$GO_VERSION/bin/go
- function go_build() {
- echo "$GO_BIN build $@"
- (cd $GOPATH/src/$MODULE_PATH && $TEST_DIR/$GO_BIN build $@) || FAIL=1
- }
- function go_test() {
- echo "$GO_BIN test $@"
- (cd $GOPATH/src/$MODULE_PATH && $TEST_DIR/$GO_BIN test $@) || FAIL=1
+ # Run the go command in a background process.
+ function go() {
+ GO_BIN=go$GO_VERSION/bin/go
+ LABELS+=("$(echo "go$GO_VERSION $@")")
+ OUT=$(mktemp)
+ (cd $GOPATH/src/$MODULE_PATH && $TEST_DIR/$GO_BIN $@ &> $OUT) &
+ PIDS+=($!)
+ OUTS+=($OUT)
}
- go_build ./...
- go_test -race ./...
- go_test -race -tags proto1_legacy ./...
+ go build ./...
+ go test -race ./...
+ go test -race -tags proto1_legacy ./...
done
+# Wait for all processes to finish.
+RET=0
+for I in ${!PIDS[@]}; do
+ print "${LABELS[$I]}"
+ if ! wait ${PIDS[$I]}; then
+ cat ${OUTS[$I]} # only output upon error
+ RET=1
+ fi
+done
+
+# TODO: Check for stale generated Go source files.
+
+# Check for unformatted Go source files.
+FMT_DIFF=$(cd $REPO_ROOT && ${GO_LATEST_BIN}fmt -d . 2>&1)
+if [ ! -z "$FMT_DIFF" ]; then
+ print "gofmt -d ."
+ echo "$FMT_DIFF"
+ RET=1
+fi
+
# Check for changed files.
GIT_DIFF=$(cd $REPO_ROOT && git diff --no-prefix HEAD 2>&1)
if [ ! -z "$GIT_DIFF" ]; then
- echo -e "git diff HEAD\n$GIT_DIFF"
- FAIL=1
+ print "git diff HEAD"
+ echo "$GIT_DIFF"
+ RET=1
fi
# Check for untracked files.
GIT_UNTRACKED=$(cd $REPO_ROOT && git ls-files --others --exclude-standard 2>&1)
if [ ! -z "$GIT_UNTRACKED" ]; then
- echo -e "git ls-files --others --exclude-standard\n$GIT_UNTRACKED"
- FAIL=1
+ print "git ls-files --others --exclude-standard"
+ echo "$GIT_UNTRACKED"
+ RET=1
fi
-exit $FAIL
+# Print termination status.
+if [ $RET -eq 0 ]; then
+ echo -e "\x1b[32;1mPASS\x1b[0m"
+else
+ echo -e "\x1b[31;1mFAIL\x1b[0m"
+fi
+exit $RET