forked from etclabscore/core-geth
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
137 lines (105 loc) · 5.68 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
# This Makefile is meant to be used by people that do not usually work
# with Go source code. If you know what GOPATH is then you probably
# don't need to bother with make.
.PHONY: geth android ios geth-cross evm evmc mkdocs-serve all test clean
GOBIN = ./build/bin
GO ?= latest
GORUN = env GO111MODULE=on go run
ROOT_DIR := $(shell dirname $(realpath $(firstword $(MAKEFILE_LIST))))
geth:
$(GORUN) build/ci.go install ./cmd/geth
@echo "Done building."
@echo "Run \"$(GOBIN)/geth\" to launch geth."
all:
$(GORUN) build/ci.go install
android:
$(GORUN) build/ci.go aar --local
@echo "Done building."
@echo "Import \"$(GOBIN)/geth.aar\" to use the library."
@echo "Import \"$(GOBIN)/geth-sources.jar\" to add javadocs"
@echo "For more info see https://stackoverflow.com/questions/20994336/android-studio-how-to-attach-javadoc"
ios:
$(GORUN) build/ci.go xcode --local
@echo "Done building."
@echo "Import \"$(GOBIN)/Geth.framework\" to use the library."
test:
$(GORUN) build/ci.go test
# DEPRECATED.
# No attempt will be made after the Istanbul fork to maintain
# Parity configuration support.
sync-parity-chainspecs:
./params/parity.json.d/sync-parity-remote.sh
test-coregeth: \
test-coregeth-features \
test-coregeth-consensus \
test-coregeth-regression-condensed ## Runs all tests specific to core-geth.
# The following commands acquire external EWASM and EVM interpreter shared objects for
# testing EVMC support.
hera:
./build/hera.sh
ssvm:
./build/ssvm.sh
evmone:
./build/evmone.sh
aleth-interpreter:
./build/aleth-interpreter.sh
# Test EVMC support against various external interpreters.
test-evmc: hera ssvm evmone aleth-interpreter
go test -count 1 ./tests -run TestState -evmc.ewasm=$(ROOT_DIR)/build/_workspace/hera/build/src/libhera.so
go test -count 1 ./tests -run TestState -evmc.ewasm=$(ROOT_DIR)/build/_workspace/SSVM/build/tools/ssvm-evmc/libssvmEVMC.so
go test -count 1 ./tests -run TestState -evmc.evm=$(ROOT_DIR)/build/_workspace/evmone/lib/libevmone.so
go test -count 1 ./tests -run TestState -evmc.evm=$(ROOT_DIR)/build/_workspace/aleth/lib/libaleth-interpreter.so
clean-evmc:
rm -rf ./build/_workspace/hera ./build/_workspace/SSVM ./build/_workspace/evmone ./build/_workspace/aleth
test-coregeth-features: \
test-coregeth-features-coregeth \
test-coregeth-features-multigethv0 ## Runs tests specific to multi-geth using Fork/Feature configs.
test-coregeth-consensus: test-coregeth-features-clique-consensus
test-coregeth-features-coregeth:
@echo "Testing fork/feature/datatype implementation; equivalence - COREGETH."
env COREGETH_TESTS_CHAINCONFIG_FEATURE_EQUIVALENCE_COREGETH=on go test -count=1 -timeout 60m ./tests
test-coregeth-features-multigethv0:
@echo "Testing fork/feature/datatype implementation; equivalence - MULTIGETHv0."
env COREGETH_TESTS_CHAINCONFIG_FEATURE_EQUIVALENCE_MULTIGETHV0=on go test -count=1 -timeout 60m ./tests
test-coregeth-features-clique-consensus:
@echo "Testing fork/feature/datatype implementation; equivalence - Clique consensus"
env COREGETH_TESTS_CHAINCONFIG_CONSENSUS_EQUIVALENCE_CLIQUE=on go test -count=1 -timeout 60m -run TestState ./tests ## Only run state tests here, since Blockchain tests will care about rewards, etc.
test-coregeth-chainspecs-coregeth: ## Run tests specific to core-geth using coregeth chainspec file configs.
@echo "Testing CoreGeth JSON chainspec equivalence."
env COREGETH_TESTS_CHAINCONFIG_COREGETH_SPECS=on go test -count=1 ./tests
test-coregeth-regression-condensed: geth
@echo "Running condensed regression tests (imports) against simulated canonical blockchains."
./tests/regression/simulated/test.sh ./tests/regression/simulated/classic-condense-state/classic.conf.json ./tests/regression/simulated/classic-condense-state/export.rlp.gz
./tests/regression/simulated/test.sh ./tests/regression/simulated/foundation-condense-state/foundation.conf.json ./tests/regression/simulated/foundation-condense-state/export.rlp.gz
./tests/regression/simulated/test.sh ./tests/regression/simulated/foundation-condense-state-2/foundation.conf.json ./tests/regression/simulated/foundation-condense-state-2/export.rlp.gz
tests-generate: tests-generate-state tests-generate-difficulty ## Generate all tests.
tests-generate-state: ## Generate state tests.
@echo "Generating state tests."
env COREGETH_TESTS_GENERATE_STATE_TESTS=on \
env COREGETH_TESTS_CHAINCONFIG_FEATURE_EQUIVALENCE_COREGETH=on \
go test -p 1 -v -timeout 60m ./tests -run TestGenStateAll
tests-generate-difficulty: ## Generate difficulty tests.
@echo "Generating difficulty tests configs."
env COREGETH_TESTS_GENERATE_DIFFICULTY_TESTS_CONFIGS=on \
go run build/ci.go test -v -timeout 10m ./tests -run TestDifficultyTestConfigGen
@echo "Generating difficulty tests."
env COREGETH_TESTS_GENERATE_DIFFICULTY_TESTS=on \
go run build/ci.go test -v -timeout 10m ./tests -run TestDifficultyGen
lint: ## Run linters.
$(GORUN) build/ci.go lint
clean: clean-evmc
env GO111MODULE=on go clean -cache
rm -fr build/_workspace/pkg/ $(GOBIN)/*
mkdocs-serve: ## Serve generated documentation (during development)
@build/mkdocs-serve.sh
docs-generate: ## Generate JSON RPC API documentation from the OpenRPC service discovery document.
env COREGETH_GEN_OPENRPC_DOCS=on go test -count=1 -run BuildStatic ./ethclient
# The devtools target installs tools required for 'go generate'.
# You need to put $GOBIN (or $GOPATH/bin) in your PATH to use 'go generate'.
devtools:
env GOBIN= go install golang.org/x/tools/cmd/stringer@latest
env GOBIN= go install github.com/fjl/gencodec@latest
env GOBIN= go install github.com/golang/protobuf/protoc-gen-go@latest
env GOBIN= go install ./cmd/abigen
@type "solc" 2> /dev/null || echo 'Please install solc'
@type "protoc" 2> /dev/null || echo 'Please install protoc'