build: build all packages together

Build all packages together with a global timeout. Locally,
the tests pass within 40 sec. On travis, we complete within
3-4 min.

travis truncates the logs after 4MB which we are hitting so
show the relevant information first and then whatever is left.
This commit is contained in:
Frank Schroeder 2017-06-29 14:50:47 +02:00 committed by Frank Schröder
parent e4b40acc7e
commit 61ca9b02d4
2 changed files with 16 additions and 11 deletions

3
.gitignore vendored
View File

@ -5,10 +5,11 @@
*.swp
*.test
.DS_Store
Thumbs.db
.vagrant/
/pkg
Thumbs.db
bin/
exit-code
ui/.bundle
ui/.sass-cache
ui/dist/

View File

@ -50,16 +50,20 @@ cov:
open /tmp/coverage.html
test: dev
go test -tags "$(GOTAGS)" -i ./...
go test -tags "$(GOTAGS)" -run '^$$' ./... > /dev/null
go test -tags "$(GOTAGS)" -v $$(go list ./... | egrep -v '(agent/consul|vendor)') > test.log 2>&1 || echo 'FAIL_TOKEN' >> test.log
go test -tags "$(GOTAGS)" -v $$(go list ./... | egrep '(agent/consul)') >> test.log 2>&1 || echo 'FAIL_TOKEN' >> test.log
@if [ "$$TRAVIS" == "true" ] ; then cat test.log ; fi
@if grep -q 'FAIL_TOKEN' test.log ; then grep 'FAIL:' test.log ; exit 1 ; else echo 'PASS' ; fi
go test -tags '$(GOTAGS)' -i ./...
go test $(GOTEST_FLAGS) -tags '$(GOTAGS)' -timeout 7m -v ./... 2>&1 >test$(GOTEST_FLAGS).log ; echo $$? > exit-code
@echo "Exit code: `cat exit-code`" >> test$(GOTEST_FLAGS).log
@echo "----"
@grep -A5 'DATA RACE' test.log || true
@grep -A10 'panic: test timed out' test.log || true
@grep '^PASS' test.log | uniq || true
@grep -A1 -- '--- FAIL:' test.log || true
@grep '^FAIL' test.log || true
@test "$$TRAVIS" == "true" && cat test.log || true
@exit $$(cat exit-code)
test-race: dev
go test -tags "$(GOTAGS)" -i -run '^$$' ./...
( set -o pipefail ; go test -race -tags "$(GOTAGS)" -v ./... 2>&1 | tee test-race.log )
test-race:
$(MAKE) GOTEST_FLAGS=-race
cover:
go test $(GOFILES) --cover