# Copyright (c) 2019-2024 Status Research & Development GmbH. Licensed under # either of: # - Apache License, version 2.0 # - MIT license # at your option. This file may not be copied, modified, or distributed except # according to those terms. SHELL := bash # the shell used internally by "make" # used inside the included makefiles BUILD_SYSTEM_DIR := vendor/nimbus-build-system # we set its default value before LOG_LEVEL is used in "variables.mk" LOG_LEVEL := DEBUG # used by Make targets that launch a beacon node RUNTIME_LOG_LEVEL := INFO LINK_PCRE := 0 # we don't want an error here, so we can handle things later, in the ".DEFAULT" target -include $(BUILD_SYSTEM_DIR)/makefiles/variables.mk NODE_ID := 0 BASE_PORT := 9000 BASE_REST_PORT := 5052 BASE_METRICS_PORT := 8008 # WARNING: Use lazy assignment to allow CI to override. EXECUTOR_NUMBER ?= 0 SEPOLIA_WEB3_URL := "--web3-url=https://rpc.sepolia.dev --web3-url=https://www.sepoliarpc.space" GNOSIS_WEB3_URLS := "--web3-url=https://rpc.gnosischain.com/" VALIDATORS := 1 CPU_LIMIT := 0 BUILD_END_MSG := "\\x1B[92mBuild completed successfully:\\x1B[39m" TEST_MODULES_FLAGS := -d:chronicles_log_level=TRACE -d:chronicles_sinks=json[file] ifeq ($(CPU_LIMIT), 0) CPU_LIMIT_CMD := else CPU_LIMIT_CMD := cpulimit --limit=$(CPU_LIMIT) --foreground -- endif # TODO: move this to nimbus-build-system ifeq ($(shell uname), Darwin) # Scary warnings in large volume: https://github.com/status-im/nimbus-eth2/issues/3076 SILENCE_WARNINGS := 2>&1 | grep -v "failed to insert symbol" | grep -v "could not find object file symbol for symbol" || true else SILENCE_WARNINGS := endif # unconditionally built by the default Make target TOOLS_CORE_CUSTOMCOMPILE := \ libnimbus_lc.a TOOLS_CORE := \ deposit_contract \ resttest \ mev_mock \ ncli \ ncli_db \ ncli_split_keystore \ fakeee \ wss_sim \ stack_sizes \ nimbus_light_client \ nimbus_validator_client \ nimbus_signing_node \ validator_db_aggregator \ ncli_testnet \ $(TOOLS_CORE_CUSTOMCOMPILE) # This TOOLS/TOOLS_CORE decomposition is a workaroud so nimbus_beacon_node can # build on its own, and if/when that becomes a non-issue, it can be recombined # to a single TOOLS list. TOOLS := $(TOOLS_CORE) nimbus_beacon_node .PHONY: $(TOOLS) TOOLS_DIRS := \ beacon_chain \ beacon_chain/el \ ncli \ research \ tools TOOLS_CSV := $(subst $(SPACE),$(COMMA),$(TOOLS)) .PHONY: \ all \ deps \ update \ test \ clean \ libbacktrace \ book \ publish-book \ dist-amd64 \ dist-arm64 \ dist-arm \ dist-win64 \ dist-macos \ dist-macos-arm64 \ dist \ local-testnet-minimal \ local-testnet-mainnet # TODO: Add the installer packages here PLATFORM_SPECIFIC_TARGETS := # TODO Fix the gnosis build on Windows ifneq ($(OS), Windows_NT) PLATFORM_SPECIFIC_TARGETS += gnosis-build endif # We don't need these `vendor/holesky` files but fetching them # may trigger 'This repository is over its data quota' from GitHub GIT_SUBMODULE_CONFIG := -c lfs.fetchexclude=/public-keys/all.txt,/custom_config_data/genesis.ssz ifeq ($(NIM_PARAMS),) # "variables.mk" was not included, so we update the submodules. # # The `git reset ...` will try to fix a `make update` that was interrupted # with Ctrl+C after deleting the working copy and before getting a chance to # restore it in $(BUILD_SYSTEM_DIR). # `vendor/holesky` requires Git LFS ifeq (, $(shell which git-lfs)) ifeq ($(shell uname), Darwin) $(error Git LFS not installed. Run 'brew install git-lfs' to set up) else $(error Git LFS not installed) endif endif GIT_SUBMODULE_UPDATE := git $(GIT_SUBMODULE_CONFIG) submodule update --init --recursive .DEFAULT: +@ echo -e "Git submodules not found. Running '$(GIT_SUBMODULE_UPDATE)'.\n"; \ $(GIT_SUBMODULE_UPDATE) && \ git submodule foreach --quiet 'git $(GIT_SUBMODULE_CONFIG) reset --quiet --hard' && \ echo # Now that the included *.mk files appeared, and are newer than this file, Make will restart itself: # https://www.gnu.org/software/make/manual/make.html#Remaking-Makefiles # # After restarting, it will execute its original goal, so we don't have to start a child Make here # with "$(MAKE) $(MAKECMDGOALS)". Isn't hidden control flow great? else # "variables.mk" was included. Business as usual until the end of this file. # default target, because it's the first one that doesn't start with '.' all: | $(TOOLS) libnfuzz.so libnfuzz.a $(PLATFORM_SPECIFIC_TARGETS) # must be included after the default target -include $(BUILD_SYSTEM_DIR)/makefiles/targets.mk DEPOSITS_DELAY := 0 #- "--define:release" cannot be added to "config.nims" #- disable Nim's default parallelisation because it starts too many processes for too little gain #- https://github.com/status-im/nim-libp2p#use-identify-metrics NIM_PARAMS := -d:release --parallelBuild:1 -d:libp2p_agents_metrics -d:KnownLibP2PAgents=nimbus,lighthouse,lodestar,prysm,teku,grandine $(NIM_PARAMS) ifeq ($(USE_LIBBACKTRACE), 0) NIM_PARAMS += -d:disable_libbacktrace endif deps: | deps-common nat-libs build/generate_makefile ifneq ($(USE_LIBBACKTRACE), 0) deps: | libbacktrace endif #- deletes binaries that might need to be rebuilt after a Git pull update: | update-common rm -f build/generate_makefile rm -fr nimcache/ # nim-libbacktrace libbacktrace: + "$(MAKE)" -C vendor/nim-libbacktrace --no-print-directory BUILD_CXX_LIB=0 # Make sure ports don't overlap to support concurrent execution of tests # Avoid selecting ephemeral ports that may be used by others; safe = 5001-9999 # - Port 8301 is used by Consul # - Port 9952 sometimes reports (48) Address already in use. # # EXECUTOR_NUMBER: [0, 2] (depends on max number of concurrent CI jobs) # # The following port ranges are allocated (entire continuous range): # # Unit tests: # - NIMBUS_TEST_KEYMANAGER_BASE_PORT + [0, 4) # - NIMBUS_TEST_SIGNING_NODE_BASE_PORT + [0, 2) # # REST tests: # - --base-port (REST_TEST_BASE_PORT + 0) # - --base-rest-port (REST_TEST_BASE_PORT + 1) # - --base-metrics-port (REST_TEST_BASE_PORT + 2) # # Local testnets (entire continuous range): # - --base-port + [0, --nodes + --light-clients) # - --base-rest-port + [0, --nodes) # - --base-metrics-port + [0, --nodes) # - --base-vc-keymanager-port + [0, --nodes) # - --base-vc-metrics-port + [0, --nodes] # - --base-remote-signer-port + [0, --signer-nodes) # - --base-remote-signer-metrics-port + [0, --signer-nodes) # # Local testnets with --run-geth or --run-nimbus (only these ports): # - --base-el-net-port + --el-port-offset * [0, --nodes + --light-clients) # - --base-el-rpc-port + --el-port-offset * [0, --nodes + --light-clients) # - --base-el-ws-port + --el-port-offset * [0, --nodes + --light-clients) # - --base-el-auth-rpc-port + --el-port-offset * [0, --nodes + --light-clients) UNIT_TEST_BASE_PORT := 9960 REST_TEST_BASE_PORT := 9990 MINIMAL_TESTNET_BASE_PORT := 5001 MAINNET_TESTNET_BASE_PORT := 6501 restapi-test: ./tests/simulation/restapi.sh \ --data-dir resttest0_data \ --base-port $$(( $(REST_TEST_BASE_PORT) + EXECUTOR_NUMBER * 3 + 0 )) \ --base-rest-port $$(( $(REST_TEST_BASE_PORT) + EXECUTOR_NUMBER * 3 + 1 )) \ --base-metrics-port $$(( $(REST_TEST_BASE_PORT) + EXECUTOR_NUMBER * 3 + 2 )) \ --resttest-delay 30 \ --kill-old-processes SIGNER_TYPE := nimbus local-testnet-minimal: ./scripts/launch_local_testnet.sh \ --data-dir $@ \ --preset minimal \ --nodes 2 \ --signer-nodes 1 \ --remote-validators-count 512 \ --signer-type $(SIGNER_TYPE) \ --deneb-fork-epoch 0 \ --electra-fork-epoch 50 \ --stop-at-epoch 6 \ --disable-htop \ --enable-payload-builder \ --base-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 0 )) \ --base-rest-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 30 )) \ --base-metrics-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 60 )) \ --base-vc-keymanager-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 130)) \ --base-vc-metrics-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 160)) \ --base-remote-signer-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 200)) \ --base-remote-signer-metrics-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 250)) \ --base-el-net-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 300 )) \ --base-el-rpc-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 301 )) \ --base-el-ws-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 302 )) \ --base-el-auth-rpc-port $$(( $(MINIMAL_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 303 )) \ --el-port-offset 5 \ --timeout 648 \ --kill-old-processes \ --run-geth --dl-geth \ -- \ --verify-finalization \ --discv5:no \ --num-threads:1 local-testnet-mainnet: ./scripts/launch_local_testnet.sh \ --data-dir $@ \ --nodes 2 \ --deneb-fork-epoch 0 \ --electra-fork-epoch 50 \ --stop-at-epoch 6 \ --disable-htop \ --base-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 0 )) \ --base-rest-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 30 )) \ --base-metrics-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 60 )) \ --base-vc-keymanager-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 130 )) \ --base-vc-metrics-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 160 )) \ --base-remote-signer-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 200 )) \ --base-remote-signer-metrics-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 250 )) \ --base-el-net-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 300 )) \ --base-el-rpc-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 301 )) \ --base-el-ws-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 302 )) \ --base-el-auth-rpc-port $$(( $(MAINNET_TESTNET_BASE_PORT) + EXECUTOR_NUMBER * 400 + 303 )) \ --el-port-offset 5 \ --timeout 2784 \ --kill-old-processes \ --run-geth --dl-geth \ -- \ --verify-finalization \ --discv5:no # test binaries that can output an XML report XML_TEST_BINARIES_CORE := \ consensus_spec_tests_minimal \ consensus_spec_tests_mainnet XML_TEST_BINARIES := \ $(XML_TEST_BINARIES_CORE) \ all_tests # test suite TEST_BINARIES := \ block_sim \ test_libnimbus_lc .PHONY: $(TEST_BINARIES) $(XML_TEST_BINARIES) force_build_alone_all_tests # Preset-dependent tests consensus_spec_tests_mainnet: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ "tests/consensus_spec/consensus_spec_tests_preset.nim" \ $(NIM_PARAMS) -d:const_preset=mainnet $(TEST_MODULES_FLAGS) && \ echo -e $(BUILD_END_MSG) "build/$@" consensus_spec_tests_minimal: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ "tests/consensus_spec/consensus_spec_tests_preset.nim" \ $(NIM_PARAMS) -d:const_preset=minimal -d:FIELD_ELEMENTS_PER_BLOB=4 $(TEST_MODULES_FLAGS) && \ echo -e $(BUILD_END_MSG) "build/$@" # Tests we only run for the default preset proto_array: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ "beacon_chain/fork_choice/$@.nim" \ $(NIM_PARAMS) $(TEST_MODULES_FLAGS) && \ echo -e $(BUILD_END_MSG) "build/$@" fork_choice: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ "beacon_chain/fork_choice/$@.nim" \ $(NIM_PARAMS) $(TEST_MODULES_FLAGS) && \ echo -e $(BUILD_END_MSG) "build/$@" # Windows GitHub Actions CI runners, as of this writing, have around 8GB of RAM # and compiling all_tests requires around 5.5GB of that. It often fails via OOM # on the two cores available. Usefully, the part of the process requiring those # gigabytes of RAM is `nim c --compileOnly`, which intrinsically serializes. As # a result, only slightly increase build times by using fake dependencies, when # running `make test`, to ensure the `all_tests` target builds alone when being # built as part of `test`, while not also spuriously otherwise depending on the # not-actually-related Makefile goals. # # This works because `nim c --compileOnly` is fast but RAM-heavy, while the # rest of the build process, such as LTO, requires less RAM but is slow and # still is parallelized. # # On net, this saves CI and human time, because it reduces the likelihood of # CI false negatives in a process lasting hours and requiring a restart, and # therefore even more wasted time, when it does. # # If one asks for, e.g., `make all_tests block_sim`, it intentionally allows # those in parallel, because the CI system doesn't do that. # # https://www.gnu.org/software/make/manual/html_node/Parallel-Disable.html # describes a special target .WAIT which would enable this more easily but # remains unusable for this Makefile due to requiring GNU Make 4.4. ifneq (,$(filter test,$(MAKECMDGOALS))) FORCE_BUILD_ALONE_ALL_TESTS_DEPS := $(XML_TEST_BINARIES_CORE) $(TEST_BINARIES) else FORCE_BUILD_ALONE_ALL_TESTS_DEPS := endif force_build_alone_all_tests: | $(FORCE_BUILD_ALONE_ALL_TESTS_DEPS) all_tests: | build deps nimbus_signing_node force_build_alone_all_tests + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ "tests/$@.nim" \ $(NIM_PARAMS) $(TEST_MODULES_FLAGS) && \ echo -e $(BUILD_END_MSG) "build/$@" # Block sim; getting to 4th epoch triggers consensus checks block_sim: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ "research/$@.nim" \ $(NIM_PARAMS) && \ echo -e $(BUILD_END_MSG) "build/$@" DISABLE_TEST_FIXTURES_SCRIPT := 0 # This parameter passing scheme is ugly, but short. test: | $(XML_TEST_BINARIES) $(TEST_BINARIES) ifeq ($(DISABLE_TEST_FIXTURES_SCRIPT), 0) V=$(V) scripts/setup_scenarios.sh endif for TEST_BINARY in $(XML_TEST_BINARIES); do \ PARAMS="--xml:build/$${TEST_BINARY}.xml --console"; \ echo -e "\nRunning $${TEST_BINARY} $${PARAMS}\n"; \ NIMBUS_TEST_KEYMANAGER_BASE_PORT=$$(( $(UNIT_TEST_BASE_PORT) + EXECUTOR_NUMBER * 6 + 0 )) \ NIMBUS_TEST_SIGNING_NODE_BASE_PORT=$$(( $(UNIT_TEST_BASE_PORT) + EXECUTOR_NUMBER * 6 + 4 )) \ build/$${TEST_BINARY} $${PARAMS} || { \ echo -e "\n$${TEST_BINARY} $${PARAMS} failed; Last 5000 lines from the log:"; \ tail -n5000 "$${TEST_BINARY}.log"; exit 1; \ }; \ done; \ rm -rf 0000-*.json t_slashprot_migration.* *.log block_sim_db for TEST_BINARY in $(TEST_BINARIES); do \ PARAMS=""; \ REDIRECT=""; \ if [[ "$${TEST_BINARY}" == "block_sim" ]]; then PARAMS="--validators=10000 --slots=192"; \ elif [[ "$${TEST_BINARY}" == "test_libnimbus_lc" ]]; then REDIRECT="$${TEST_BINARY}.log"; \ fi; \ echo -e "\nRunning $${TEST_BINARY} $${PARAMS}\n"; \ if [[ "$${REDIRECT}" != "" ]]; then \ build/$${TEST_BINARY} $${PARAMS} > "$${REDIRECT}" && echo "OK" || { \ echo -e "\n$${TEST_BINARY} $${PARAMS} failed; Last 5000 lines from the log:"; \ tail -n5000 "$${TEST_BINARY}.log"; exit 1; \ }; \ else \ build/$${TEST_BINARY} $${PARAMS} || { \ echo -e "\n$${TEST_BINARY} $${PARAMS} failed; Last 5000 lines from the log:"; \ tail -n5000 "$${TEST_BINARY}.log"; exit 1; \ }; \ fi; \ done; \ rm -rf 0000-*.json t_slashprot_migration.* *.log block_sim_db # It's OK to only build this once. `make update` deletes the binary, forcing a rebuild. ifneq ($(USE_LIBBACKTRACE), 0) build/generate_makefile: | libbacktrace endif build/generate_makefile: tools/generate_makefile.nim | deps-common + echo -e $(BUILD_MSG) "$@" && \ $(ENV_SCRIPT) $(NIMC) c -o:$@ $(NIM_PARAMS) tools/generate_makefile.nim $(SILENCE_WARNINGS) && \ echo -e $(BUILD_END_MSG) "$@" # GCC's LTO parallelisation is able to detect a GNU Make jobserver and get its # maximum number of processes from there, but only if we use the "+" prefix. # Without it, it will default to the number of CPU cores, which can be a # problem on low-memory systems. # It also requires Make to pass open file descriptors to the GCC process, # which is not possible if we let Nim handle this, so we generate and use a # makefile instead. $(filter-out $(TOOLS_CORE_CUSTOMCOMPILE),$(TOOLS)): | build deps + for D in $(TOOLS_DIRS); do [ -e "$${D}/$@.nim" ] && TOOL_DIR="$${D}" && break; done && \ echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh $@ "$${TOOL_DIR}/$@.nim" $(NIM_PARAMS) && \ echo -e $(BUILD_END_MSG) "build/$@" # Windows GitHub Actions CI runners, as of this writing, have around 8GB of RAM # and compiling nimbus_beacon_node requires more than 5GB. It can fail with OOM # on the two cores available. Usefully, the part of the process requiring those # gigabytes of RAM is `nim c --compileOnly`, which intrinsically serializes. As # a result, only slightly increase build times by using fake dependencies, when # running `make`, to ensure `nimbus_beacon_node` builds alone, when being built # as part of `all`, while allowing one to also build `nimbus_beacon_node` alone # without pulling in the rest of `$(TOOLS)`. # # This works because `nim c --compileOnly` is fast but RAM-heavy, while the # rest of the build process, such as LTO, requires less RAM but is slow and # still is parallelized. # # On net, this saves CI and human time, because it reduces the likelihood of # CI false negatives in a process lasting hours and requiring a restart, and # therefore even more wasted time, when it does. # # If one asks for, e.g., `make nimbus_beacon_node nimbus_validator_client`, it # intentionally allows those in parallel, as the CI systems don't do that. # # https://www.gnu.org/software/make/manual/html_node/Parallel-Disable.html # describes a special target .WAIT which would enable this more easily but # remains unusable for this Makefile due to requiring GNU Make 4.4. ifneq (,$(filter all,$(MAKECMDGOALS))) FORCE_BUILD_ALONE_TOOLS_DEPS := $(TOOLS_CORE) # If this isn't an included target (such as Windows), this is a no-op) gnosis-build: | nimbus_beacon_node else ifeq (,$(MAKECMDGOALS)) FORCE_BUILD_ALONE_TOOLS_DEPS := $(TOOLS_CORE) # If this isn't an included target (such as Windows), this is a no-op) gnosis-build: | nimbus_beacon_node else FORCE_BUILD_ALONE_TOOLS_DEPS := endif .PHONY: force_build_alone_tools force_build_alone_tools: | $(FORCE_BUILD_ALONE_TOOLS_DEPS) # https://www.gnu.org/software/make/manual/html_node/Multiple-Rules.html#Multiple-Rules # Already defined as a reult nimbus_beacon_node: force_build_alone_tools GOERLI_TESTNETS_PARAMS := \ --tcp-port=$$(( $(BASE_PORT) + $(NODE_ID) )) \ --udp-port=$$(( $(BASE_PORT) + $(NODE_ID) )) \ --metrics \ --metrics-port=$$(( $(BASE_METRICS_PORT) + $(NODE_ID) )) \ --rest \ --rest-port=$$(( $(BASE_REST_PORT) + $(NODE_ID) )) #- https://www.gnu.org/software/make/manual/html_node/Multi_002dLine.html #- macOS doesn't support "=" at the end of "define FOO": https://stackoverflow.com/questions/13260396/gnu-make-3-81-eval-function-not-working define CONNECT_TO_NETWORK scripts/makedir.sh build/data/shared_$(1)_$(NODE_ID) scripts/make_prometheus_config.sh \ --nodes 1 \ --base-metrics-port $$(($(BASE_METRICS_PORT) + $(NODE_ID))) \ --config-file "build/data/shared_$(1)_$(NODE_ID)/prometheus.yml" $(CPU_LIMIT_CMD) build/$(2) \ --network=$(1) $(3) $(GOERLI_TESTNETS_PARAMS) \ --log-level="$(RUNTIME_LOG_LEVEL)" \ --log-file=build/data/shared_$(1)_$(NODE_ID)/nbc_bn_$$(date +"%Y%m%d%H%M%S").log \ --data-dir=build/data/shared_$(1)_$(NODE_ID) \ $(NODE_PARAMS) endef define CONNECT_TO_NETWORK_IN_DEV_MODE scripts/makedir.sh build/data/shared_$(1)_$(NODE_ID) scripts/make_prometheus_config.sh \ --nodes 1 \ --base-metrics-port $$(($(BASE_METRICS_PORT) + $(NODE_ID))) \ --config-file "build/data/shared_$(1)_$(NODE_ID)/prometheus.yml" $(CPU_LIMIT_CMD) build/$(2) \ --network=$(1) $(3) $(GOERLI_TESTNETS_PARAMS) \ --log-level="DEBUG; TRACE:discv5,networking; REQUIRED:none; DISABLED:none" \ --data-dir=build/data/shared_$(1)_$(NODE_ID) \ --dump $(NODE_PARAMS) endef define CONNECT_TO_NETWORK_WITH_VALIDATOR_CLIENT # if launching a VC as well - send the BN looking nowhere for validators/secrets scripts/makedir.sh build/data/shared_$(1)_$(NODE_ID) scripts/makedir.sh build/data/shared_$(1)_$(NODE_ID)/empty_dummy_folder scripts/make_prometheus_config.sh \ --nodes 1 \ --base-metrics-port $$(($(BASE_METRICS_PORT) + $(NODE_ID))) \ --config-file "build/data/shared_$(1)_$(NODE_ID)/prometheus.yml" $(CPU_LIMIT_CMD) build/$(2) \ --network=$(1) $(3) $(GOERLI_TESTNETS_PARAMS) \ --log-level="$(RUNTIME_LOG_LEVEL)" \ --log-file=build/data/shared_$(1)_$(NODE_ID)/nbc_bn_$$(date +"%Y%m%d%H%M%S").log \ --data-dir=build/data/shared_$(1)_$(NODE_ID) \ --validators-dir=build/data/shared_$(1)_$(NODE_ID)/empty_dummy_folder \ --secrets-dir=build/data/shared_$(1)_$(NODE_ID)/empty_dummy_folder \ $(NODE_PARAMS) & sleep 4 build/nimbus_validator_client \ --log-level="$(RUNTIME_LOG_LEVEL)" \ --log-file=build/data/shared_$(1)_$(NODE_ID)/nbc_vc_$$(date +"%Y%m%d%H%M%S").log \ --data-dir=build/data/shared_$(1)_$(NODE_ID) \ --rest-port=$$(( $(BASE_REST_PORT) + $(NODE_ID) )) endef define CONNECT_TO_NETWORK_WITH_LIGHT_CLIENT scripts/makedir.sh build/data/shared_$(1)_$(NODE_ID) $(CPU_LIMIT_CMD) build/nimbus_light_client \ --network=$(1) \ --log-level="$(RUNTIME_LOG_LEVEL)" \ --log-file=build/data/shared_$(1)_$(NODE_ID)/nbc_lc_$$(date +"%Y%m%d%H%M%S").log \ --data-dir=build/data/shared_$(1)_$(NODE_ID) \ --trusted-block-root="$(LC_TRUSTED_BLOCK_ROOT)" endef define MAKE_DEPOSIT_DATA build/nimbus_beacon_node deposits createTestnetDeposits \ --network=$(1) \ --new-wallet-file=build/data/shared_$(1)_$(NODE_ID)/wallet.json \ --out-validators-dir=build/data/shared_$(1)_$(NODE_ID)/validators \ --out-secrets-dir=build/data/shared_$(1)_$(NODE_ID)/secrets \ --out-deposits-file=$(1)-deposits_data-$$(date +"%Y%m%d%H%M%S").json \ --count=$(VALIDATORS) endef define MAKE_DEPOSIT build/nimbus_beacon_node deposits createTestnetDeposits \ --network=$(1) \ --out-deposits-file=nbc-$(1)-deposits.json \ --new-wallet-file=build/data/shared_$(1)_$(NODE_ID)/wallet.json \ --out-validators-dir=build/data/shared_$(1)_$(NODE_ID)/validators \ --out-secrets-dir=build/data/shared_$(1)_$(NODE_ID)/secrets \ --count=$(VALIDATORS) build/deposit_contract sendDeposits \ $(2) \ --deposit-contract=$$(cat vendor/$(1)/metadata/deposit_contract.txt) \ --deposits-file=nbc-$(1)-deposits.json \ --min-delay=$(DEPOSITS_DELAY) \ --max-delay=$(DEPOSITS_DELAY) \ --ask-for-key endef define CLEAN_NETWORK rm -rf build/data/shared_$(1)*/db rm -rf build/data/shared_$(1)*/dump rm -rf build/data/shared_$(1)*/*.log endef ### ### Sepolia ### sepolia-build: | nimbus_beacon_node nimbus_signing_node # https://www.gnu.org/software/make/manual/html_node/Call-Function.html#Call-Function sepolia: | sepolia-build $(call CONNECT_TO_NETWORK,sepolia,nimbus_beacon_node,$(SEPOLIA_WEB3_URL)) sepolia-vc: | sepolia-build nimbus_validator_client $(call CONNECT_TO_NETWORK_WITH_VALIDATOR_CLIENT,sepolia,nimbus_beacon_node,$(SEPOLIA_WEB3_URL)) sepolia-lc: | nimbus_light_client $(call CONNECT_TO_NETWORK_WITH_LIGHT_CLIENT,sepolia) ifneq ($(LOG_LEVEL), TRACE) sepolia-dev: + "$(MAKE)" LOG_LEVEL=TRACE $@ else sepolia-dev: | sepolia-build $(call CONNECT_TO_NETWORK_IN_DEV_MODE,sepolia,nimbus_beacon_node,$(SEPOLIA_WEB3_URL)) endif sepolia-dev-deposit: | sepolia-build deposit_contract $(call MAKE_DEPOSIT,sepolia,$(SEPOLIA_WEB3_URL)) clean-sepolia: $(call CLEAN_NETWORK,sepolia) ### ### Gnosis chain binary ### # TODO The `-d:gnosisChainBinary` override can be removed if the web3 library # gains support for multiple "Chain Profiles" that consist of a set of # consensus object (such as blocks and transactions) that are specific # to the chain. gnosis-build gnosis-chain-build: | build deps + echo -e $(BUILD_MSG) "build/nimbus_beacon_node_gnosis" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ nimbus_beacon_node_gnosis \ beacon_chain/nimbus_beacon_node.nim \ $(NIM_PARAMS) \ -d:gnosisChainBinary \ -d:const_preset=gnosis \ && \ echo -e $(BUILD_END_MSG) "build/nimbus_beacon_node_gnosis" gnosis-vc-build: | build deps + echo -e $(BUILD_MSG) "build/nimbus_validator_client_gnosis" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ nimbus_validator_client_gnosis \ beacon_chain/nimbus_validator_client.nim \ $(NIM_PARAMS) \ -d:gnosisChainBinary \ -d:const_preset=gnosis \ && \ echo -e $(BUILD_END_MSG) "build/nimbus_validator_client_gnosis" gnosis: | gnosis-build $(call CONNECT_TO_NETWORK,gnosis,nimbus_beacon_node_gnosis,$(GNOSIS_WEB3_URLS)) ifneq ($(LOG_LEVEL), TRACE) gnosis-dev: + "$(MAKE)" --no-print-directory LOG_LEVEL=TRACE $@ else gnosis-dev: | gnosis-build $(call CONNECT_TO_NETWORK_IN_DEV_MODE,gnosis,nimbus_beacon_node_gnosis,$(GNOSIS_WEB3_URLS)) endif gnosis-dev-deposit: | gnosis-build deposit_contract $(call MAKE_DEPOSIT,gnosis,$(GNOSIS_WEB3_URLS)) clean-gnosis: $(call CLEAN_NETWORK,gnosis) # v22.3 names gnosis-chain: | gnosis-build echo `gnosis-chain` is deprecated, use `gnosis` after migrating data folder $(call CONNECT_TO_NETWORK,gnosis-chain,nimbus_beacon_node_gnosis,$(GNOSIS_WEB3_URLS)) ifneq ($(LOG_LEVEL), TRACE) gnosis-chain-dev: + "$(MAKE)" --no-print-directory LOG_LEVEL=TRACE $@ else gnosis-chain-dev: | gnosis-build echo `gnosis-chain-dev` is deprecated, use `gnosis-dev` instead $(call CONNECT_TO_NETWORK_IN_DEV_MODE,gnosis-chain,nimbus_beacon_node_gnosis,$(GNOSIS_WEB3_URLS)) endif gnosis-chain-dev-deposit: | gnosis-build deposit_contract echo `gnosis-chain-dev-deposit` is deprecated, use `gnosis-chain-dev-deposit` instead $(call MAKE_DEPOSIT,gnosis-chain,$(GNOSIS_WEB3_URLS)) clean-gnosis-chain: $(call CLEAN_NETWORK,gnosis-chain) ### ### libnimbus_lc ### libnimbus_lc.a: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ rm -f build/$@ && \ $(ENV_SCRIPT) $(NIMC) c -d:disable_libbacktrace -d:release --app:staticlib --noMain --nimcache:nimcache/libnimbus_lc_static -o:build/$@ $(NIM_PARAMS) beacon_chain/libnimbus_lc/libnimbus_lc.nim $(SILENCE_WARNINGS) && \ echo -e $(BUILD_END_MSG) "build/$@" # `-Wno-maybe-uninitialized` in Linux: https://github.com/nim-lang/Nim/issues/22246 # `-Wno-unsafe-buffer-usage` Support llvm@18 on macOS: https://github.com/status-im/nimbus-eth2/pull/6153 # `-Wl,--stack,0x0000000000800000` in Windows: MinGW default of 2 MB leads to `SIGSEGV` in `___chkstk_ms` in Nim 2.0 test_libnimbus_lc: libnimbus_lc.a + echo -e $(BUILD_MSG) "build/$@" && \ EXTRA_FLAGS=() && \ case "$$(uname)" in \ Darwin) \ if (( $${WITH_UBSAN:-0} )); then \ EXTRA_FLAGS+=('-fsanitize=undefined'); \ fi; \ clang -D__DIR__="\"beacon_chain/libnimbus_lc\"" \ --std=c17 \ -Weverything -Werror \ -Wno-declaration-after-statement -Wno-nullability-extension \ -Wno-unsafe-buffer-usage -Wno-unknown-warning-option \ -isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk \ -o build/test_libnimbus_lc \ beacon_chain/libnimbus_lc/test_libnimbus_lc.c build/libnimbus_lc.a \ -framework Security "$${EXTRA_FLAGS[@]}"; \ ;; \ MINGW64_*) \ if (( $${WITH_UBSAN:-0} )); then \ EXTRA_FLAGS+=('-fsanitize=undefined'); \ fi; \ gcc -D__DIR__="\"beacon_chain/libnimbus_lc\"" \ --std=c17 -flto \ -pedantic -pedantic-errors \ -Wall -Wextra -Werror -Wno-nullability-extension \ -Wno-unsafe-buffer-usage -Wno-unknown-warning-option \ -Wl,--stack,0x0000000000800000 \ -o build/test_libnimbus_lc \ -D_CRT_SECURE_NO_WARNINGS \ beacon_chain/libnimbus_lc/test_libnimbus_lc.c \ build/libnimbus_lc.a \ "$${EXTRA_FLAGS[@]}"; \ ;; \ *) \ if (( $${WITH_UBSAN:-0} )); then \ EXTRA_FLAGS+=('-fsanitize=undefined'); \ fi; \ gcc -D__DIR__="\"beacon_chain/libnimbus_lc\"" \ --std=c17 -flto \ -pedantic -pedantic-errors \ -Wall -Wextra -Werror -Wno-maybe-uninitialized \ -Wno-unsafe-buffer-usage -Wno-unknown-warning-option \ -o build/test_libnimbus_lc \ beacon_chain/libnimbus_lc/test_libnimbus_lc.c \ build/libnimbus_lc.a \ "$${EXTRA_FLAGS[@]}"; \ ;; \ esac && \ echo -e $(BUILD_END_MSG) "build/$@" ### ### Other ### nimbus-msi: | nimbus_beacon_node "$(WIX)/bin/candle" -ext WixUIExtension -ext WixUtilExtension installer/windows/*.wxs -o installer/windows/obj/ "$(WIX)/bin/light" -ext WixUIExtension -ext WixUtilExtension -cultures:"en-us;en-uk;neutral" installer/windows/obj/*.wixobj -out build/NimbusBeaconNode.msi nimbus-pkg: | nimbus_beacon_node xcodebuild -project installer/macos/nimbus-pkg.xcodeproj -scheme nimbus-pkg build packagesbuild installer/macos/nimbus-pkg.pkgproj ntu: | build deps mkdir -p vendor/.nimble/bin/ + $(ENV_SCRIPT) $(NIMC) -d:danger -o:vendor/.nimble/bin/ntu c vendor/nim-testutils/ntu.nim clean: | clean-common rm -rf build/{$(TOOLS_CSV),all_tests,test_*,proto_array,fork_choice,*.a,*.so,*_node,*ssz*,nimbus_*,beacon_node*,block_sim,transition*,generate_makefile,nimbus-wix/obj} ifneq ($(USE_LIBBACKTRACE), 0) + "$(MAKE)" -C vendor/nim-libbacktrace clean $(HANDLE_OUTPUT) endif libnfuzz.so: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ $(ENV_SCRIPT) $(NIMC) c -d:release --app:lib --noMain --nimcache:nimcache/libnfuzz -o:build/$@.0 $(NIM_PARAMS) nfuzz/libnfuzz.nim $(SILENCE_WARNINGS) && \ echo -e $(BUILD_END_MSG) "build/$@" && \ rm -f build/$@ && \ ln -s $@.0 build/$@ libnfuzz.a: | build deps + echo -e $(BUILD_MSG) "build/$@" && \ rm -f build/$@ && \ $(ENV_SCRIPT) $(NIMC) c -d:release --app:staticlib --noMain --nimcache:nimcache/libnfuzz_static -o:build/$@ $(NIM_PARAMS) nfuzz/libnfuzz.nim $(SILENCE_WARNINGS) && \ echo -e $(BUILD_END_MSG) "build/$@" && \ [[ -e "$@" ]] && mv "$@" build/ || true # workaround for https://github.com/nim-lang/Nim/issues/12745 book: "$(MAKE)" -C docs book auditors-book: [[ "$$(mdbook --version)" == "mdbook v0.4.36" ]] || { echo "'mdbook v0.4.35' not found in PATH. See 'docs/README.md'. Aborting."; exit 1; } [[ "$$(mdbook-toc --version)" == "mdbook-toc 0.14.1" ]] || { echo "'mdbook-toc 0.14.1' not found in PATH. See 'docs/README.md'. Aborting."; exit 1; } [[ "$$(mdbook-open-on-gh --version)" == "mdbook-open-on-gh 2.4.1" ]] || { echo "'mdbook-open-on-gh 2.4.1' not found in PATH. See 'docs/README.md'. Aborting."; exit 1; } [[ "$$(mdbook-admonish --version)" == "mdbook-admonish 1.14.0" ]] || { echo "'mdbook-open-on-gh 1.13.1' not found in PATH. See 'docs/README.md'. Aborting."; exit 1; } cd docs/the_auditors_handbook && \ mdbook build publish-book: | book auditors-book CURRENT_BRANCH="$$(git rev-parse --abbrev-ref HEAD)"; \ if [[ "$${CURRENT_BRANCH}" != "stable" && "$${CURRENT_BRANCH}" != "unstable" ]]; then \ echo -e "\nWarning: you're publishing the books from a branch that is neither 'stable' nor 'unstable'!\n"; \ fi CURRENT_COMMIT="$$(git rev-parse --short HEAD)" && \ git branch -D gh-pages && \ git branch --track gh-pages origin/gh-pages && \ git worktree add tmp-book gh-pages && \ rm -rf tmp-book/* && \ mkdir -p tmp-book/auditors-book && \ cp -a docs/the_nimbus_book/CNAME tmp-book/ && \ cp -a docs/the_nimbus_book/site/* tmp-book/ && \ cp -a docs/the_auditors_handbook/book/* tmp-book/auditors-book/ && \ cd tmp-book && \ git add . && { \ git commit -m "make publish-book $${CURRENT_COMMIT}" && \ git push origin gh-pages || true; } && \ cd .. && \ git worktree remove -f tmp-book && \ rm -rf tmp-book dist-amd64: + MAKE="$(MAKE)" \ scripts/make_dist.sh amd64 dist-amd64-opt: + MAKE="$(MAKE)" \ scripts/make_dist.sh amd64-opt dist-arm64: + MAKE="$(MAKE)" \ scripts/make_dist.sh arm64 dist-arm: + MAKE="$(MAKE)" \ scripts/make_dist.sh arm dist-win64: + MAKE="$(MAKE)" \ scripts/make_dist.sh win64 dist-macos: + MAKE="$(MAKE)" \ scripts/make_dist.sh macos dist-macos-arm64: + MAKE="$(MAKE)" \ scripts/make_dist.sh macos-arm64 dist: + $(MAKE) dist-amd64 + $(MAKE) dist-amd64-opt + $(MAKE) dist-arm64 + $(MAKE) dist-arm + $(MAKE) dist-win64 + $(MAKE) dist-macos + $(MAKE) dist-macos-arm64 #- Build and run benchmarks using an external repo (which can be used easily on # older commits, before this Make target was added). #- It's up to the user to create a benchmarking environment that minimises the # results spread. We're showing a 95% CI bar to help visualise that. benchmarks: + vendor/nimbus-benchmarking/run_nbc_benchmarks.sh --output-type d3 endif # "variables.mk" was not included