2022-02-12 11:27:43 +00:00
# Copyright (c) 2019-2022 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-02-25 10:22:44 +02:00
GOERLI_WEB3_URL := "--web3-url=wss://goerli.infura.io/ws/v3/809a18497dd74102b5f37d25aae3c85a"
GNOSIS_WEB3_URLS := "--web3-url=wss://rpc.gnosischain.com/wss --web3-url=wss://xdai.poanetwork.dev/wss"
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
i f e q ( $( CPU_LIMIT ) , 0 )
2022-02-18 15:30:43 +01:00
CPU_LIMIT_CMD :=
2020-08-22 00:05:37 +03:00
e l s e
2022-02-18 15:30:43 +01:00
CPU_LIMIT_CMD := cpulimit --limit= $( CPU_LIMIT) --foreground --
e n d i f
# TODO: move this to nimbus-build-system
i f e q ( $( shell uname ) , D a r w i n )
# 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
e l s e
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
2019-12-04 15:40:36 +01:00
TOOLS := \
2020-11-07 20:00:31 +02:00
nimbus_beacon_node \
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-01-22 10:25:30 +01:00
wss_sim \
2020-05-04 07:38:14 +02:00
stack_sizes \
2020-11-07 20:00:31 +02:00
nimbus_validator_client \
2022-01-17 14:58:33 +02:00
nimbus_signing_node \
validator_db_aggregator
2021-02-14 21:04:54 +01:00
.PHONY : $( TOOLS )
2020-06-24 00:41:38 +02:00
# bench_bls_sig_agggregation TODO reenable after bls v0.10.1 changes
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-01-03 16:31:35 +01:00
dist
2019-08-21 14:45:24 +02:00
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 '.'
all : | $( TOOLS ) libnfuzz .so libnfuzz .a
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-06-14 04:25:19 +02:00
i f e q ( $( OS ) , W i n d o w s _ N T )
2021-01-07 10:19:29 +01:00
# libbacktrace/libunwind is disabled on Windows.
2020-10-12 16:04:21 +03:00
USE_LIBBACKTRACE := 0
2020-06-14 04:25:19 +02:00
e n d i f
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
NIM_PARAMS += -d:release --parallelBuild:1 -d:libp2p_agents_metrics -d:KnownLibP2PAgents= nimbus,lighthouse,prysm,teku
2020-11-27 02:29:06 +01:00
2020-02-20 17:41:10 +01:00
i f e q ( $( USE_LIBBACKTRACE ) , 0 )
2020-09-21 08:40:01 +02:00
# Blame Jacek for the lack of line numbers in your stack traces ;-)
2021-02-14 21:04:54 +01:00
NIM_PARAMS += --stacktrace:on --excessiveStackTrace:on --linetrace:off -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
2021-04-28 18:41:02 +02:00
# test binaries that can output an XML report
XML_TEST_BINARIES := \
2021-10-12 13:36:52 +02:00
consensus_spec_tests_mainnet \
consensus_spec_tests_minimal \
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
2021-04-28 18:41:02 +02:00
.PHONY : $( TEST_BINARIES ) $( XML_TEST_BINARIES )
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" \
2021-02-15 18:08:18 +01:00
$( NIM_PARAMS) -d:chronicles_log_level= TRACE -d:const_preset= mainnet -d:chronicles_sinks= "json[file]" && \
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" \
2021-07-13 06:38:35 +00:00
$( NIM_PARAMS) -d:chronicles_log_level= TRACE -d:const_preset= minimal -d:chronicles_sinks= "json[file]" && \
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 " \
2021-10-12 13:36:52 +02:00
$( NIM_PARAMS) -d:chronicles_sinks= "json[file]" && \
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 " \
2021-10-12 13:36:52 +02:00
$( NIM_PARAMS) -d:chronicles_sinks= "json[file]" && \
2021-02-14 21:04:54 +01:00
echo -e $( BUILD_END_MSG) " build/ $@ "
all_tests : | 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
$@ \
" tests/ $@ .nim " \
2021-10-12 13:36:52 +02:00
$( NIM_PARAMS) -d:chronicles_log_level= TRACE -d:chronicles_sinks= "json[file]" && \
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 " ; \
build/$$ { TEST_BINARY} $$ { PARAMS} || { echo -e " \n $$ {TEST_BINARY} $$ {PARAMS} failed; Aborting. " ; exit 1; } ; \
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 " ; \
build/$$ { TEST_BINARY} $$ { PARAMS} || { echo -e " \n $$ {TEST_BINARY} $$ {PARAMS} failed; Aborting. " ; exit 1; } ; \
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-02-18 15:30:43 +01:00
$( ENV_SCRIPT) nim 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
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 := \
--tcp-port= $$ ( ( $( BASE_PORT) + $( NODE_ID) ) ) \
--udp-port= $$ ( ( $( BASE_PORT) + $( NODE_ID) ) ) \
--metrics \
--metrics-port= $$ ( ( $( BASE_METRICS_PORT) + $( NODE_ID) ) ) \
2022-02-12 11:27:43 +00:00
--rest \
--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
2020-10-12 16:10:23 +03: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
2020-10-12 16:04:21 +03: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-02-12 11:27:43 +00: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
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) \
2021-07-13 16:27:10 +02:00
--deposit-contract= $$ ( cat vendor/eth2-network/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) \
--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
2020-11-12 21:50:49 +02:00
###
2021-03-15 21:49:53 +02:00
### Pyrmont
2020-11-12 21:50:49 +02:00
###
2021-11-30 03:20:21 +02:00
pyrmont-build : | nimbus_beacon_node nimbus_signing_node
2020-11-12 21:50:49 +02:00
# https://www.gnu.org/software/make/manual/html_node/Call-Function.html#Call-Function
pyrmont : | pyrmont -build
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK,pyrmont,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
2020-11-12 21:50:49 +02:00
pyrmont-vc : | pyrmont -build nimbus_validator_client
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK_WITH_VALIDATOR_CLIENT,pyrmont,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
2020-11-12 21:50:49 +02:00
i f n e q ( $( LOG_LEVEL ) , T R A C E )
pyrmont-dev :
2021-02-19 16:37:00 +01:00
+ " $( MAKE) " LOG_LEVEL = TRACE $@
2020-11-12 21:50:49 +02:00
e l s e
pyrmont-dev : | pyrmont -build
2022-02-25 10:22:44 +02:00
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,pyrmont,nimbus_beacon_node,$( GOERLI_WEB3_URL) )
2020-11-12 21:50:49 +02:00
e n d i f
2020-11-14 23:46:34 +02:00
pyrmont-dev-deposit : | pyrmont -build deposit_contract
2022-02-25 10:22:44 +02:00
$( call MAKE_DEPOSIT,pyrmont,$( GOERLI_WEB3_URL) )
2020-11-14 23:46:34 +02:00
2020-11-12 21:50:49 +02:00
clean-pyrmont :
$( call CLEAN_NETWORK,pyrmont)
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
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-02-25 10:22:44 +02:00
###
### Gnosis chain binary
###
# TODO The constants overrides below should not be necessary if we restrore
# the support for compiling with custom const presets.
# See the prepared preset file in media/gnosis-chain/preset.yaml
#
# 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-chain-build :
+ $( ENV_SCRIPT) nim $( NIM_PARAMS) \
-d:gnosisChainBinary \
-d:has_genesis_detection \
-d:SLOTS_PER_EPOCH= 16 \
-d:SECONDS_PER_SLOT= 5 \
-d:BASE_REWARD_FACTOR= 25 \
-d:EPOCHS_PER_SYNC_COMMITTEE_PERIOD= 512 \
-o:build/nimbus_beacon_node_gnosis c beacon_chain/nimbus_beacon_node.nim
gnosis-chain : | gnosis -chain -build
$( 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 :
+ " $( MAKE) " LOG_LEVEL = TRACE $@
e l s e
gnosis-chain-dev : | gnosis -chain -build
$( call CONNECT_TO_NETWORK_IN_DEV_MODE,gnosis-chain,nimbus_beacon_node_gnosis,$( GNOSIS_WEB3_URLS) )
e n d i f
gnosis-chain-dev-deposit : | gnosis -chain -build deposit_contract
$( 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
###
2020-06-11 19:41:43 +03:00
ctail : | build deps
mkdir -p vendor/.nimble/bin/
2020-11-24 20:26:37 +01:00
+ $( ENV_SCRIPT) nim -d:danger -o:vendor/.nimble/bin/ctail c vendor/nim-chronicles-tail/ctail.nim
2020-06-11 19:41:43 +03:00
ntu : | build deps
mkdir -p vendor/.nimble/bin/
2020-11-24 20:26:37 +01:00
+ $( ENV_SCRIPT) nim -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
2020-11-27 02:29:06 +01: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}
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-02-18 15:30:43 +01:00
$( ENV_SCRIPT) nim 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-02-18 15:30:43 +01:00
$( ENV_SCRIPT) nim 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 :
2021-02-15 08:33:49 +01:00
which mdbook & >/dev/null || { echo "'mdbook' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
which mdbook-toc & >/dev/null || { echo "'mdbook-toc' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
2021-03-22 16:40:26 +01:00
which mdbook-open-on-gh & >/dev/null || { echo "'mdbook-open-on-gh' not found in PATH. See 'docs/README.md'. Aborting." ; exit 1; }
2020-07-01 10:37:04 +02:00
cd docs/the_nimbus_book && \
2020-05-02 16:30:34 +02:00
mdbook build
2020-07-07 10:44:21 +02:00
auditors-book :
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/ && \
2020-07-13 12:46:42 +02:00
cp -a docs/the_nimbus_book/book/* 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 . && { \
2020-07-13 12:46:42 +02:00
git commit -m "make publish-book" && \
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