#!/usr/bin/make -f BUILDDIR ?= $(CURDIR)/build BUILD_TAGS?=tendermint # If building a release, please checkout the version tag to get the correct version setting ifneq ($(shell git symbolic-ref -q --short HEAD),) VERSION := unreleased-$(shell git symbolic-ref -q --short HEAD)-$(shell git rev-parse HEAD) else VERSION := $(shell git describe) endif LD_FLAGS = -X github.com/tendermint/tendermint/version.TMVersion=$(VERSION) BUILD_FLAGS = -mod=readonly -ldflags "$(LD_FLAGS)" CGO_ENABLED ?= 0 # handle nostrip ifeq (,$(findstring nostrip,$(TENDERMINT_BUILD_OPTIONS))) BUILD_FLAGS += -trimpath LD_FLAGS += -s -w endif # handle race ifeq (race,$(findstring race,$(TENDERMINT_BUILD_OPTIONS))) CGO_ENABLED=1 BUILD_FLAGS += -race endif # handle cleveldb ifeq (cleveldb,$(findstring cleveldb,$(TENDERMINT_BUILD_OPTIONS))) CGO_ENABLED=1 BUILD_TAGS += cleveldb endif # handle badgerdb ifeq (badgerdb,$(findstring badgerdb,$(TENDERMINT_BUILD_OPTIONS))) BUILD_TAGS += badgerdb endif # handle rocksdb ifeq (rocksdb,$(findstring rocksdb,$(TENDERMINT_BUILD_OPTIONS))) CGO_ENABLED=1 BUILD_TAGS += rocksdb endif # handle boltdb ifeq (boltdb,$(findstring boltdb,$(TENDERMINT_BUILD_OPTIONS))) BUILD_TAGS += boltdb endif # allow users to pass additional flags via the conventional LDFLAGS variable LD_FLAGS += $(LDFLAGS) all: check build test install .PHONY: all include test/Makefile ############################################################################### ### Build Tendermint ### ############################################################################### build: $(BUILDDIR)/ CGO_ENABLED=$(CGO_ENABLED) go build $(BUILD_FLAGS) -tags '$(BUILD_TAGS)' -o $(BUILDDIR)/ ./cmd/tendermint/ .PHONY: build install: CGO_ENABLED=$(CGO_ENABLED) go install $(BUILD_FLAGS) -tags $(BUILD_TAGS) ./cmd/tendermint .PHONY: install $(BUILDDIR)/: mkdir -p $@ ############################################################################### ### Protobuf ### ############################################################################### check-proto-gen-deps: ifeq (,$(shell which protoc)) $(error "Protocol buffers compiler protoc is required. See https://github.com/protocolbuffers/protobuf/#protocol-compiler-installation for installation instructions.") endif ifeq (,$(shell which protoc-gen-gogofaster)) $(error "gogofaster plugin for protoc is required. Run 'go install github.com/gogo/protobuf/protoc-gen-gogofaster@latest' to install") endif .PHONY: check-proto-gen-deps proto-gen: check-proto-gen-deps @echo "Generating Protobuf files" @./scripts/proto-gen.sh .PHONY: proto-gen check-proto-lint-deps: ifeq (,$(shell which buf)) $(error "buf is required for Protobuf linting. See https://docs.buf.build/installation for installation instructions.") endif .PHONY: check-proto-lint-deps # The proto-lint and proto-check-breaking targets are provided for convenience # and for local execution only. # # For CI-based checks, see ./.github/workflows/proto-check.yml proto-lint: check-proto-lint-deps @echo "Linting Protobuf files" buf lint .PHONY: proto-lint proto-check-breaking: check-proto-lint-deps @echo "Checking for breaking changes in Protobuf files" buf breaking .PHONY: proto-check-breaking ############################################################################### ### Build ABCI ### ############################################################################### build_abci: @go build -mod=readonly -i ./abci/cmd/... .PHONY: build_abci install_abci: @go install -mod=readonly ./abci/cmd/... .PHONY: install_abci ############################################################################### ### Privval Server ### ############################################################################### build_privval_server: @go build -mod=readonly -o $(BUILDDIR)/ -i ./cmd/priv_val_server/... .PHONY: build_privval_server generate_test_cert: # generate self signing ceritificate authority @certstrap init --common-name "root CA" --expires "20 years" # generate server cerificate @certstrap request-cert -cn server -ip 127.0.0.1 # self-sign server cerificate with rootCA @certstrap sign server --CA "root CA" # generate client cerificate @certstrap request-cert -cn client -ip 127.0.0.1 # self-sign client cerificate with rootCA @certstrap sign client --CA "root CA" .PHONY: generate_test_cert ############################################################################### ### Distribution ### ############################################################################### # dist builds binaries for all platforms and packages them for distribution # TODO add abci to these scripts dist: @BUILD_TAGS=$(BUILD_TAGS) sh -c "'$(CURDIR)/scripts/dist.sh'" .PHONY: dist go-mod-cache: go.sum @echo "--> Download go modules to local cache" @go mod download .PHONY: go-mod-cache go.sum: go.mod @echo "--> Ensure dependencies have not been modified" @go mod verify @go mod tidy draw_deps: @# requires brew install graphviz or apt-get install graphviz go get github.com/RobotsAndPencils/goviz @goviz -i github.com/tendermint/tendermint/cmd/tendermint -d 3 | dot -Tpng -o dependency-graph.png .PHONY: draw_deps get_deps_bin_size: @# Copy of build recipe with additional flags to perform binary size analysis $(eval $(shell go build -work -a $(BUILD_FLAGS) -tags $(BUILD_TAGS) -o $(BUILDDIR)/ ./cmd/tendermint/ 2>&1)) @find $(WORK) -type f -name "*.a" | xargs -I{} du -hxs "{}" | sort -rh | sed -e s:${WORK}/::g > deps_bin_size.log @echo "Results can be found here: $(CURDIR)/deps_bin_size.log" .PHONY: get_deps_bin_size ############################################################################### ### Libs ### ############################################################################### # generates certificates for TLS testing in remotedb and RPC server gen_certs: clean_certs certstrap init --common-name "tendermint.com" --passphrase "" certstrap request-cert --common-name "server" -ip "127.0.0.1" --passphrase "" certstrap sign "server" --CA "tendermint.com" --passphrase "" mv out/server.crt rpc/jsonrpc/server/test.crt mv out/server.key rpc/jsonrpc/server/test.key rm -rf out .PHONY: gen_certs # deletes generated certificates clean_certs: rm -f rpc/jsonrpc/server/test.crt rm -f rpc/jsonrpc/server/test.key .PHONY: clean_certs ############################################################################### ### Formatting, linting, and vetting ### ############################################################################### format: find . -name '*.go' -type f -not -path "*.git*" -not -name '*.pb.go' -not -name '*pb_test.go' | xargs gofmt -w -s find . -name '*.go' -type f -not -path "*.git*" -not -name '*.pb.go' -not -name '*pb_test.go' | xargs goimports -w -local github.com/tendermint/tendermint .PHONY: format lint: @echo "--> Running linter" go run github.com/golangci/golangci-lint/cmd/golangci-lint run .PHONY: lint DESTINATION = ./index.html.md ############################################################################### ### Documentation ### ############################################################################### # todo remove once tendermint.com DNS is solved build-docs: @cd docs && \ while read -r branch path_prefix; do \ (git checkout $${branch} && npm ci && VUEPRESS_BASE="/$${path_prefix}/" npm run build) ; \ mkdir -p ~/output/$${path_prefix} ; \ cp -r .vuepress/dist/* ~/output/$${path_prefix}/ ; \ cp ~/output/$${path_prefix}/index.html ~/output ; \ done < versions ; .PHONY: build-docs ############################################################################### ### Docker image ### ############################################################################### build-docker: build-linux cp $(BUILDDIR)/tendermint DOCKER/tendermint docker build --label=tendermint --tag="tendermint/tendermint" -f DOCKER/Dockerfile . rm -rf DOCKER/tendermint .PHONY: build-docker ############################################################################### ### Mocks ### ############################################################################### mockery: go generate -run="./scripts/mockery_generate.sh" ./... .PHONY: mockery ############################################################################### ### Local testnet using docker ### ############################################################################### # Build linux binary on other platforms build-linux: GOOS=linux GOARCH=amd64 $(MAKE) build .PHONY: build-linux build-docker-localnode: @cd networks/local && make .PHONY: build-docker-localnode # Runs `make build TENDERMINT_BUILD_OPTIONS=cleveldb` from within an Amazon # Linux (v2)-based Docker build container in order to build an Amazon # Linux-compatible binary. Produces a compatible binary at ./build/tendermint build_c-amazonlinux: $(MAKE) -C ./DOCKER build_amazonlinux_buildimage docker run --rm -it -v `pwd`:/tendermint tendermint/tendermint:build_c-amazonlinux .PHONY: build_c-amazonlinux # Run a 4-node testnet locally localnet-start: localnet-stop build-docker-localnode @if ! [ -f build/node0/config/genesis.json ]; then docker run --rm -v $(CURDIR)/build:/tendermint:Z tendermint/localnode testnet --config /etc/tendermint/config-template.toml --o . --starting-ip-address 192.167.10.2; fi docker-compose up .PHONY: localnet-start # Stop testnet localnet-stop: docker-compose down .PHONY: localnet-stop # Build hooks for dredd, to skip or add information on some steps build-contract-tests-hooks: ifeq ($(OS),Windows_NT) go build -mod=readonly $(BUILD_FLAGS) -o build/contract_tests.exe ./cmd/contract_tests else go build -mod=readonly $(BUILD_FLAGS) -o build/contract_tests ./cmd/contract_tests endif .PHONY: build-contract-tests-hooks # Run a nodejs tool to test endpoints against a localnet # The command takes care of starting and stopping the network # prerequisits: build-contract-tests-hooks build-linux # the two build commands were not added to let this command run from generic containers or machines. # The binaries should be built beforehand contract-tests: dredd .PHONY: contract-tests clean: rm -rf $(CURDIR)/artifacts/ $(BUILDDIR)/ build-reproducible: docker rm latest-build || true docker run --volume=$(CURDIR):/sources:ro \ --env TARGET_PLATFORMS='linux/amd64 linux/arm64 darwin/amd64 windows/amd64' \ --env APP=tendermint \ --env COMMIT=$(shell git rev-parse --short=8 HEAD) \ --env VERSION=$(shell git describe --tags) \ --name latest-build cosmossdk/rbuilder:latest docker cp -a latest-build:/home/builder/artifacts/ $(CURDIR)/ .PHONY: build-reproducible # Implements test splitting and running. This is pulled directly from # the github action workflows for better local reproducibility. GO_TEST_FILES != find $(CURDIR) -name "*_test.go" # default to four splits by default NUM_SPLIT ?= 4 $(BUILDDIR): mkdir -p $@ # The format statement filters out all packages that don't have tests. # Note we need to check for both in-package tests (.TestGoFiles) and # out-of-package tests (.XTestGoFiles). $(BUILDDIR)/packages.txt:$(GO_TEST_FILES) $(BUILDDIR) go list -f "{{ if (or .TestGoFiles .XTestGoFiles) }}{{ .ImportPath }}{{ end }}" ./... | sort > $@ split-test-packages:$(BUILDDIR)/packages.txt split -d -n l/$(NUM_SPLIT) $< $<. test-group-%:split-test-packages cat $(BUILDDIR)/packages.txt.$* | xargs go test -mod=readonly -timeout=5m -race -coverprofile=$(BUILDDIR)/$*.profile.out