etcd/Makefile

177 lines
5.4 KiB
Makefile
Raw Normal View History

# run from repository root
# Example:
# make build
# make clean
# make docker-clean
# make docker-start
# make docker-kill
# make docker-remove
UNAME := $(shell uname)
XARGS = xargs
ARCH ?= $(shell go env GOARCH)
# -r is only necessary on GNU xargs.
ifeq ($(UNAME), Linux)
XARGS += -r
endif
XARGS += rm -r
.PHONY: build
build:
2022-01-26 14:11:10 +03:00
GO_BUILD_FLAGS="-v" ./scripts/build.sh
./bin/etcd --version
./bin/etcdctl version
./bin/etcdutl version
build_tools:
GO_BUILD_FLAGS="-v" ./scripts/build_tools.sh
clean:
rm -f ./codecov
rm -rf ./covdir
rm -f ./bin/Dockerfile-release*
vendor: Get rid of ./vendor cleanup Updated scripts and documentation to not recommend vendoring. Implemented best practices for tools installation. Performed multiple tests to confirm its not breaking any workflows and has no negative performance impact. Rather see 3x speedup. 1. PASSES="fmt unit integration e2e functional" ./test 2. ./scripts/updatebom.sh 3. ./scripts/updatedep.sh 4. ./scripts/genproto.sh - works - ca be simplified - in follow up PR 5. Installation without explicit GOPATH: ``` % unset GOPATH % [sudo] rm -rf ~/go % git clone https://github.com/etcd-io/etcd.git % time ./build go: downloading google.golang.org/grpc v1.26.0 go: downloading github.com/jonboulle/clockwork v0.1.0 go: downloading github.com/prometheus/client_golang v1.0.0 go: downloading github.com/soheilhy/cmux v0.1.4 go: downloading github.com/gogo/protobuf v1.2.1 go: downloading sigs.k8s.io/yaml v1.1.0 go: downloading golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2 go: downloading github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903 go: downloading go.etcd.io/bbolt v1.3.5 go: downloading go.uber.org/zap v1.15.0 go: downloading golang.org/x/crypto v0.0.0-20191002192127-34f69633bfdc go: downloading github.com/golang/protobuf v1.3.2 go: downloading github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8 go: downloading github.com/beorn7/perks v1.0.0 go: downloading github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4 go: downloading github.com/coreos/go-systemd/v22 v22.0.0 go: downloading gopkg.in/yaml.v2 v2.2.2 go: downloading github.com/coreos/go-semver v0.2.0 go: downloading github.com/sirupsen/logrus v1.4.2 go: downloading golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7 go: downloading github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 go: downloading github.com/google/uuid v1.0.0 go: downloading github.com/modern-go/reflect2 v1.0.1 go: downloading github.com/prometheus/common v0.4.1 go: downloading github.com/spf13/cobra v0.0.3 go: downloading github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 go: downloading github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c go: downloading github.com/spf13/pflag v1.0.1 go: downloading github.com/json-iterator/go v1.1.7 go: downloading github.com/dgrijalva/jwt-go v3.2.0+incompatible go: downloading github.com/google/btree v1.0.0 go: downloading go.uber.org/atomic v1.6.0 go: downloading github.com/prometheus/procfs v0.0.2 go: downloading go.uber.org/multierr v1.5.0 go: downloading github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd go: downloading golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5 go: downloading github.com/grpc-ecosystem/grpc-gateway v1.9.5 go: downloading github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4 go: downloading github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4 go: downloading google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55 go: downloading github.com/matttproud/golang_protobuf_extensions v1.0.1 go: downloading golang.org/x/text v0.3.3 go: downloading github.com/olekukonko/tablewriter v0.0.0-20170122224234-a0225b3f23b5 go: downloading github.com/bgentry/speakeasy v0.1.0 go: downloading gopkg.in/cheggaaa/pb.v1 v1.0.25 go: downloading github.com/urfave/cli v1.20.0 go: downloading github.com/mattn/go-runewidth v0.0.2 ./build 8.22s user 2.31s system 117% cpu 8.961 total ``` Before: ``` % git clone https://github.com/etcd-io/etcd.git && cd etcd && time ./build Cloning into 'etcd'... remote: Enumerating objects: 97872, done. remote: Total 97872 (delta 0), reused 0 (delta 0), pack-reused 97872 Receiving objects: 100% (97872/97872), 58.97 MiB | 19.85 MiB/s, done. Resolving deltas: 100% (63091/63091), done. ./build 34.97s user 4.15s system 236% cpu 16.555 total ``` 6. Rebuild without changes: ``` % time ./build ./build 1.43s user 0.83s system 168% cpu 1.336 total ``` 7. Instantation of vendor directory (assuming ./build loaded them to $GOPATH/pkg): ``` time go mod vendor go: downloading github.com/inconshreveable/mousetrap v1.0.0 go: downloading github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa go: downloading github.com/creack/pty v1.1.11 go: downloading github.com/etcd-io/gofail v0.0.0-20190801230047-ad7f989257ca go: downloading github.com/konsorten/go-windows-terminal-sequences v1.0.1 go mod vendor 0.51s user 0.44s system 110% cpu 0.861 total ``` 8. Fresh instantation of vendor: ``` % rm -rf vendor % [sudo] rm -rf ~/go % time go mod vendor go: downloading github.com/coreos/go-systemd/v22 v22.0.0 go: downloading github.com/spf13/cobra v0.0.3 go: downloading github.com/prometheus/client_golang v1.0.0 go: downloading golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7 go: downloading github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4 go: downloading github.com/gogo/protobuf v1.2.1 go: downloading sigs.k8s.io/yaml v1.1.0 go: downloading google.golang.org/grpc v1.26.0 go: downloading github.com/urfave/cli v1.20.0 go: downloading go.uber.org/zap v1.15.0 go: downloading github.com/spf13/pflag v1.0.1 go: downloading github.com/soheilhy/cmux v0.1.4 go: downloading github.com/json-iterator/go v1.1.7 go: downloading github.com/coreos/go-semver v0.2.0 go: downloading github.com/prometheus/common v0.4.1 go: downloading github.com/prometheus/procfs v0.0.2 go: downloading go.uber.org/atomic v1.6.0 go: downloading github.com/olekukonko/tablewriter v0.0.0-20170122224234-a0225b3f23b5 go: downloading github.com/golang/protobuf v1.3.2 go: downloading github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa go: downloading github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4 go: downloading github.com/modern-go/reflect2 v1.0.1 go: downloading github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd go: downloading go.uber.org/multierr v1.5.0 go: downloading github.com/creack/pty v1.1.11 go: downloading github.com/mattn/go-runewidth v0.0.2 go: downloading github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 go: downloading golang.org/x/crypto v0.0.0-20191002192127-34f69633bfdc go: downloading golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5 go: downloading github.com/jonboulle/clockwork v0.1.0 go: downloading gopkg.in/yaml.v2 v2.2.2 go: downloading github.com/etcd-io/gofail v0.0.0-20190801230047-ad7f989257ca go: downloading github.com/grpc-ecosystem/grpc-gateway v1.9.5 go: downloading github.com/google/btree v1.0.0 go: downloading google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55 go: downloading github.com/beorn7/perks v1.0.0 go: downloading github.com/dgrijalva/jwt-go v3.2.0+incompatible go: downloading github.com/google/uuid v1.0.0 go: downloading golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2 go: downloading github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8 go: downloading go.etcd.io/bbolt v1.3.5 go: downloading golang.org/x/text v0.3.3 go: downloading gopkg.in/cheggaaa/pb.v1 v1.0.25 go: downloading github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 go: downloading github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4 go: downloading github.com/inconshreveable/mousetrap v1.0.0 go: downloading github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c go: downloading github.com/matttproud/golang_protobuf_extensions v1.0.1 go: downloading github.com/bgentry/speakeasy v0.1.0 go: downloading github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903 go: downloading github.com/sirupsen/logrus v1.4.2 go: downloading github.com/konsorten/go-windows-terminal-sequences v1.0.1 go mod vendor 3.62s user 1.30s system 127% cpu 3.854 total ``` 9. Size of the repository - before: 39M, after: 18M Before: ``` % time git clone https://github.com/etcd-io/etcd.git Cloning into 'etcd'... remote: Enumerating objects: 97872, done. remote: Total 97872 (delta 0), reused 0 (delta 0), pack-reused 97872 Receiving objects: 100% (97872/97872), 58.97 MiB | 20.53 MiB/s, done. Resolving deltas: 100% (63091/63091), done. git clone https://github.com/etcd-io/etcd.git 4.66s user 1.02s system 93% cpu 6.068 total % du -h --exclude .git -d 1 944K ./clientv3 108K ./etcdmain 5.4M ./Documentation 384K ./security 384K ./mvcc 28K ./.github 8.0K ./version 144K ./contrib 240K ./proxy 2.5M ./etcdserver 112K ./embed 536K ./integration 332K ./tools 116K ./lease 108K ./logos 896K ./tests 960K ./raft 216K ./client 52K ./scripts 100K ./hack 464K ./etcdctl 3.0M ./pkg 620K ./functional 136K ./wal 152K ./auth 21M ./vendor 39M ``` After: ``` % time git clone https://github.com/ptabor/etcd.git -b 20200908-no-vendor Cloning into 'etcd'... remote: Enumerating objects: 38, done. remote: Counting objects: 100% (38/38), done. remote: Compressing objects: 100% (37/37), done. remote: Total 98489 (delta 10), reused 8 (delta 1), pack-reused 98451 Receiving objects: 100% (98489/98489), 59.23 MiB | 21.26 MiB/s, done. Resolving deltas: 100% (63572/63572), done. git clone https://github.com/ptabor/etcd.git -b 20200908-no-vendor 5.56s user 1.05s system 105% cpu 6.260 total % du -h --exclude .git -d 1 944K ./clientv3 108K ./etcdmain 5.4M ./Documentation 384K ./security 384K ./mvcc 28K ./.github 8.0K ./version 144K ./contrib 240K ./proxy 2.5M ./etcdserver 112K ./embed 536K ./integration 332K ./tools 116K ./lease 108K ./logos 896K ./tests 960K ./raft 216K ./client 56K ./scripts 100K ./hack 464K ./etcdctl 3.0M ./pkg 620K ./functional 136K ./wal 152K ./auth 19M . ```
2020-09-09 17:12:31 +03:00
rm -rf ./bin/etcd*
rm -rf ./default.etcd
rm -rf ./tests/e2e/default.etcd
rm -rf ./release
rm -rf ./coverage/*.err ./coverage/*.out
rm -rf ./tests/e2e/default.proxy
find ./ -name "127.0.0.1:*" -o -name "localhost:*" -o -name "*.log" -o -name "agent-*" -o -name "*.coverprofile" -o -name "testname-proxy-*" | $(XARGS)
2022-03-22 01:55:38 +03:00
GO_VERSION ?= 1.17.8
ETCD_VERSION ?= $(shell git rev-parse --short HEAD || echo "GitNotFound")
TEST_SUFFIX = $(shell date +%s | base64 | head -c 15)
TEST_OPTS ?= PASSES='unit'
TMP_DIR_MOUNT_FLAG = --tmpfs=/tmp:exec
ifdef HOST_TMP_DIR
TMP_DIR_MOUNT_FLAG = --mount type=bind,source=$(HOST_TMP_DIR),destination=/tmp
endif
TMP_DOCKERFILE:=$(shell mktemp)
# Example:
# GO_VERSION=1.14.3 make build-docker-test
# make build-docker-test
#
# gcloud auth configure-docker
# GO_VERSION=1.14.3 make push-docker-test
# make push-docker-test
#
# gsutil -m acl ch -u allUsers:R -r gs://artifacts.etcd-development.appspot.com
# make pull-docker-test
build-docker-test:
$(info GO_VERSION: $(GO_VERSION))
@sed 's|REPLACE_ME_GO_VERSION|$(GO_VERSION)|g' ./tests/Dockerfile > $(TMP_DOCKERFILE)
docker build \
--network=host \
--tag gcr.io/etcd-development/etcd-test:go$(GO_VERSION) \
--file $(TMP_DOCKERFILE) .
push-docker-test:
$(info GO_VERSION: $(GO_VERSION))
docker push gcr.io/etcd-development/etcd-test:go$(GO_VERSION)
pull-docker-test:
$(info GO_VERSION: $(GO_VERSION))
docker pull gcr.io/etcd-development/etcd-test:go$(GO_VERSION)
# Example:
#
# Local machine:
# TEST_OPTS="PASSES='fmt'" make test
# TEST_OPTS="PASSES='fmt bom dep build unit'" make test
# TEST_OPTS="PASSES='build unit release integration_e2e functional'" make test
# TEST_OPTS="PASSES='build grpcproxy'" make test
#
# grpc-proxy tests:
# TEST_OPTS="PASSES='build grpcproxy'" make test
# HOST_TMP_DIR=/tmp TEST_OPTS="PASSES='build grpcproxy'" make test
.PHONY: test
test:
$(info TEST_OPTS: $(TEST_OPTS))
$(info log-file: test-$(TEST_SUFFIX).log)
$(TEST_OPTS) OUTPUT_FILE="test-$(TEST_SUFFIX).log" ./scripts/test.sh
update makefile for test egrep add 'FAIL:' to egrep ```shell [root@LF-136-9 etcd]# egrep "(--- FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-MTYyNjIyOTc0MQo.log [root@LF-136-9 etcd]# egrep "(--- FAIL:|FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-MTYyNjIyOTc0MQo.log ok go.etcd.io/etcd/server/v3/auth 3.247s ok go.etcd.io/etcd/server/v3/config 0.047s ok go.etcd.io/etcd/server/v3/datadir 0.035s ok go.etcd.io/etcd/server/v3/embed 1.944s ok go.etcd.io/etcd/server/v3/etcdmain 0.326s FAIL go.etcd.io/etcd/server/v3/etcdserver [build failed] ? go.etcd.io/etcd/server/v3/etcdserver/api [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/etcdhttp 0.110s ok go.etcd.io/etcd/server/v3/etcdserver/api/membership 0.479s ok go.etcd.io/etcd/server/v3/etcdserver/api/rafthttp 0.251s ok go.etcd.io/etcd/server/v3/etcdserver/api/snap 0.045s ? go.etcd.io/etcd/server/v3/etcdserver/api/snap/snappb [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v2auth 1.470s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2discovery 0.088s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2error 0.034s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2http 0.128s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2http/httptypes 0.033s ? go.etcd.io/etcd/server/v3/etcdserver/api/v2stats [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v2store 0.068s ? go.etcd.io/etcd/server/v3/etcdserver/api/v2v3 [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3alarm [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3client [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v3compactor 1.793s ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election/v3electionpb [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election/v3electionpb/gw [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock/v3lockpb [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock/v3lockpb/gw [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v3rpc 0.089s ok go.etcd.io/etcd/server/v3/etcdserver/cindex 0.045s ok go.etcd.io/etcd/server/v3/lease 3.324s ok go.etcd.io/etcd/server/v3/lease/leasehttp 2.096s ? go.etcd.io/etcd/server/v3/lease/leasepb [no test files] ? go.etcd.io/etcd/server/v3/mock/mockstorage [no test files] ? go.etcd.io/etcd/server/v3/mock/mockstore [no test files] ? go.etcd.io/etcd/server/v3/mock/mockwait [no test files] ok go.etcd.io/etcd/server/v3/mvcc 8.805s ok go.etcd.io/etcd/server/v3/mvcc/backend 1.983s ? go.etcd.io/etcd/server/v3/mvcc/backend/testing [no test files] ? go.etcd.io/etcd/server/v3/mvcc/buckets [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy/adapter [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy/cache [no test files] ok go.etcd.io/etcd/server/v3/proxy/httpproxy 0.046s ok go.etcd.io/etcd/server/v3/proxy/tcpproxy 0.035s ? go.etcd.io/etcd/server/v3/verify [no test files] ok go.etcd.io/etcd/server/v3/wal 0.513s ok go.etcd.io/etcd/server/v3/wal/walpb 0.045s FAIL FAIL: (code:2): % (cd server && env go test -short -timeout=3m --race --cpu=16 ./...) FAIL: 'unit' failed at Wed Jul 14 10:29:37 CST 2021 ```
2021-07-14 06:21:54 +03:00
! egrep "(--- FAIL:|FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-$(TEST_SUFFIX).log
test-smoke:
$(info log-file: test-$(TEST_SUFFIX).log)
PASSES="fmt build unit" OUTPUT_FILE="test-$(TEST_SUFFIX).log" ./scripts/test.sh
test-full:
$(info log-file: test-$(TEST_SUFFIX).log)
PASSES="fmt build release unit integration functional e2e grpcproxy" OUTPUT_FILE="test-$(TEST_SUFFIX).log" ./scripts/test.sh
ensure-docker-test-image-exists:
make pull-docker-test || ( echo "WARNING: Container Image not found in registry, building locally"; make build-docker-test )
docker-test: ensure-docker-test-image-exists
$(info GO_VERSION: $(GO_VERSION))
$(info ETCD_VERSION: $(ETCD_VERSION))
$(info TEST_OPTS: $(TEST_OPTS))
$(info log-file: test-$(TEST_SUFFIX).log)
$(info HOST_TMP_DIR: $(HOST_TMP_DIR))
$(info TMP_DIR_MOUNT_FLAG: $(TMP_DIR_MOUNT_FLAG))
docker run \
--rm \
$(TMP_DIR_MOUNT_FLAG) \
--mount type=bind,source=`pwd`,destination=/go/src/go.etcd.io/etcd \
gcr.io/etcd-development/etcd-test:go$(GO_VERSION) \
/bin/bash -c "$(TEST_OPTS) OUTPUT_FILE='test-$(TEST_SUFFIX).log' ./scripts/test.sh"
update makefile for test egrep add 'FAIL:' to egrep ```shell [root@LF-136-9 etcd]# egrep "(--- FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-MTYyNjIyOTc0MQo.log [root@LF-136-9 etcd]# egrep "(--- FAIL:|FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-MTYyNjIyOTc0MQo.log ok go.etcd.io/etcd/server/v3/auth 3.247s ok go.etcd.io/etcd/server/v3/config 0.047s ok go.etcd.io/etcd/server/v3/datadir 0.035s ok go.etcd.io/etcd/server/v3/embed 1.944s ok go.etcd.io/etcd/server/v3/etcdmain 0.326s FAIL go.etcd.io/etcd/server/v3/etcdserver [build failed] ? go.etcd.io/etcd/server/v3/etcdserver/api [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/etcdhttp 0.110s ok go.etcd.io/etcd/server/v3/etcdserver/api/membership 0.479s ok go.etcd.io/etcd/server/v3/etcdserver/api/rafthttp 0.251s ok go.etcd.io/etcd/server/v3/etcdserver/api/snap 0.045s ? go.etcd.io/etcd/server/v3/etcdserver/api/snap/snappb [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v2auth 1.470s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2discovery 0.088s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2error 0.034s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2http 0.128s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2http/httptypes 0.033s ? go.etcd.io/etcd/server/v3/etcdserver/api/v2stats [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v2store 0.068s ? go.etcd.io/etcd/server/v3/etcdserver/api/v2v3 [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3alarm [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3client [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v3compactor 1.793s ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election/v3electionpb [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election/v3electionpb/gw [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock/v3lockpb [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock/v3lockpb/gw [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v3rpc 0.089s ok go.etcd.io/etcd/server/v3/etcdserver/cindex 0.045s ok go.etcd.io/etcd/server/v3/lease 3.324s ok go.etcd.io/etcd/server/v3/lease/leasehttp 2.096s ? go.etcd.io/etcd/server/v3/lease/leasepb [no test files] ? go.etcd.io/etcd/server/v3/mock/mockstorage [no test files] ? go.etcd.io/etcd/server/v3/mock/mockstore [no test files] ? go.etcd.io/etcd/server/v3/mock/mockwait [no test files] ok go.etcd.io/etcd/server/v3/mvcc 8.805s ok go.etcd.io/etcd/server/v3/mvcc/backend 1.983s ? go.etcd.io/etcd/server/v3/mvcc/backend/testing [no test files] ? go.etcd.io/etcd/server/v3/mvcc/buckets [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy/adapter [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy/cache [no test files] ok go.etcd.io/etcd/server/v3/proxy/httpproxy 0.046s ok go.etcd.io/etcd/server/v3/proxy/tcpproxy 0.035s ? go.etcd.io/etcd/server/v3/verify [no test files] ok go.etcd.io/etcd/server/v3/wal 0.513s ok go.etcd.io/etcd/server/v3/wal/walpb 0.045s FAIL FAIL: (code:2): % (cd server && env go test -short -timeout=3m --race --cpu=16 ./...) FAIL: 'unit' failed at Wed Jul 14 10:29:37 CST 2021 ```
2021-07-14 06:21:54 +03:00
! egrep "(--- FAIL:|FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-$(TEST_SUFFIX).log
docker-test-coverage:
$(info GO_VERSION: $(GO_VERSION))
$(info ETCD_VERSION: $(ETCD_VERSION))
$(info log-file: docker-test-coverage-$(TEST_SUFFIX).log)
$(info HOST_TMP_DIR: $(HOST_TMP_DIR))
$(info TMP_DIR_MOUNT_FLAG: $(TMP_DIR_MOUNT_FLAG))
docker run \
--rm \
$(TMP_DIR_MOUNT_FLAG) \
--mount type=bind,source=`pwd`,destination=/go/src/go.etcd.io/etcd \
gcr.io/etcd-development/etcd-test:go$(GO_VERSION) \
/bin/bash ./scripts/codecov_upload.sh docker-test-coverage-$(TEST_SUFFIX).log \
update makefile for test egrep add 'FAIL:' to egrep ```shell [root@LF-136-9 etcd]# egrep "(--- FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-MTYyNjIyOTc0MQo.log [root@LF-136-9 etcd]# egrep "(--- FAIL:|FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 test-MTYyNjIyOTc0MQo.log ok go.etcd.io/etcd/server/v3/auth 3.247s ok go.etcd.io/etcd/server/v3/config 0.047s ok go.etcd.io/etcd/server/v3/datadir 0.035s ok go.etcd.io/etcd/server/v3/embed 1.944s ok go.etcd.io/etcd/server/v3/etcdmain 0.326s FAIL go.etcd.io/etcd/server/v3/etcdserver [build failed] ? go.etcd.io/etcd/server/v3/etcdserver/api [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/etcdhttp 0.110s ok go.etcd.io/etcd/server/v3/etcdserver/api/membership 0.479s ok go.etcd.io/etcd/server/v3/etcdserver/api/rafthttp 0.251s ok go.etcd.io/etcd/server/v3/etcdserver/api/snap 0.045s ? go.etcd.io/etcd/server/v3/etcdserver/api/snap/snappb [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v2auth 1.470s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2discovery 0.088s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2error 0.034s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2http 0.128s ok go.etcd.io/etcd/server/v3/etcdserver/api/v2http/httptypes 0.033s ? go.etcd.io/etcd/server/v3/etcdserver/api/v2stats [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v2store 0.068s ? go.etcd.io/etcd/server/v3/etcdserver/api/v2v3 [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3alarm [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3client [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v3compactor 1.793s ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election/v3electionpb [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3election/v3electionpb/gw [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock/v3lockpb [no test files] ? go.etcd.io/etcd/server/v3/etcdserver/api/v3lock/v3lockpb/gw [no test files] ok go.etcd.io/etcd/server/v3/etcdserver/api/v3rpc 0.089s ok go.etcd.io/etcd/server/v3/etcdserver/cindex 0.045s ok go.etcd.io/etcd/server/v3/lease 3.324s ok go.etcd.io/etcd/server/v3/lease/leasehttp 2.096s ? go.etcd.io/etcd/server/v3/lease/leasepb [no test files] ? go.etcd.io/etcd/server/v3/mock/mockstorage [no test files] ? go.etcd.io/etcd/server/v3/mock/mockstore [no test files] ? go.etcd.io/etcd/server/v3/mock/mockwait [no test files] ok go.etcd.io/etcd/server/v3/mvcc 8.805s ok go.etcd.io/etcd/server/v3/mvcc/backend 1.983s ? go.etcd.io/etcd/server/v3/mvcc/backend/testing [no test files] ? go.etcd.io/etcd/server/v3/mvcc/buckets [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy/adapter [no test files] ? go.etcd.io/etcd/server/v3/proxy/grpcproxy/cache [no test files] ok go.etcd.io/etcd/server/v3/proxy/httpproxy 0.046s ok go.etcd.io/etcd/server/v3/proxy/tcpproxy 0.035s ? go.etcd.io/etcd/server/v3/verify [no test files] ok go.etcd.io/etcd/server/v3/wal 0.513s ok go.etcd.io/etcd/server/v3/wal/walpb 0.045s FAIL FAIL: (code:2): % (cd server && env go test -short -timeout=3m --race --cpu=16 ./...) FAIL: 'unit' failed at Wed Jul 14 10:29:37 CST 2021 ```
2021-07-14 06:21:54 +03:00
! egrep "(--- FAIL:|FAIL:|DATA RACE|panic: test timed out|appears to have leaked)" -B50 -A10 docker-test-coverage-$(TEST_SUFFIX).log
# Example:
# ETCD_VERSION=v3-test make build-docker-release-main
# ETCD_VERSION=v3-test make push-docker-release-main
# gsutil -m acl ch -u allUsers:R -r gs://artifacts.etcd-development.appspot.com
build-docker-release-main:
$(info ETCD_VERSION: $(ETCD_VERSION))
cp ./Dockerfile-release.$(ARCH) ./bin/Dockerfile-release.$(ARCH)
docker build \
--network=host \
--tag gcr.io/etcd-development/etcd:$(ETCD_VERSION) \
--file ./bin/Dockerfile-release.$(ARCH) \
./bin
rm -f ./bin/Dockerfile-release.$(ARCH)
docker run \
--rm \
gcr.io/etcd-development/etcd:$(ETCD_VERSION) \
/bin/sh -c "/usr/local/bin/etcd --version && /usr/local/bin/etcdctl version && /usr/local/bin/etcdutl version"
push-docker-release-main:
$(info ETCD_VERSION: $(ETCD_VERSION))
docker push gcr.io/etcd-development/etcd:$(ETCD_VERSION)
# Recursively analyzes the tree:
lint:
golangci-lint run
# Fixes found issues, if supported by the linter:
lint-fix:
golangci-lint run --fix