vet: Get it to work on Darwin. (#3452)
This commit is contained in:

committed by
GitHub

parent
71f583e958
commit
09c4b45e16
39
vet.sh
39
vet.sh
@ -1,20 +1,22 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [[ `uname -a` = *"Darwin"* ]]; then
|
|
||||||
echo "It seems you are running on Mac. This script does not work on Mac. See https://github.com/grpc/grpc-go/issues/2047"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
set -ex # Exit on error; debugging enabled.
|
set -ex # Exit on error; debugging enabled.
|
||||||
set -o pipefail # Fail a pipe if any sub-command fails.
|
set -o pipefail # Fail a pipe if any sub-command fails.
|
||||||
|
|
||||||
|
# not makes sure the command passed to it does not exit with a return code of 0.
|
||||||
|
not() {
|
||||||
|
# This is required instead of the earlier (! $COMMAND) because subshells and
|
||||||
|
# pipefail don't work the same on Darwin as in Linux.
|
||||||
|
! "$@"
|
||||||
|
}
|
||||||
|
|
||||||
die() {
|
die() {
|
||||||
echo "$@" >&2
|
echo "$@" >&2
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
fail_on_output() {
|
fail_on_output() {
|
||||||
tee /dev/stderr | (! read)
|
tee /dev/stderr | not read
|
||||||
}
|
}
|
||||||
|
|
||||||
# Check to make sure it's safe to modify the user's git repo.
|
# Check to make sure it's safe to modify the user's git repo.
|
||||||
@ -60,7 +62,7 @@ if [[ "$1" = "-install" ]]; then
|
|||||||
unzip ${PROTOC_FILENAME}
|
unzip ${PROTOC_FILENAME}
|
||||||
bin/protoc --version
|
bin/protoc --version
|
||||||
popd
|
popd
|
||||||
elif ! which protoc > /dev/null; then
|
elif not which protoc > /dev/null; then
|
||||||
die "Please install protoc into your path"
|
die "Please install protoc into your path"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -70,21 +72,21 @@ elif [[ "$#" -ne 0 ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# - Ensure all source files contain a copyright message.
|
# - Ensure all source files contain a copyright message.
|
||||||
(! git grep -L "\(Copyright [0-9]\{4,\} gRPC authors\)\|DO NOT EDIT" -- '*.go')
|
not git grep -L "\(Copyright [0-9]\{4,\} gRPC authors\)\|DO NOT EDIT" -- '*.go'
|
||||||
|
|
||||||
# - Make sure all tests in grpc and grpc/test use leakcheck via Teardown.
|
# - Make sure all tests in grpc and grpc/test use leakcheck via Teardown.
|
||||||
(! grep 'func Test[^(]' *_test.go)
|
not grep 'func Test[^(]' *_test.go
|
||||||
(! grep 'func Test[^(]' test/*.go)
|
not grep 'func Test[^(]' test/*.go
|
||||||
|
|
||||||
# - Do not import x/net/context.
|
# - Do not import x/net/context.
|
||||||
(! git grep -l 'x/net/context' -- "*.go")
|
not git grep -l 'x/net/context' -- "*.go"
|
||||||
|
|
||||||
# - Do not import math/rand for real library code. Use internal/grpcrand for
|
# - Do not import math/rand for real library code. Use internal/grpcrand for
|
||||||
# thread safety.
|
# thread safety.
|
||||||
git grep -l '"math/rand"' -- "*.go" 2>&1 | (! grep -v '^examples\|^stress\|grpcrand\|^benchmark\|wrr_test')
|
git grep -l '"math/rand"' -- "*.go" 2>&1 | not grep -v '^examples\|^stress\|grpcrand\|^benchmark\|wrr_test'
|
||||||
|
|
||||||
# - Ensure all ptypes proto packages are renamed when importing.
|
# - Ensure all ptypes proto packages are renamed when importing.
|
||||||
(! git grep "\(import \|^\s*\)\"github.com/golang/protobuf/ptypes/" -- "*.go")
|
not git grep "\(import \|^\s*\)\"github.com/golang/protobuf/ptypes/" -- "*.go"
|
||||||
|
|
||||||
# - Check imports that are illegal in appengine (until Go 1.11).
|
# - Check imports that are illegal in appengine (until Go 1.11).
|
||||||
# TODO: Remove when we drop Go 1.10 support
|
# TODO: Remove when we drop Go 1.10 support
|
||||||
@ -92,8 +94,8 @@ go list -f {{.Dir}} ./... | xargs go run test/go_vet/vet.go
|
|||||||
|
|
||||||
# - gofmt, goimports, golint (with exceptions for generated code), go vet.
|
# - gofmt, goimports, golint (with exceptions for generated code), go vet.
|
||||||
gofmt -s -d -l . 2>&1 | fail_on_output
|
gofmt -s -d -l . 2>&1 | fail_on_output
|
||||||
goimports -l . 2>&1 | (! grep -vE "(_mock|\.pb)\.go")
|
goimports -l . 2>&1 | not grep -vE "(_mock|\.pb)\.go"
|
||||||
golint ./... 2>&1 | (! grep -vE "(_mock|\.pb)\.go:")
|
golint ./... 2>&1 | not grep -vE "(_mock|\.pb)\.go:"
|
||||||
go vet -all ./...
|
go vet -all ./...
|
||||||
|
|
||||||
misspell -error .
|
misspell -error .
|
||||||
@ -119,9 +121,9 @@ fi
|
|||||||
SC_OUT="$(mktemp)"
|
SC_OUT="$(mktemp)"
|
||||||
staticcheck -go 1.9 -checks 'inherit,-ST1015' ./... > "${SC_OUT}" || true
|
staticcheck -go 1.9 -checks 'inherit,-ST1015' ./... > "${SC_OUT}" || true
|
||||||
# Error if anything other than deprecation warnings are printed.
|
# Error if anything other than deprecation warnings are printed.
|
||||||
(! grep -v "is deprecated:.*SA1019" "${SC_OUT}")
|
not grep -v "is deprecated:.*SA1019" "${SC_OUT}"
|
||||||
# Only ignore the following deprecated types/fields/functions.
|
# Only ignore the following deprecated types/fields/functions.
|
||||||
(! grep -Fv '.HandleResolvedAddrs
|
not grep -Fv '.HandleResolvedAddrs
|
||||||
.HandleSubConnStateChange
|
.HandleSubConnStateChange
|
||||||
.HeaderMap
|
.HeaderMap
|
||||||
.NewAddress
|
.NewAddress
|
||||||
@ -157,4 +159,5 @@ naming.Update
|
|||||||
naming.Watcher
|
naming.Watcher
|
||||||
resolver.Backend
|
resolver.Backend
|
||||||
resolver.GRPCLB' "${SC_OUT}"
|
resolver.GRPCLB' "${SC_OUT}"
|
||||||
)
|
|
||||||
|
echo SUCCESS
|
||||||
|
Reference in New Issue
Block a user