mirror of https://github.com/hashicorp/consul
Merge pull request #8269 from hashicorp/dnephin/ci-add-go-test-race
ci: add 'go test -race'pull/8335/head
commit
e07b20e75a
|
@ -114,7 +114,8 @@ jobs:
|
||||||
PACKAGE_NAMES=$(go list -tags "$GOTAGS" ./... | circleci tests split --split-by=timings --timings-type=classname)
|
PACKAGE_NAMES=$(go list -tags "$GOTAGS" ./... | circleci tests split --split-by=timings --timings-type=classname)
|
||||||
echo "Running $(echo $PACKAGE_NAMES | wc -w) packages"
|
echo "Running $(echo $PACKAGE_NAMES | wc -w) packages"
|
||||||
echo $PACKAGE_NAMES
|
echo $PACKAGE_NAMES
|
||||||
gotestsum --format=short-verbose \
|
gotestsum \
|
||||||
|
--format=short-verbose \
|
||||||
--jsonfile /tmp/jsonfile/go-test-${CIRCLE_NODE_INDEX}.log \
|
--jsonfile /tmp/jsonfile/go-test-${CIRCLE_NODE_INDEX}.log \
|
||||||
--junitfile $TEST_RESULTS_DIR/gotestsum-report.xml -- \
|
--junitfile $TEST_RESULTS_DIR/gotestsum-report.xml -- \
|
||||||
-tags="$GOTAGS" -p 2 \
|
-tags="$GOTAGS" -p 2 \
|
||||||
|
@ -134,6 +135,40 @@ jobs:
|
||||||
# without it.
|
# without it.
|
||||||
command: bash <(curl -s https://codecov.io/bash) -C "$CIRCLE_SHA1"
|
command: bash <(curl -s https://codecov.io/bash) -C "$CIRCLE_SHA1"
|
||||||
|
|
||||||
|
go-test-race:
|
||||||
|
docker:
|
||||||
|
- image: *GOLANG_IMAGE
|
||||||
|
environment:
|
||||||
|
<<: *ENVIRONMENT
|
||||||
|
GOTAGS: "" # No tags for OSS but there are for enterprise
|
||||||
|
# GOMAXPROCS defaults to number of cores on underlying hardware, set
|
||||||
|
# explicitly to avoid OOM issues https://support.circleci.com/hc/en-us/articles/360034684273-common-GoLang-memory-issues
|
||||||
|
GOMAXPROCS: 4
|
||||||
|
# The medium resource class (default) boxes are 2 vCPUs, 4GB RAM
|
||||||
|
# https://circleci.com/docs/2.0/configuration-reference/#docker-executor
|
||||||
|
# but we can run a little over that limit.
|
||||||
|
steps:
|
||||||
|
- checkout
|
||||||
|
- run: *install-gotestsum
|
||||||
|
- run: go mod download
|
||||||
|
- run:
|
||||||
|
name: go test -race
|
||||||
|
command: |
|
||||||
|
mkdir -p $TEST_RESULTS_DIR
|
||||||
|
gotestsum \
|
||||||
|
--format=short-verbose \
|
||||||
|
--junitfile $TEST_RESULTS_DIR/gotestsum-report.xml -- \
|
||||||
|
-tags="$GOTAGS" -p 2 \
|
||||||
|
-race -gcflags=all=-d=checkptr=0 \
|
||||||
|
./agent/{ae,cache,checks,config,pool,proxycfg,router} \
|
||||||
|
./agent/consul/{authmethod/...,autopilot,fsm,state,stream} \
|
||||||
|
./snapshot
|
||||||
|
|
||||||
|
- store_test_results:
|
||||||
|
path: *TEST_RESULTS_DIR
|
||||||
|
- store_artifacts:
|
||||||
|
path: *TEST_RESULTS_DIR
|
||||||
|
|
||||||
# split off a job for the API package since it is separate
|
# split off a job for the API package since it is separate
|
||||||
go-test-api:
|
go-test-api:
|
||||||
docker:
|
docker:
|
||||||
|
@ -660,6 +695,7 @@ workflows:
|
||||||
requires: [dev-build]
|
requires: [dev-build]
|
||||||
- go-test-api:
|
- go-test-api:
|
||||||
requires: [dev-build]
|
requires: [dev-build]
|
||||||
|
- go-test-race: *filter-ignore-non-go-branches
|
||||||
- go-test-sdk: *filter-ignore-non-go-branches
|
- go-test-sdk: *filter-ignore-non-go-branches
|
||||||
|
|
||||||
build-distros:
|
build-distros:
|
||||||
|
|
Loading…
Reference in New Issue