gotest: add gofmt, govet, golint, gosimple, unconvert, race detector, test coverage in travis
This commit is contained in:
parent
242c656fd6
commit
1aa4452622
@ -5,9 +5,6 @@ go:
|
||||
sudo: false
|
||||
install:
|
||||
- go get -v github.com/roasbeef/btcd # Required for the rpc test package.
|
||||
- go get -v github.com/Masterminds/glide
|
||||
- glide install
|
||||
- go install -v . # Required for the integration tests.
|
||||
script:
|
||||
- export PATH=$PATH:$HOME/gopath/bin
|
||||
- go test -p 1 -v $(go list ./... | grep -v '/vendor/')
|
||||
- ./gotest.sh -l -r -c
|
||||
|
140
gotest.sh
Executable file
140
gotest.sh
Executable file
@ -0,0 +1,140 @@
|
||||
#!/bin/bash
|
||||
# The script does automatic checking on a Go package and its sub-packages, including:
|
||||
# 1. gofmt (http://golang.org/cmd/gofmt/)
|
||||
# 2. golint (https://github.com/golang/lint)
|
||||
# 3. go vet (http://golang.org/cmd/vet)
|
||||
# 4. gosimple (https://github.com/dominikh/go-simple)
|
||||
# 5. unconvert (https://github.com/mdempsky/unconvert)
|
||||
# 6. race detector (http://blog.golang.org/race-detector)
|
||||
# 7. test coverage (http://blog.golang.org/cover)
|
||||
#
|
||||
# gometalinter (github.com/alecthomas/gometalinter) is used to run each static
|
||||
# checker.
|
||||
|
||||
declare GREEN='\033[0;32m'
|
||||
declare NC='\033[0m'
|
||||
print () {
|
||||
echo -e "${GREEN}$1${NC}"
|
||||
}
|
||||
|
||||
# test_with_profile run test coverage on each subdirectories and merge the
|
||||
# coverage profile.
|
||||
test_with_coverage_profile() {
|
||||
print "* Run tests with creating coverage profile:"
|
||||
|
||||
echo "mode: count" > profile.cov
|
||||
|
||||
# Standard go tooling behavior is to ignore dirs with leading underscores.
|
||||
for dir in $(find . -maxdepth 10 \
|
||||
-not -path './.git*' \
|
||||
-not -path '*/_*' \
|
||||
-not -path './cmd*' \
|
||||
-not -path './release*' \
|
||||
-not -path './vendor*' \
|
||||
-type d)
|
||||
do
|
||||
if ls $dir/*.go &> /dev/null; then
|
||||
go test -v -covermode=count -coverprofile=$dir/profile.tmp $dir
|
||||
|
||||
if [ -f $dir/profile.tmp ]; then
|
||||
cat $dir/profile.tmp | tail -n +2 >> profile.cov
|
||||
rm $dir/profile.tmp
|
||||
fi
|
||||
fi
|
||||
done
|
||||
|
||||
if [ "$TRAVIS" == "true" ] ; then
|
||||
print "* Send test coverage to travis server:"
|
||||
# Make sure goveralls is installed and $GOPATH/bin is in your path.
|
||||
if [ ! -x "$(type -p goveralls)" ]; then
|
||||
print "** Install goveralls:"
|
||||
go get github.com/mattn/goveralls
|
||||
fi
|
||||
|
||||
print "** Submit the test coverage result to coveralls.io"
|
||||
goveralls -coverprofile=profile.cov -service=travis-ci
|
||||
fi
|
||||
}
|
||||
|
||||
# test_race_conditions run standard go test without creating coverage
|
||||
# profile but with race condition checks.
|
||||
test_race_conditions() {
|
||||
print "* Run tests with race conditions checks:"
|
||||
|
||||
test_targets=$(go list ./... | grep -v '/vendor/')
|
||||
env GORACE="halt_on_error=1" go test -p 1 -v -race $test_targets
|
||||
}
|
||||
|
||||
# lint_check runs static checks.
|
||||
lint_check() {
|
||||
print "* Run static checks:"
|
||||
|
||||
# Make sure gometalinter is installed and $GOPATH/bin is in your path.
|
||||
if [ ! -x "$(type -p gometalinter)" ]; then
|
||||
print "** Install gometalinter:"
|
||||
go get -v github.com/alecthomas/gometalinter
|
||||
gometalinter --install
|
||||
fi
|
||||
|
||||
# Automatic checks
|
||||
linter_targets=$(glide novendor | grep -v lnrpc)
|
||||
test -z "$(gometalinter --disable-all \
|
||||
--enable=gofmt \
|
||||
--enable=vet \
|
||||
--enable=golint \
|
||||
--enable=gosimple \
|
||||
--enable=unconvert \
|
||||
--line-length=72 \
|
||||
--deadline=4m $linter_targets 2>&1 | grep -v 'ALL_CAPS\|OP_' 2>&1 | tee /dev/stderr)"
|
||||
}
|
||||
|
||||
set -e
|
||||
|
||||
# Read input flags and initialize variables
|
||||
NEED_LINT="false"
|
||||
NEED_COVERAGE="false"
|
||||
NEED_RACE="false"
|
||||
|
||||
while getopts "lrc" flag; do
|
||||
case "${flag}" in
|
||||
l) NEED_LINT="true" ;;
|
||||
r) NEED_RACE="true" ;;
|
||||
c) NEED_COVERAGE="true" ;;
|
||||
*)
|
||||
printf '\nUsage: %s [-l] [-r] [-c], where:\n' $0
|
||||
printf ' -l: include code lint check\n'
|
||||
printf ' -r: run tests with race condition check\n'
|
||||
printf ' -c: run tests with test coverage\n'
|
||||
exit 1 ;;
|
||||
esac
|
||||
done
|
||||
|
||||
# remove the options from the positional parameters
|
||||
shift $(( OPTIND - 1 ))
|
||||
|
||||
# Make sure glide is installed and $GOPATH/bin is in your path.
|
||||
if [ ! -x "$(type -p glide)" ]; then
|
||||
print "* Install glide:"
|
||||
go get -u github.com/Masterminds/glide
|
||||
glide install
|
||||
fi
|
||||
|
||||
# Required for the integration tests
|
||||
print "* Build source:"
|
||||
go install -v . ./cmd/...
|
||||
|
||||
# Lint check is first because we shouldn't run tests on garbage code.
|
||||
if [ "$NEED_LINT" == "true" ]; then
|
||||
lint_check
|
||||
fi
|
||||
|
||||
# Race condition second because we shouldn't check coverage on buggy code.
|
||||
if [ "$NEED_RACE" == "true" ]; then
|
||||
test_race_conditions
|
||||
fi
|
||||
|
||||
# Test coverage is third because in this case code should work properly and
|
||||
# we may calmly send coverage profile (if script is run on travis)
|
||||
if [ "$NEED_COVERAGE" == "true" ]; then
|
||||
test_with_coverage_profile
|
||||
fi
|
Loading…
Reference in New Issue
Block a user