2023-01-16 10:34:40 +00:00
# Copyright (c) 2019-2023 Status Research & Development GmbH. Licensed under
2019-03-28 16:18:59 +01:00
# 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.
2019-09-10 02:50:09 +02:00
SHELL := bash # the shell used internally by "make"
2019-08-21 14:45:24 +02:00
# used inside the included makefiles
BUILD_SYSTEM_DIR := vendor/nimbus-build-system
2019-03-28 16:18:59 +01:00
2020-08-27 13:29:23 +02:00
# we set its default value before LOG_LEVEL is used in "variables.mk"
2021-02-19 16:37:00 +01:00
LOG_LEVEL := DEBUG
# used by Make targets that launch a beacon node
RUNTIME_LOG_LEVEL := INFO
2020-08-27 13:29:23 +02:00
2020-11-13 16:00:45 +01:00
LINK_PCRE := 0
2020-04-19 01:25:21 +02:00
# we don't want an error here, so we can handle things later, in the ".DEFAULT" target
2019-08-21 14:45:24 +02:00
- i n c l u d e $( BUILD_SYSTEM_DIR ) / m a k e f i l e s / v a r i a b l e s . m k
2019-03-28 16:18:59 +01:00
2020-07-10 01:41:51 +03:00
NODE_ID := 0
BASE_PORT := 9000
2022-02-12 11:27:43 +00:00
BASE_REST_PORT := 5052
2020-07-10 01:41:51 +03:00
BASE_METRICS_PORT := 8008
2022-07-26 11:38:38 +02:00
# WARNING: Use lazy assignment to allow CI to override.
EXECUTOR_NUMBER ?= 0
2022-02-25 10:22:44 +02:00
2022-06-16 17:11:26 +03:00
SEPOLIA_WEB3_URL := "--web3-url=https://rpc.sepolia.dev --web3-url=https://www.sepoliarpc.space"
2022-02-25 10:22:44 +02:00
GOERLI_WEB3_URL := "--web3-url=wss://goerli.infura.io/ws/v3/809a18497dd74102b5f37d25aae3c85a"
2022-11-30 12:48:08 +02:00
GNOSIS_WEB3_URLS := "--web3-url=https://rpc.gnosischain.com/"
2022-02-25 10:22:44 +02:00
2020-07-10 18:18:14 +03:00
VALIDATORS := 1
2020-08-22 00:05:37 +03:00
CPU_LIMIT := 0
2021-09-09 14:14:19 +02:00
BUILD_END_MSG := "\\x1B[92mBuild completed successfully:\\x1B[39m"
2020-08-22 00:05:37 +03:00
2022-11-04 03:11:11 +02:00
TEST_MODULES_FLAGS := -d:chronicles_log_level= TRACE -d:chronicles_sinks= json[ file]
2020-08-22 00:05:37 +03:00
i f e q ( $( CPU_LIMIT ) , 0 )
2022-05-31 12:45:37 +02:00
CPU_LIMIT_CMD :=
2020-08-22 00:05:37 +03:00
e l s e
2022-05-31 12:45:37 +02:00
CPU_LIMIT_CMD := cpulimit --limit= $( CPU_LIMIT) --foreground --
2022-02-18 15:30:43 +01:00
e n d i f
# TODO: move this to nimbus-build-system
i f e q ( $( shell uname ) , D a r w i n )
2022-05-31 12:45:37 +02:00
# 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
2022-02-18 15:30:43 +01:00
e l s e
2022-05-31 12:45:37 +02:00
SILENCE_WARNINGS :=
2020-08-22 00:05:37 +03:00
e n d i f
2020-07-10 01:41:51 +03:00
2019-12-04 15:40:36 +01:00
# unconditionally built by the default Make target
2020-07-29 21:19:36 +00:00
# TODO re-enable ncli_query if/when it works again
2023-01-16 10:34:40 +00:00
TOOLS_CORE := \
2020-06-11 19:41:43 +03:00
deposit_contract \
2021-04-27 23:46:24 +03:00
resttest \
2020-03-11 02:39:58 +02:00
logtrace \
2020-07-29 21:19:36 +00:00
ncli \
2020-06-11 19:41:43 +03:00
ncli_db \
2022-05-17 16:50:49 +03:00
ncli_split_keystore \
2022-10-19 00:18:36 +02:00
fakeee \
2022-01-22 10:25:30 +01:00
wss_sim \
2020-05-04 07:38:14 +02:00
stack_sizes \
2022-05-31 12:45:37 +02:00
nimbus_light_client \
2020-11-07 20:00:31 +02:00
nimbus_validator_client \
2022-01-17 14:58:33 +02:00
nimbus_signing_node \
2023-02-23 04:10:07 +02:00
validator_db_aggregator \
ncli_testnet
2020-06-24 00:41:38 +02:00
2023-01-16 10:34:40 +00:00
# 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 )
2020-06-11 19:41:43 +03:00
2019-12-04 15:40:36 +01:00
TOOLS_DIRS := \
beacon_chain \
2021-03-03 07:23:05 +01:00
beacon_chain/eth1 \
2019-12-04 15:40:36 +01:00
ncli \
research \
2020-06-10 17:21:32 +02:00
tools
2019-04-13 00:15:38 +02:00
TOOLS_CSV := $( subst $( SPACE) ,$( COMMA) ,$( TOOLS) )
2019-03-28 16:18:59 +01:00
2019-12-04 15:40:36 +01:00
.PHONY : \
all \
deps \
update \
test \
2020-06-16 22:45:52 +03:00
clean_eth2_network_simulation_all \
2019-12-04 15:40:36 +01:00
eth2_network_simulation \
2020-02-13 13:19:12 +01:00
clean \
2020-05-02 16:30:34 +02:00
libbacktrace \
book \
2020-10-15 14:19:41 +02:00
publish-book \
2021-01-07 10:19:29 +01:00
dist-amd64 \
dist-arm64 \
dist-arm \
2021-02-02 23:31:01 +01:00
dist-win64 \
2021-05-19 09:38:13 +03:00
dist-macos \
dist-macos-arm64 \
2022-09-18 07:44:20 +02:00
dist \
local-testnet-minimal \
local-testnet-mainnet
2019-08-21 14:45:24 +02:00
2023-01-13 12:17:53 +02:00
# TODO: Add the installer packages here
PLATFORM_SPECIFIC_TARGETS :=
# TODO Fix the gnosis build on Windows
i f n e q ( $( OS ) , W i n d o w s _ N T )
PLATFORM_SPECIFIC_TARGETS += gnosis-build
e n d i f
2019-12-03 19:52:54 +01:00
i f e q ( $( NIM_PARAMS ) , )
2020-04-19 01:25:21 +02:00
# "variables.mk" was not included, so we update the submodules.
2020-09-16 17:46:05 +02:00
#
# 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).
2020-04-19 01:25:21 +02:00
GIT_SUBMODULE_UPDATE := git submodule update --init --recursive
.DEFAULT :
+@ echo -e " Git submodules not found. Running ' $( GIT_SUBMODULE_UPDATE) '.\n " ; \
2020-04-19 13:36:11 +02:00
$( GIT_SUBMODULE_UPDATE) && \
2020-09-16 17:46:05 +02:00
git submodule foreach --quiet 'git reset --quiet --hard' && \
2020-04-19 01:25:21 +02:00
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?
e l s e # "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 '.'
2023-01-13 12:17:53 +02:00
all : | $( TOOLS ) libnfuzz .so libnfuzz .a $( PLATFORM_SPECIFIC_TARGETS )
2019-08-21 14:45:24 +02:00
# must be included after the default target
- i n c l u d e $( BUILD_SYSTEM_DIR ) / m a k e f i l e s / t a r g e t s . m k
2020-07-28 23:37:12 +03:00
DEPOSITS_DELAY := 0
2020-07-10 01:41:51 +03:00
2020-11-27 02:29:06 +01:00
#- "--define:release" cannot be added to "config.nims"
#- disable Nim's default parallelisation because it starts too many processes for too little gain
2021-10-01 16:15:08 +02:00
#- https://github.com/status-im/nim-libp2p#use-identify-metrics
2023-02-27 11:30:13 +00:00
NIM_PARAMS := -d:release --parallelBuild:1 -d:libp2p_agents_metrics -d:KnownLibP2PAgents= nimbus,lighthouse,lodestar,prysm,teku $( NIM_PARAMS)
2020-11-27 02:29:06 +01:00
2020-02-20 17:41:10 +01:00
i f e q ( $( USE_LIBBACKTRACE ) , 0 )
2022-03-05 15:40:08 +01:00
NIM_PARAMS += -d:disable_libbacktrace
2020-02-20 17:41:10 +01:00
e n d i f
2020-02-13 13:19:12 +01:00
2021-02-14 21:04:54 +01:00
deps : | deps -common nat -libs build /generate_makefile
2020-02-20 17:41:10 +01:00
i f n e q ( $( USE_LIBBACKTRACE ) , 0 )
deps : | libbacktrace
e n d i f
2019-08-21 14:45:24 +02:00
2020-11-27 02:29:06 +01:00
#- deletes binaries that might need to be rebuilt after a Git pull
2019-08-21 14:45:24 +02:00
update : | update -common
2020-11-27 02:29:06 +01:00
rm -f build/generate_makefile
2021-03-17 17:29:34 +00:00
rm -fr nimcache/
2019-08-21 14:45:24 +02:00
2020-02-13 13:19:12 +01:00
# nim-libbacktrace
libbacktrace :
2020-09-04 08:33:37 +02:00
+ " $( MAKE) " -C vendor/nim-libbacktrace --no-print-directory BUILD_CXX_LIB = 0
2020-02-13 13:19:12 +01:00
2022-07-23 16:28:10 +02:00
# 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
#
# EXECUTOR_NUMBER: [0, 1] (depends on max number of concurrent CI jobs)
#
# The following port ranges are allocated (entire continuous range):
2022-11-30 15:29:08 +01:00
#
# Unit tests:
# - NIMBUS_TEST_KEYMANAGER_BASE_PORT + [0, 4)
#
# REST tests:
# - --base-port
# - --base-rest-port
# - --base-metrics-port
#
# Local testnets (entire continuous range):
2022-07-23 16:28:10 +02:00
# - --base-port + [0, --nodes + --light-clients)
# - --base-rest-port + [0, --nodes)
# - --base-metrics-port + [0, --nodes)
2023-01-04 18:59:35 +01:00
# - --base-vc-keymanager-port + [0, --nodes)
2022-11-30 12:47:11 +02:00
# - --base-vc-metrics-port + [0, --nodes]
2023-02-23 04:10:07 +02:00
# - --base-remote-signer-port + [0, --nimbus-signer-nodes | --web3signer-nodes)
# - --base-remote-signer-metrics-port + [0, --nimbus-signer-node | --web3signer-nodes)
2022-07-23 16:28:10 +02:00
#
2022-11-30 15:29:08 +01:00
# Local testnets with --run-geth or --run-nimbus (only these ports):
2022-07-23 16:28:10 +02:00
# - --base-el-net-port + --el-port-offset * [0, --nodes + --light-clients)
2023-02-23 04:10:07 +02:00
# - --base-el-rpc-port + --el-port-offset * [0, --nodes + --light-clients)
2022-07-23 16:28:10 +02:00
# - --base-el-ws-port + --el-port-offset * [0, --nodes + --light-clients)
# - --base-el-auth-rpc-port + --el-port-offset * [0, --nodes + --light-clients)
2022-11-30 15:29:08 +01:00
UNIT_TEST_BASE_PORT := 9950
2022-07-23 16:28:10 +02:00
2022-06-19 20:54:12 +03:00
restapi-test :
./tests/simulation/restapi.sh \
--data-dir resttest0_data \
2022-07-23 16:28:10 +02:00
--base-port $$ ( ( 5001 + EXECUTOR_NUMBER * 500 ) ) \
--base-rest-port $$ ( ( 5031 + EXECUTOR_NUMBER * 500 ) ) \
--base-metrics-port $$ ( ( 5061 + EXECUTOR_NUMBER * 500 ) ) \
2022-06-19 20:54:12 +03:00
--resttest-delay 30 \
--kill-old-processes
2022-07-15 03:19:19 +03:00
local-testnet-minimal :
./scripts/launch_local_testnet.sh \
2022-07-22 00:34:31 +02:00
--data-dir $@ \
2022-07-15 03:19:19 +03:00
--preset minimal \
2023-02-23 04:10:07 +02:00
--nodes 2 \
--capella-fork-epoch 3 \
--deneb-fork-epoch 20 \
2022-09-19 13:10:47 +02:00
--stop-at-epoch 6 \
2022-07-15 03:19:19 +03:00
--disable-htop \
2023-02-23 04:10:07 +02:00
--enable-payload-builder \
2022-07-15 03:19:19 +03:00
--enable-logtrace \
2022-07-23 16:28:10 +02:00
--base-port $$ ( ( 6001 + EXECUTOR_NUMBER * 500 ) ) \
--base-rest-port $$ ( ( 6031 + EXECUTOR_NUMBER * 500 ) ) \
--base-metrics-port $$ ( ( 6061 + EXECUTOR_NUMBER * 500 ) ) \
2023-01-04 18:59:35 +01:00
--base-vc-keymanager-port $$ ( ( 6131 + EXECUTOR_NUMBER * 500 ) ) \
2022-11-30 12:47:11 +02:00
--base-vc-metrics-port $$ ( ( 6161 + EXECUTOR_NUMBER * 500 ) ) \
--base-remote-signer-port $$ ( ( 6201 + EXECUTOR_NUMBER * 500 ) ) \
2023-02-23 04:10:07 +02:00
--base-remote-signer-metrics-port $$ ( ( 6251 + EXECUTOR_NUMBER * 500 ) ) \
2022-11-30 12:47:11 +02:00
--base-el-net-port $$ ( ( 6301 + EXECUTOR_NUMBER * 500 ) ) \
2023-02-23 04:10:07 +02:00
--base-el-rpc-port $$ ( ( 6302 + EXECUTOR_NUMBER * 500 ) ) \
2022-11-30 12:47:11 +02:00
--base-el-ws-port $$ ( ( 6303 + EXECUTOR_NUMBER * 500 ) ) \
--base-el-auth-rpc-port $$ ( ( 6304 + EXECUTOR_NUMBER * 500 ) ) \
2022-07-23 16:28:10 +02:00
--el-port-offset 5 \
2022-09-19 13:10:47 +02:00
--timeout 648 \
2022-07-15 03:19:19 +03:00
--kill-old-processes \
2023-02-23 04:10:07 +02:00
--run-geth --dl-geth \
2022-07-15 03:19:19 +03:00
-- \
--verify-finalization \
--discv5:no
local-testnet-mainnet :
./scripts/launch_local_testnet.sh \
2022-07-22 00:34:31 +02:00
--data-dir $@ \
2023-02-23 04:10:07 +02:00
--nodes 2 \
2023-04-20 15:18:35 +00:00
--capella-fork-epoch 3 \
2022-09-19 13:10:47 +02:00
--stop-at-epoch 6 \
2022-07-15 03:19:19 +03:00
--disable-htop \
--enable-logtrace \
2022-07-23 16:28:10 +02:00
--base-port $$ ( ( 7001 + EXECUTOR_NUMBER * 500 ) ) \
--base-rest-port $$ ( ( 7031 + EXECUTOR_NUMBER * 500 ) ) \
--base-metrics-port $$ ( ( 7061 + EXECUTOR_NUMBER * 500 ) ) \
2023-01-04 18:59:35 +01:00
--base-vc-keymanager-port $$ ( ( 7131 + EXECUTOR_NUMBER * 500 ) ) \
2022-11-30 12:47:11 +02:00
--base-vc-metrics-port $$ ( ( 7161 + EXECUTOR_NUMBER * 500 ) ) \
--base-remote-signer-port $$ ( ( 7201 + EXECUTOR_NUMBER * 500 ) ) \
2023-02-23 04:10:07 +02:00
--base-remote-signer-metrics-port $$ ( ( 7251 + EXECUTOR_NUMBER * 500 ) ) \
2022-11-30 12:47:11 +02:00
--base-el-net-port $$ ( ( 7301 + EXECUTOR_NUMBER * 500 ) ) \
2023-02-23 04:10:07 +02:00
--base-el-rpc-port $$ ( ( 7302 + EXECUTOR_NUMBER * 500 ) ) \
2022-11-30 12:47:11 +02:00
--base-el-ws-port $$ ( ( 7303 + EXECUTOR_NUMBER * 500 ) ) \
--base-el-auth-rpc-port $$ ( ( 7304 + EXECUTOR_NUMBER * 500 ) ) \
2022-07-23 16:28:10 +02:00
--el-port-offset 5 \
2022-09-19 13:10:47 +02:00
--timeout 2784 \
2022-07-15 03:19:19 +03:00
--kill-old-processes \
2023-02-23 04:10:07 +02:00
--run-geth --dl-geth \
2022-07-15 03:19:19 +03:00
-- \
--verify-finalization \
--discv5:no
2021-04-28 18:41:02 +02:00
# test binaries that can output an XML report
2023-01-16 10:34:40 +00:00
XML_TEST_BINARIES_CORE := \
2023-01-31 13:35:01 +01:00
consensus_spec_tests_minimal \
consensus_spec_tests_mainnet
2023-01-16 10:34:40 +00:00
XML_TEST_BINARIES := \
$( XML_TEST_BINARIES_CORE) \
2021-10-12 13:36:52 +02:00
all_tests
2021-04-28 18:41:02 +02:00
# test suite
TEST_BINARIES := \
2021-02-14 21:04:54 +01:00
state_sim \
block_sim
2023-01-16 10:34:40 +00:00
.PHONY : $( TEST_BINARIES ) $( XML_TEST_BINARIES ) force_build_alone_all_tests
2021-02-14 21:04:54 +01:00
2021-10-12 13:36:52 +02:00
# Preset-dependent tests
consensus_spec_tests_mainnet : | build deps
2021-02-14 21:04:54 +01:00
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
2021-02-14 21:04:54 +01:00
$@ \
2021-10-12 13:36:52 +02:00
"tests/consensus_spec/consensus_spec_tests_preset.nim" \
2022-11-04 03:11:11 +02:00
$( NIM_PARAMS) -d:const_preset= mainnet $( TEST_MODULES_FLAGS) && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
2021-10-12 13:36:52 +02:00
consensus_spec_tests_minimal : | build deps
2021-07-13 06:38:35 +00:00
+ echo -e $( BUILD_MSG) " build/ $@ " && \
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
$@ \
2021-10-12 13:36:52 +02:00
"tests/consensus_spec/consensus_spec_tests_preset.nim" \
2022-11-04 03:11:11 +02:00
$( NIM_PARAMS) -d:const_preset= minimal $( TEST_MODULES_FLAGS) && \
2021-07-13 06:38:35 +00:00
echo -e $( BUILD_END_MSG) " build/ $@ "
2021-10-12 13:36:52 +02:00
# Tests we only run for the default preset
2021-02-14 21:04:54 +01:00
proto_array : | build deps
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
2021-02-14 21:04:54 +01:00
$@ \
" beacon_chain/fork_choice/ $@ .nim " \
2022-11-04 03:11:11 +02:00
$( NIM_PARAMS) $( TEST_MODULES_FLAGS) && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
fork_choice : | build deps
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
2021-02-14 21:04:54 +01:00
$@ \
" beacon_chain/fork_choice/ $@ .nim " \
2022-11-04 03:11:11 +02:00
$( NIM_PARAMS) $( TEST_MODULES_FLAGS) && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
2023-01-16 10:34:40 +00:00
# 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 state_sim`, it intentionally allows
# those in paralle, because the CI system does 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.
i f n e q ( , $( filter test ,$ ( MAKECMDGOALS ) ) )
FORCE_BUILD_ALONE_ALL_TESTS_DEPS := $( XML_TEST_BINARIES_CORE) $( TEST_BINARIES)
e l s e
FORCE_BUILD_ALONE_ALL_TESTS_DEPS :=
e n d i f
force_build_alone_all_tests : | $( FORCE_BUILD_ALONE_ALL_TESTS_DEPS )
2023-04-06 16:16:21 +03:00
all_tests : | build deps nimbus_signing_node force_build_alone_all_tests
2021-02-14 21:04:54 +01:00
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
2021-02-14 21:04:54 +01:00
$@ \
" tests/ $@ .nim " \
2022-11-04 03:11:11 +02:00
$( NIM_PARAMS) $( TEST_MODULES_FLAGS) && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
# State and block sims; getting to 4th epoch triggers consensus checks
state_sim : | build deps
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
2021-02-14 21:04:54 +01:00
$@ \
" research/ $@ .nim " \
2021-10-12 13:36:52 +02:00
$( NIM_PARAMS) && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
block_sim : | build deps
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh \
2021-02-14 21:04:54 +01:00
$@ \
" research/ $@ .nim " \
2021-10-12 13:36:52 +02:00
$( NIM_PARAMS) && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
2019-11-22 14:21:16 +01:00
DISABLE_TEST_FIXTURES_SCRIPT := 0
2021-02-14 21:04:54 +01:00
# This parameter passing scheme is ugly, but short.
2021-04-28 18:41:02 +02:00
test : | $( XML_TEST_BINARIES ) $( TEST_BINARIES )
2019-11-22 14:21:16 +01:00
i f e q ( $( DISABLE_TEST_FIXTURES_SCRIPT ) , 0 )
2021-10-12 13:36:52 +02:00
V = $( V) scripts/setup_scenarios.sh
2019-08-14 23:53:48 +02:00
e n d i f
2021-04-28 18:41:02 +02:00
for TEST_BINARY in $( XML_TEST_BINARIES) ; do \
PARAMS = " --xml:build/ $$ {TEST_BINARY}.xml --console " ; \
echo -e " \nRunning $$ {TEST_BINARY} $$ {PARAMS}\n " ; \
2022-11-30 15:29:08 +01:00
NIMBUS_TEST_KEYMANAGER_BASE_PORT = $$ ( ( $( UNIT_TEST_BASE_PORT) + EXECUTOR_NUMBER * 25 ) ) \
build/$$ { TEST_BINARY} $$ { PARAMS} || { \
echo -e " \n $$ {TEST_BINARY} $$ {PARAMS} failed; Last 50 lines from the log: " ; \
tail -n50 " $$ {TEST_BINARY}.log " ; exit 1; \
} ; \
2021-04-28 18:41:02 +02:00
done ; \
rm -rf 0000-*.json t_slashprot_migration.* *.log block_sim_db
2021-02-14 21:04:54 +01:00
for TEST_BINARY in $( TEST_BINARIES) ; do \
PARAMS = "" ; \
2021-06-23 14:43:18 +00:00
if [ [ " $$ {TEST_BINARY} " = = "state_sim" ] ] ; then PARAMS = "--validators=8000 --slots=160" ; \
elif [ [ " $$ {TEST_BINARY} " = = "block_sim" ] ] ; then PARAMS = "--validators=8000 --slots=160" ; \
2021-02-14 21:04:54 +01:00
fi ; \
echo -e " \nRunning $$ {TEST_BINARY} $$ {PARAMS}\n " ; \
2022-11-30 15:29:08 +01:00
build/$$ { TEST_BINARY} $$ { PARAMS} || { \
echo -e " \n $$ {TEST_BINARY} $$ {PARAMS} failed; Last 50 lines from the log: " ; \
tail -n50 " $$ {TEST_BINARY}.log " ; exit 1; \
} ; \
2021-02-14 21:04:54 +01:00
done ; \
rm -rf 0000-*.json t_slashprot_migration.* *.log block_sim_db
2019-03-28 16:18:59 +01:00
2020-11-27 02:29:06 +01:00
# It's OK to only build this once. `make update` deletes the binary, forcing a rebuild.
i f n e q ( $( USE_LIBBACKTRACE ) , 0 )
build/generate_makefile : | libbacktrace
e n d i f
build/generate_makefile : tools /generate_makefile .nim | deps -common
2021-06-01 15:22:21 +02:00
+ echo -e $( BUILD_MSG) " $@ " && \
2022-11-24 21:56:02 +01:00
$( ENV_SCRIPT) $( NIMC) c -o:$@ $( NIM_PARAMS) tools/generate_makefile.nim $( SILENCE_WARNINGS) && \
2021-02-23 20:39:10 +01:00
echo -e $( BUILD_END_MSG) " $@ "
2020-11-27 02:29:06 +01:00
# 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.
2019-09-05 10:50:38 +02:00
$(TOOLS) : | build deps
2020-11-24 20:26:37 +01:00
+ for D in $( TOOLS_DIRS) ; do [ -e " $$ {D}/ $@ .nim " ] && TOOL_DIR = " $$ {D} " && break; done && \
2019-03-29 18:21:14 +01:00
echo -e $( BUILD_MSG) " build/ $@ " && \
2021-02-15 18:08:18 +01:00
MAKE = " $( MAKE) " V = " $( V) " $( ENV_SCRIPT) scripts/compile_nim_program.sh $@ " $$ {TOOL_DIR}/ $@ .nim " $( NIM_PARAMS) && \
2020-11-26 03:15:37 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
2019-03-28 16:18:59 +01:00
2023-01-16 10:34:40 +00:00
# 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
2023-01-20 14:14:08 +00:00
# intentionally allows those in parallel, as the CI systems don't do that.
2023-01-16 10:34:40 +00:00
#
# 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.
i f n e q ( , $( filter all ,$ ( MAKECMDGOALS ) ) )
FORCE_BUILD_ALONE_TOOLS_DEPS := $( TOOLS_CORE)
2023-01-20 14:14:08 +00:00
# If this isn't an included target (such as Windows), this is a no-op)
gnosis-build : | nimbus_beacon_node
2023-01-16 10:34:40 +00:00
e l s e i f e q ( , $( MAKECMDGOALS ) )
FORCE_BUILD_ALONE_TOOLS_DEPS := $( TOOLS_CORE)
2023-01-20 14:14:08 +00:00
# If this isn't an included target (such as Windows), this is a no-op)
gnosis-build : | nimbus_beacon_node
2023-01-16 10:34:40 +00:00
e l s e
FORCE_BUILD_ALONE_TOOLS_DEPS :=
e n d i f
.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
2020-06-16 22:45:52 +03:00
clean_eth2_network_simulation_data :
2020-06-19 20:42:28 +03:00
rm -rf tests/simulation/data
2020-06-16 22:45:52 +03:00
clean_eth2_network_simulation_all :
2019-04-17 17:54:28 +02:00
rm -rf tests/simulation/{ data,validators}
2019-03-28 16:18:59 +01:00
2020-07-10 01:41:51 +03:00
GOERLI_TESTNETS_PARAMS := \
2022-05-31 12:45:37 +02:00
--tcp-port= $$ ( ( $( BASE_PORT) + $( NODE_ID) ) ) \
--udp-port= $$ ( ( $( BASE_PORT) + $( NODE_ID) ) ) \
--metrics \
--metrics-port= $$ ( ( $( BASE_METRICS_PORT) + $( NODE_ID) ) ) \
--rest \
2022-09-18 07:44:20 +02:00
--rest-port= $$ ( ( $( BASE_REST_PORT) + $( NODE_ID) ) )
2020-07-10 01:41:51 +03:00
2020-07-23 17:58:54 +02:00
eth2_network_simulation : | build deps clean_eth 2_network_simulation_all
2020-06-16 21:38:51 +03:00
+ GIT_ROOT = " $$ PWD " NIMFLAGS = " $( NIMFLAGS) " LOG_LEVEL = " $( LOG_LEVEL) " tests/simulation/start-in-tmux.sh
2020-07-23 17:58:54 +02:00
killall prometheus & >/dev/null
2019-03-28 16:18:59 +01:00
2020-10-06 17:18:02 +02:00
#- 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
d e f i n e C O N N E C T _ T O _ N E T W O R K
2022-05-31 12:45:37 +02:00
scripts/makedir.sh build/data/shared_$( 1) _$( NODE_ID)
2020-08-06 15:21:07 +03:00
2020-08-05 15:51:55 +03:00
scripts/make_prometheus_config.sh \
--nodes 1 \
--base-metrics-port $$ ( ( $( BASE_METRICS_PORT) + $( NODE_ID) ) ) \
2020-09-21 17:19:34 +03:00
--config-file " build/data/shared_ $( 1) _ $( NODE_ID) /prometheus.yml "
2020-08-05 15:51:55 +03:00
2020-10-16 21:48:27 +03:00
$( CPU_LIMIT_CMD) build/$( 2) \
2022-02-25 10:22:44 +02:00
--network= $( 1) $( 3) $( GOERLI_TESTNETS_PARAMS) \
2021-02-19 16:37:00 +01:00
--log-level= " $( RUNTIME_LOG_LEVEL) " \
2020-09-21 17:19:34 +03:00
--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) \
2022-02-25 10:22:44 +02:00
$( NODE_PARAMS)
2020-09-21 17:19:34 +03:00
e n d e f
2020-04-27 22:03:03 +03:00
2020-10-06 17:18:02 +02:00
d e f i n e C O N N E C T _ T O _ N E T W O R K _ I N _ D E V _ M O D E
2022-05-31 12:45:37 +02:00
scripts/makedir.sh build/data/shared_$( 1) _$( NODE_ID)
2020-09-21 17:19:34 +03:00
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 "
2020-10-16 21:48:27 +03:00
$( CPU_LIMIT_CMD) build/$( 2) \
2022-02-25 10:22:44 +02:00
--network= $( 1) $( 3) $( GOERLI_TESTNETS_PARAMS) \
2020-09-21 17:19:34 +03:00
--log-level= "DEBUG; TRACE:discv5,networking; REQUIRED:none; DISABLED:none" \
--data-dir= build/data/shared_$( 1) _$( NODE_ID) \
2022-02-25 10:22:44 +02:00
--dump $( NODE_PARAMS)
2020-09-21 17:19:34 +03:00
e n d e f
2020-09-28 19:13:36 +02:00
d e f i n e C O N N E C T _ T O _ N E T W O R K _ W I T H _ V A L I D A T O R _ C L I E N T
2020-07-28 18:14:13 +03:00
# if launching a VC as well - send the BN looking nowhere for validators/secrets
2020-10-12 16:04:21 +03:00
scripts/makedir.sh build/data/shared_$( 1) _$( NODE_ID)
scripts/makedir.sh build/data/shared_$( 1) _$( NODE_ID) /empty_dummy_folder
2020-08-05 15:51:55 +03:00
scripts/make_prometheus_config.sh \
--nodes 1 \
--base-metrics-port $$ ( ( $( BASE_METRICS_PORT) + $( NODE_ID) ) ) \
2020-09-21 17:19:34 +03:00
--config-file " build/data/shared_ $( 1) _ $( NODE_ID) /prometheus.yml "
2020-08-05 15:51:55 +03:00
2020-10-16 21:48:27 +03:00
$( CPU_LIMIT_CMD) build/$( 2) \
2022-02-25 10:22:44 +02:00
--network= $( 1) $( 3) $( GOERLI_TESTNETS_PARAMS) \
2021-02-19 16:37:00 +01:00
--log-level= " $( RUNTIME_LOG_LEVEL) " \
2020-09-21 17:19:34 +03:00
--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 \
2022-02-25 10:22:44 +02:00
$( NODE_PARAMS) &
2020-08-05 15:51:55 +03:00
2020-07-28 18:14:13 +03:00
sleep 4
2020-08-05 15:51:55 +03:00
2020-11-07 20:00:31 +02:00
build/nimbus_validator_client \
2021-02-19 16:37:00 +01:00
--log-level= " $( RUNTIME_LOG_LEVEL) " \
2020-09-21 17:19:34 +03:00
--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) \
2022-09-18 07:44:20 +02:00
--rest-port= $$ ( ( $( BASE_REST_PORT) + $( NODE_ID) ) )
2020-09-21 17:19:34 +03:00
e n d e f
2020-07-28 18:14:13 +03:00
2022-05-31 12:45:37 +02:00
d e f i n e C O N N E C T _ T O _ N E T W O R K _ W I T H _ L I G H T _ C L I E N T
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 \
2022-07-14 06:07:40 +02:00
--data-dir= build/data/shared_$( 1) _$( NODE_ID) \
2022-05-31 12:45:37 +02:00
--trusted-block-root= " $( LC_TRUSTED_BLOCK_ROOT) "
e n d e f
2020-09-28 19:13:36 +02:00
d e f i n e M A K E _ D E P O S I T _ D A T A
2021-04-08 14:35:58 +03:00
build/nimbus_beacon_node deposits createTestnetDeposits \
2020-09-21 17:19:34 +03:00
--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 \
2020-07-17 23:59:50 +03:00
--count= $( VALIDATORS)
2020-09-21 17:19:34 +03:00
e n d e f
2020-07-17 23:59:50 +03:00
2020-09-28 19:13:36 +02:00
d e f i n e M A K E _ D E P O S I T
2021-04-08 14:35:58 +03:00
build/nimbus_beacon_node deposits createTestnetDeposits \
2020-09-21 17:19:34 +03:00
--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 \
2020-07-28 23:37:12 +03:00
--count= $( VALIDATORS)
build/deposit_contract sendDeposits \
2022-02-25 10:22:44 +02:00
$( 2) \
2022-05-10 03:32:12 +03:00
--deposit-contract= $$ ( cat vendor/eth2-networks/shared/$( 1) /deposit_contract.txt) \
2020-09-21 17:19:34 +03:00
--deposits-file= nbc-$( 1) -deposits.json \
2020-07-28 23:37:12 +03:00
--min-delay= $( DEPOSITS_DELAY) \
2022-05-10 03:32:12 +03:00
--max-delay= $( DEPOSITS_DELAY) \
2020-07-28 23:37:12 +03:00
--ask-for-key
2020-09-21 17:19:34 +03:00
e n d e f
2020-09-28 19:13:36 +02:00
d e f i n e C L E A N _ N E T W O R K
2020-09-21 17:19:34 +03:00
rm -rf build/data/shared_$( 1) */db
rm -rf build/data/shared_$( 1) */dump
rm -rf build/data/shared_$( 1) */*.log
e n d e f
2021-03-15 21:49:53 +02:00
###
### Prater
###
2021-11-30 03:20:21 +02:00
prater-build : | nimbus_beacon_node nimbus_signing_node
2021-03-15 21:49:53 +02:00
# https://www.gnu.org/software/make/manual/html_node/Call-Function.html#Call-Function
prater : | prater -build
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK,prater,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
2021-03-15 21:49:53 +02:00
prater-vc : | prater -build nimbus_validator_client
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK_WITH_VALIDATOR_CLIENT,prater,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
2021-03-15 21:49:53 +02:00
2022-05-31 12:45:37 +02:00
prater-lc : | nimbus_light_client
$( call CONNECT_TO_NETWORK_WITH_LIGHT_CLIENT,prater)
2021-03-15 21:49:53 +02:00
i f n e q ( $( LOG_LEVEL ) , T R A C E )
prater-dev :
+ " $( MAKE) " LOG_LEVEL = TRACE $@
e l s e
prater-dev : | prater -build
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,prater,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
2021-03-15 21:49:53 +02:00
e n d i f
prater-dev-deposit : | prater -build deposit_contract
2022-02-25 10:22:44 +02:00
$( call MAKE_DEPOSIT,prater,$( GOERLI_WEB3_URL) )
2021-03-15 21:49:53 +02:00
clean-prater :
$( call CLEAN_NETWORK,prater)
2022-07-14 23:07:16 +03:00
###
### Goerli
###
goerli-build : | nimbus_beacon_node nimbus_signing_node
# https://www.gnu.org/software/make/manual/html_node/Call-Function.html#Call-Function
goerli : | goerli -build
$( call CONNECT_TO_NETWORK,goerli,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
goerli-vc : | goerli -build nimbus_validator_client
$( call CONNECT_TO_NETWORK_WITH_VALIDATOR_CLIENT,goerli,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
goerli-lc : | nimbus_light_client
$( call CONNECT_TO_NETWORK_WITH_LIGHT_CLIENT,goerli)
i f n e q ( $( LOG_LEVEL ) , T R A C E )
goerli-dev :
+ " $( MAKE) " LOG_LEVEL = TRACE $@
e l s e
goerli-dev : | goerli -build
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,goerli,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
e n d i f
goerli-dev-deposit : | goerli -build deposit_contract
$( call MAKE_DEPOSIT,goerli,$( GOERLI_WEB3_URL) )
clean-goerli :
$( call CLEAN_NETWORK,goerli)
2022-06-16 17:11:26 +03:00
###
### 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)
i f n e q ( $( LOG_LEVEL ) , T R A C E )
sepolia-dev :
+ " $( MAKE) " LOG_LEVEL = TRACE $@
e l s e
sepolia-dev : | sepolia -build
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,sepolia,nimbus_beacon_node,$( SEPOLIA_WEB3_URL) )
e n d i f
sepolia-dev-deposit : | sepolia -build deposit_contract
$( call MAKE_DEPOSIT,sepolia,$( SEPOLIA_WEB3_URL) )
clean-sepolia :
$( call CLEAN_NETWORK,sepolia)
2022-02-25 10:22:44 +02:00
###
### Gnosis chain binary
###
2023-01-12 19:58:42 +02:00
# TODO The `-d:gnosisChainBinary` override can be removed if the web3 library
2022-02-25 10:22:44 +02:00
# 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.
2022-04-08 22:11:37 +02:00
gnosis-build gnosis-chain-build : | build deps
2022-03-15 14:56:01 +01:00
+ 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 \
2023-01-12 19:58:42 +02:00
-d:const_preset= gnosis \
2022-03-15 14:56:01 +01:00
&& \
echo -e $( BUILD_END_MSG) "build/nimbus_beacon_node_gnosis"
2022-02-25 10:22:44 +02:00
2022-04-08 22:11:37 +02:00
gnosis : | gnosis -build
$( call CONNECT_TO_NETWORK,gnosis,nimbus_beacon_node_gnosis,$( GNOSIS_WEB3_URLS) )
i f n e q ( $( LOG_LEVEL ) , T R A C E )
gnosis-dev :
+ " $( MAKE) " --no-print-directory LOG_LEVEL = TRACE $@
e l s e
gnosis-dev : | gnosis -build
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,gnosis,nimbus_beacon_node_gnosis,$( GNOSIS_WEB3_URLS) )
e n d i f
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
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK,gnosis-chain,nimbus_beacon_node_gnosis,$( GNOSIS_WEB3_URLS) )
i f n e q ( $( LOG_LEVEL ) , T R A C E )
gnosis-chain-dev :
2022-03-15 14:56:01 +01:00
+ " $( MAKE) " --no-print-directory LOG_LEVEL = TRACE $@
2022-02-25 10:22:44 +02:00
e l s e
2022-04-08 22:11:37 +02:00
gnosis-chain-dev : | gnosis -build
echo ` gnosis-chain-dev` is deprecated, use ` gnosis-dev` instead
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,gnosis-chain,nimbus_beacon_node_gnosis,$( GNOSIS_WEB3_URLS) )
e n d i f
2022-04-08 22:11:37 +02:00
gnosis-chain-dev-deposit : | gnosis -build deposit_contract
echo ` gnosis-chain-dev-deposit` is deprecated, use ` gnosis-chain-dev-deposit` instead
2022-02-25 10:22:44 +02:00
$( call MAKE_DEPOSIT,gnosis-chain,$( GNOSIS_WEB3_URLS) )
clean-gnosis-chain :
$( call CLEAN_NETWORK,gnosis-chain)
2021-03-15 21:49:53 +02:00
###
### Other
###
2022-02-27 13:02:57 +02:00
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
2022-02-28 00:08:38 +02:00
nimbus-pkg : | nimbus_beacon_node
xcodebuild -project installer/macos/nimbus-pkg.xcodeproj -scheme nimbus-pkg build
packagesbuild installer/macos/nimbus-pkg.pkgproj
2020-06-11 19:41:43 +03:00
ntu : | build deps
mkdir -p vendor/.nimble/bin/
2022-11-24 21:56:02 +01:00
+ $( ENV_SCRIPT) $( NIMC) -d:danger -o:vendor/.nimble/bin/ntu c vendor/nim-testutils/ntu.nim
2020-06-11 19:41:43 +03:00
2019-08-21 14:45:24 +02:00
clean : | clean -common
2022-02-27 13:02:57 +02:00
rm -rf build/{ $( TOOLS_CSV) ,all_tests,test_*,proto_array,fork_choice,*.a,*.so,*_node,*ssz*,nimbus_*,beacon_node*,block_sim,state_sim,transition*,generate_makefile,nimbus-wix/obj}
2020-02-20 17:41:10 +01:00
i f n e q ( $( USE_LIBBACKTRACE ) , 0 )
2020-09-04 08:33:37 +02:00
+ " $( MAKE) " -C vendor/nim-libbacktrace clean $( HANDLE_OUTPUT)
2020-02-20 17:41:10 +01:00
e n d i f
2019-11-27 21:43:02 +01:00
2020-03-05 18:56:07 +01:00
libnfuzz.so : | build deps
2020-11-24 20:26:37 +01:00
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2022-11-24 21:56:02 +01:00
$( ENV_SCRIPT) $( NIMC) c -d:release --app:lib --noMain --nimcache:nimcache/libnfuzz -o:build/$@ .0 $( NIM_PARAMS) nfuzz/libnfuzz.nim $( SILENCE_WARNINGS) && \
2020-11-26 03:15:37 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ " && \
2019-11-27 21:43:02 +01:00
rm -f build/$@ && \
ln -s $@ .0 build/$@
2020-03-05 18:56:07 +01:00
libnfuzz.a : | build deps
2020-11-24 20:26:37 +01:00
+ echo -e $( BUILD_MSG) " build/ $@ " && \
2019-11-27 21:43:02 +01:00
rm -f build/$@ && \
2022-11-24 21:56:02 +01:00
$( ENV_SCRIPT) $( NIMC) c -d:release --app:staticlib --noMain --nimcache:nimcache/libnfuzz_static -o:build/$@ $( NIM_PARAMS) nfuzz/libnfuzz.nim $( SILENCE_WARNINGS) && \
2020-11-26 03:15:37 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ " && \
2020-11-24 17:27:21 +01:00
[ [ -e " $@ " ] ] && mv " $@ " build/ || true # workaround for https://github.com/nim-lang/Nim/issues/12745
2020-04-19 01:25:21 +02:00
2020-05-02 16:30:34 +02:00
book :
2022-07-22 21:47:24 +02:00
" $( MAKE) " -C docs book
auditors-book :
2022-06-20 22:04:46 +02:00
[ [ " $$ (mdbook --version) " = "mdbook v0.4.18" ] ] || { echo "'mdbook v0.4.18' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
[ [ " $$ (mdbook-toc --version) " = = "mdbook-toc 0.8.0" ] ] || { echo "'mdbook-toc 0.8.0' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
[ [ " $$ (mdbook-open-on-gh --version) " = = "mdbook-open-on-gh 2.1.0" ] ] || { echo "'mdbook-open-on-gh 2.1.0' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
2022-07-21 20:19:47 +02:00
[ [ " $$ (mdbook-admonish --version) " = = "mdbook-admonish 1.7.0" ] ] || { echo "'mdbook-open-on-gh 1.7.0' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
2020-07-07 10:44:21 +02:00
cd docs/the_auditors_handbook && \
mdbook build
2020-07-13 12:46:42 +02:00
publish-book : | book auditors -book
2021-02-15 08:33:49 +01:00
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
2020-07-13 12:46:42 +02:00
git branch -D gh-pages && \
git branch --track gh-pages origin/gh-pages && \
2020-07-07 10:44:21 +02:00
git worktree add tmp-book gh-pages && \
2020-07-13 12:46:42 +02:00
rm -rf tmp-book/* && \
2020-07-07 10:44:21 +02:00
mkdir -p tmp-book/auditors-book && \
2021-01-22 17:57:55 +01:00
cp -a docs/the_nimbus_book/CNAME tmp-book/ && \
2022-07-22 21:47:24 +02:00
cp -a docs/the_nimbus_book/site/* tmp-book/ && \
2020-07-07 10:44:21 +02:00
cp -a docs/the_auditors_handbook/book/* tmp-book/auditors-book/ && \
cd tmp-book && \
git add . && { \
2022-06-20 22:04:46 +02:00
git commit -m " make publish-book $$ (git rev-parse --short HEAD) " && \
2020-07-07 10:44:21 +02:00
git push origin gh-pages || true; } && \
cd .. && \
git worktree remove -f tmp-book && \
rm -rf tmp-book
2021-01-07 10:19:29 +01:00
dist-amd64 :
2021-03-10 03:59:19 +01:00
+ MAKE = " $( MAKE) " \
2021-01-07 10:19:29 +01:00
scripts/make_dist.sh amd64
dist-arm64 :
2021-03-10 03:59:19 +01:00
+ MAKE = " $( MAKE) " \
2021-01-07 10:19:29 +01:00
scripts/make_dist.sh arm64
dist-arm :
2021-03-10 03:59:19 +01:00
+ MAKE = " $( MAKE) " \
2021-01-07 10:19:29 +01:00
scripts/make_dist.sh arm
2021-02-02 23:31:01 +01:00
dist-win64 :
2021-03-10 03:59:19 +01:00
+ MAKE = " $( MAKE) " \
2021-02-02 23:31:01 +01:00
scripts/make_dist.sh win64
2021-05-19 09:38:13 +03:00
dist-macos :
+ MAKE = " $( MAKE) " \
scripts/make_dist.sh macos
dist-macos-arm64 :
+ MAKE = " $( MAKE) " \
scripts/make_dist.sh macos-arm64
2020-10-15 14:19:41 +02:00
dist :
2021-03-10 03:59:19 +01:00
+ $( MAKE) dist-amd64
+ $( MAKE) dist-arm64
+ $( MAKE) dist-arm
+ $( MAKE) dist-win64
2021-05-19 09:38:13 +03:00
+ $( MAKE) dist-macos
+ $( MAKE) dist-macos-arm64
2020-10-15 14:19:41 +02:00
2020-12-11 12:12:43 +01:00
#- 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
2020-04-19 01:25:21 +02:00
e n d i f # "variables.mk" was not included