You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

307 lines
11 KiB

[RPC] Static swagger (#3880) * manually swagging Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * three definitions with polymorphism Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * added blockchain and block Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * low quality generation, commit, block_response and validators Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * genesis and consensus states endpoints Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * fix indentation Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * consensus parameters Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * fix indentation Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add height to consensus parameters endpoint Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * unconfirmed_txs and num_unconfirmed_txs Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add missing query parameter Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add ABCI queries Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * added index document for swagger documentation Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add missing routes Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * contract tests added on CCI Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * contract tests job should be in the test suite Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * simplify requirements to test Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * typo Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * build is a prerequisite to start localnet Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * reduce nodejs size, move goodman to get_tools, add docs, fix comments Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * Update scripts/get_tools.sh That's cleaner, thanks! Co-Authored-By: Anton Kaliaev <anton.kalyaev@gmail.com> * xz not supported by cci image, let's keep it simple Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * REMOVE-indirect debug of CCI paths Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * dirty experiment, volume is empty but binary has been produced Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * dirty experiment, volume is empty but binary has been produced Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * dirty experiment going on Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * locally works, CCI have difficulties with second layaer containers volumes Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * restore experiment, use machine instead of docker for contract tests Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * simplify a bit Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * rollback on machine golang Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * Document the changes Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * Changelog Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * comments Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com>
5 years ago
[RPC] Static swagger (#3880) * manually swagging Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * three definitions with polymorphism Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * added blockchain and block Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * low quality generation, commit, block_response and validators Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * genesis and consensus states endpoints Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * fix indentation Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * consensus parameters Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * fix indentation Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add height to consensus parameters endpoint Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * unconfirmed_txs and num_unconfirmed_txs Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add missing query parameter Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add ABCI queries Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * added index document for swagger documentation Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * add missing routes Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * contract tests added on CCI Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * contract tests job should be in the test suite Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * simplify requirements to test Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * typo Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * build is a prerequisite to start localnet Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * reduce nodejs size, move goodman to get_tools, add docs, fix comments Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * Update scripts/get_tools.sh That's cleaner, thanks! Co-Authored-By: Anton Kaliaev <anton.kalyaev@gmail.com> * xz not supported by cci image, let's keep it simple Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * REMOVE-indirect debug of CCI paths Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * dirty experiment, volume is empty but binary has been produced Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * dirty experiment, volume is empty but binary has been produced Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * dirty experiment going on Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * locally works, CCI have difficulties with second layaer containers volumes Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * restore experiment, use machine instead of docker for contract tests Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * simplify a bit Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * rollback on machine golang Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * Document the changes Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * Changelog Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com> * comments Signed-off-by: Karoly Albert Szabo <szabo.karoly.a@gmail.com>
5 years ago
  1. #!/usr/bin/make -f
  2. PACKAGES=$(shell go list ./...)
  3. BUILDDIR ?= $(CURDIR)/build
  4. BUILD_TAGS?=tendermint
  5. # If building a release, please checkout the version tag to get the correct version setting
  6. ifneq ($(shell git symbolic-ref -q --short HEAD),)
  7. VERSION := unreleased-$(shell git symbolic-ref -q --short HEAD)-$(shell git rev-parse HEAD)
  8. else
  9. VERSION := $(shell git describe)
  10. endif
  11. LD_FLAGS = -X github.com/tendermint/tendermint/version.TMCoreSemVer=$(VERSION)
  12. BUILD_FLAGS = -mod=readonly -ldflags "$(LD_FLAGS)"
  13. HTTPS_GIT := https://github.com/tendermint/tendermint.git
  14. DOCKER_BUF := docker run -v $(shell pwd):/workspace --workdir /workspace bufbuild/buf
  15. CGO_ENABLED ?= 0
  16. # handle nostrip
  17. ifeq (,$(findstring nostrip,$(TENDERMINT_BUILD_OPTIONS)))
  18. BUILD_FLAGS += -trimpath
  19. LD_FLAGS += -s -w
  20. endif
  21. # handle race
  22. ifeq (race,$(findstring race,$(TENDERMINT_BUILD_OPTIONS)))
  23. CGO_ENABLED=1
  24. BUILD_FLAGS += -race
  25. endif
  26. # handle cleveldb
  27. ifeq (cleveldb,$(findstring cleveldb,$(TENDERMINT_BUILD_OPTIONS)))
  28. CGO_ENABLED=1
  29. BUILD_TAGS += cleveldb
  30. endif
  31. # handle badgerdb
  32. ifeq (badgerdb,$(findstring badgerdb,$(TENDERMINT_BUILD_OPTIONS)))
  33. BUILD_TAGS += badgerdb
  34. endif
  35. # handle rocksdb
  36. ifeq (rocksdb,$(findstring rocksdb,$(TENDERMINT_BUILD_OPTIONS)))
  37. CGO_ENABLED=1
  38. BUILD_TAGS += rocksdb
  39. endif
  40. # handle boltdb
  41. ifeq (boltdb,$(findstring boltdb,$(TENDERMINT_BUILD_OPTIONS)))
  42. BUILD_TAGS += boltdb
  43. endif
  44. # allow users to pass additional flags via the conventional LDFLAGS variable
  45. LD_FLAGS += $(LDFLAGS)
  46. all: check build test install
  47. .PHONY: all
  48. # The below include contains the tools.
  49. include tools/Makefile
  50. include test/Makefile
  51. ###############################################################################
  52. ### Build Tendermint ###
  53. ###############################################################################
  54. build: $(BUILDDIR)/
  55. CGO_ENABLED=$(CGO_ENABLED) go build $(BUILD_FLAGS) -tags '$(BUILD_TAGS)' -o $(BUILDDIR)/ ./cmd/tendermint/
  56. .PHONY: build
  57. install:
  58. CGO_ENABLED=$(CGO_ENABLED) go install $(BUILD_FLAGS) -tags $(BUILD_TAGS) ./cmd/tendermint
  59. .PHONY: install
  60. $(BUILDDIR)/:
  61. mkdir -p $@
  62. ###############################################################################
  63. ### Protobuf ###
  64. ###############################################################################
  65. proto-all: proto-gen proto-lint proto-check-breaking
  66. .PHONY: proto-all
  67. proto-gen:
  68. ## If you get the following error,
  69. ## "error while loading shared libraries: libprotobuf.so.14: cannot open shared object file: No such file or directory"
  70. ## See https://stackoverflow.com/a/25518702
  71. ## Note the $< here is substituted for the %.proto
  72. ## Note the $@ here is substituted for the %.pb.go
  73. @sh scripts/protocgen.sh
  74. .PHONY: proto-gen
  75. proto-gen-docker:
  76. @docker pull -q tendermintdev/docker-build-proto
  77. @echo "Generating Protobuf files"
  78. @docker run -v $(shell pwd):/workspace --workdir /workspace tendermintdev/docker-build-proto sh ./scripts/protocgen.sh
  79. .PHONY: proto-gen-docker
  80. proto-lint:
  81. @$(DOCKER_BUF) check lint --error-format=json
  82. .PHONY: proto-lint
  83. proto-format:
  84. @echo "Formatting Protobuf files"
  85. docker run -v $(shell pwd):/workspace --workdir /workspace tendermintdev/docker-build-proto find ./ -not -path "./third_party/*" -name *.proto -exec clang-format -i {} \;
  86. .PHONY: proto-format
  87. proto-check-breaking:
  88. @$(DOCKER_BUF) check breaking --against-input .git#branch=master
  89. .PHONY: proto-check-breaking
  90. proto-check-breaking-ci:
  91. @$(DOCKER_BUF) check breaking --against-input $(HTTPS_GIT)#branch=master
  92. .PHONY: proto-check-breaking-ci
  93. ###############################################################################
  94. ### Build ABCI ###
  95. ###############################################################################
  96. build_abci:
  97. @go build -mod=readonly -i ./abci/cmd/...
  98. .PHONY: build_abci
  99. install_abci:
  100. @go install -mod=readonly ./abci/cmd/...
  101. .PHONY: install_abci
  102. ###############################################################################
  103. ### Privval Server ###
  104. ###############################################################################
  105. build_privval_server:
  106. @go build -mod=readonly -o $(BUILDDIR)/ -i ./cmd/priv_val_server/...
  107. .PHONY: build_privval_server
  108. generate_test_cert:
  109. # generate self signing ceritificate authority
  110. @certstrap init --common-name "root CA" --expires "20 years"
  111. # generate server cerificate
  112. @certstrap request-cert -cn server -ip 127.0.0.1
  113. # self-sign server cerificate with rootCA
  114. @certstrap sign server --CA "root CA"
  115. # generate client cerificate
  116. @certstrap request-cert -cn client -ip 127.0.0.1
  117. # self-sign client cerificate with rootCA
  118. @certstrap sign client --CA "root CA"
  119. .PHONY: generate_test_cert
  120. ###############################################################################
  121. ### Distribution ###
  122. ###############################################################################
  123. # dist builds binaries for all platforms and packages them for distribution
  124. # TODO add abci to these scripts
  125. dist:
  126. @BUILD_TAGS=$(BUILD_TAGS) sh -c "'$(CURDIR)/scripts/dist.sh'"
  127. .PHONY: dist
  128. go-mod-cache: go.sum
  129. @echo "--> Download go modules to local cache"
  130. @go mod download
  131. .PHONY: go-mod-cache
  132. go.sum: go.mod
  133. @echo "--> Ensure dependencies have not been modified"
  134. @go mod verify
  135. @go mod tidy
  136. draw_deps:
  137. @# requires brew install graphviz or apt-get install graphviz
  138. go get github.com/RobotsAndPencils/goviz
  139. @goviz -i github.com/tendermint/tendermint/cmd/tendermint -d 3 | dot -Tpng -o dependency-graph.png
  140. .PHONY: draw_deps
  141. get_deps_bin_size:
  142. @# Copy of build recipe with additional flags to perform binary size analysis
  143. $(eval $(shell go build -work -a $(BUILD_FLAGS) -tags $(BUILD_TAGS) -o $(BUILDDIR)/ ./cmd/tendermint/ 2>&1))
  144. @find $(WORK) -type f -name "*.a" | xargs -I{} du -hxs "{}" | sort -rh | sed -e s:${WORK}/::g > deps_bin_size.log
  145. @echo "Results can be found here: $(CURDIR)/deps_bin_size.log"
  146. .PHONY: get_deps_bin_size
  147. ###############################################################################
  148. ### Libs ###
  149. ###############################################################################
  150. # generates certificates for TLS testing in remotedb and RPC server
  151. gen_certs: clean_certs
  152. certstrap init --common-name "tendermint.com" --passphrase ""
  153. certstrap request-cert --common-name "server" -ip "127.0.0.1" --passphrase ""
  154. certstrap sign "server" --CA "tendermint.com" --passphrase ""
  155. mv out/server.crt rpc/jsonrpc/server/test.crt
  156. mv out/server.key rpc/jsonrpc/server/test.key
  157. rm -rf out
  158. .PHONY: gen_certs
  159. # deletes generated certificates
  160. clean_certs:
  161. rm -f rpc/jsonrpc/server/test.crt
  162. rm -f rpc/jsonrpc/server/test.key
  163. .PHONY: clean_certs
  164. ###############################################################################
  165. ### Formatting, linting, and vetting ###
  166. ###############################################################################
  167. format:
  168. find . -name '*.go' -type f -not -path "*.git*" -not -name '*.pb.go' -not -name '*pb_test.go' | xargs gofmt -w -s
  169. 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
  170. .PHONY: format
  171. lint:
  172. @echo "--> Running linter"
  173. @golangci-lint run
  174. .PHONY: lint
  175. DESTINATION = ./index.html.md
  176. ###############################################################################
  177. ### Documentation ###
  178. ###############################################################################
  179. # todo remove once tendermint.com DNS is solved
  180. build-docs:
  181. @cd docs && \
  182. while read -r branch path_prefix; do \
  183. (git checkout $${branch} && npm install && VUEPRESS_BASE="/$${path_prefix}/" npm run build) ; \
  184. mkdir -p ~/output/$${path_prefix} ; \
  185. cp -r .vuepress/dist/* ~/output/$${path_prefix}/ ; \
  186. cp ~/output/$${path_prefix}/index.html ~/output ; \
  187. done < versions ;
  188. .PHONY: build-docs
  189. ###############################################################################
  190. ### Docker image ###
  191. ###############################################################################
  192. build-docker: build-linux
  193. cp $(BUILDDIR)/tendermint DOCKER/tendermint
  194. docker build --label=tendermint --tag="tendermint/tendermint" DOCKER
  195. rm -rf DOCKER/tendermint
  196. .PHONY: build-docker
  197. ###############################################################################
  198. ### Local testnet using docker ###
  199. ###############################################################################
  200. # Build linux binary on other platforms
  201. build-linux: tools
  202. GOOS=linux GOARCH=amd64 $(MAKE) build
  203. .PHONY: build-linux
  204. build-docker-localnode:
  205. @cd networks/local && make
  206. .PHONY: build-docker-localnode
  207. # Runs `make build TENDERMINT_BUILD_OPTIONS=cleveldb` from within an Amazon
  208. # Linux (v2)-based Docker build container in order to build an Amazon
  209. # Linux-compatible binary. Produces a compatible binary at ./build/tendermint
  210. build_c-amazonlinux:
  211. $(MAKE) -C ./DOCKER build_amazonlinux_buildimage
  212. docker run --rm -it -v `pwd`:/tendermint tendermint/tendermint:build_c-amazonlinux
  213. .PHONY: build_c-amazonlinux
  214. # Run a 4-node testnet locally
  215. localnet-start: localnet-stop build-docker-localnode
  216. @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
  217. docker-compose up
  218. .PHONY: localnet-start
  219. # Stop testnet
  220. localnet-stop:
  221. docker-compose down
  222. .PHONY: localnet-stop
  223. # Build hooks for dredd, to skip or add information on some steps
  224. build-contract-tests-hooks:
  225. ifeq ($(OS),Windows_NT)
  226. go build -mod=readonly $(BUILD_FLAGS) -o build/contract_tests.exe ./cmd/contract_tests
  227. else
  228. go build -mod=readonly $(BUILD_FLAGS) -o build/contract_tests ./cmd/contract_tests
  229. endif
  230. .PHONY: build-contract-tests-hooks
  231. # Run a nodejs tool to test endpoints against a localnet
  232. # The command takes care of starting and stopping the network
  233. # prerequisits: build-contract-tests-hooks build-linux
  234. # the two build commands were not added to let this command run from generic containers or machines.
  235. # The binaries should be built beforehand
  236. contract-tests:
  237. dredd
  238. .PHONY: contract-tests
  239. clean:
  240. rm -rf $(CURDIR)/artifacts/ $(BUILDDIR)/
  241. build-reproducible:
  242. docker rm latest-build || true
  243. docker run --volume=$(CURDIR):/sources:ro \
  244. --env TARGET_PLATFORMS='linux/amd64 linux/arm64 darwin/amd64 windows/amd64' \
  245. --env APP=tendermint \
  246. --env COMMIT=$(shell git rev-parse --short=8 HEAD) \
  247. --env VERSION=$(shell git describe --tags) \
  248. --name latest-build cosmossdk/rbuilder:latest
  249. docker cp -a latest-build:/home/builder/artifacts/ $(CURDIR)/
  250. .PHONY: build-reproducible