Skip to content

Commit

Permalink
feat(scripts): Added Makefile for scripts (#712)
Browse files Browse the repository at this point in the history
  • Loading branch information
greg-szabo authored Dec 19, 2024
1 parent 55fc086 commit d9e6512
Show file tree
Hide file tree
Showing 3 changed files with 205 additions and 1 deletion.
55 changes: 55 additions & 0 deletions code/scripts/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
# Malachite source code directory
MALACHITE_CODE_DIR?=$(realpath $(CURDIR)/../../code)

# Number of nodes for the testnet
NODES_COUNT?=5

# Malachite home directory
NODES_HOME?=$(HOME)/.malachite

# Binary name
APP_BINARY?=informalsystems-malachitebft-example-channel

# Is this a RELEASE build?
ifeq ($(strip $(RELEASE)),)
BINARY_PATH="$(MALACHITE_CODE_DIR)/target/debug/$(APP_BINARY)"
else
BINARY_PATH="$(MALACHITE_CODE_DIR)/target/release/$(APP_BINARY)"
RELEASE_FLAG=--release
endif

CC=$(shell which cargo)

all: build testnet start

build:
@cd $(MALACHITE_CODE_DIR) && $(CC) build $(RELEASE_FLAG) --package $(APP_BINARY)

testnet: build
@$(BINARY_PATH) testnet --home $(NODES_HOME) --nodes $(NODES_COUNT)

start: testnet
@for i in $$(seq 1 $(NODES_COUNT)); do \
o=$$(($$i - 1)) ;\
cd $(NODES_HOME)/$$o ;\
nohup $(BINARY_PATH) start --home $(NODES_HOME)/$$o & \
done

stop:
@killall -v -u $$UID $(APP_BINARY) 2> /dev/null || true

log:
@for i in $$(seq 1 $(NODES_COUNT)); do \
o=$$(($$i - 1)) ;\
ls -lh $(NODES_HOME)/$$o/nohup.out ;\
done

clean: stop
@test -n "$(NODES_HOME)" && test "$$(echo "$(NODES_HOME)" | wc -c)" -gt 2
rm -rf $(NODES_HOME)

restart: clean start

shortrun: restart
@sleep 6
$(MAKE) stop
149 changes: 149 additions & 0 deletions code/scripts/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
# Testnet scripts
This directory contains scripts that gives you three ways to run local testnet for development purposes.

In each case, we are going to assume that you run your commands from the `code` folder.

## Bash
The `spawn.bash` script is a generic script that can run using the Bash command language interpreter.

* How to use with mandatory parameters:
```bash
scripts/spawn.bash --nodes 5 --home $HOME/.malachite --app informalsystems-malachitebft-example-channel
```

The script will build the application (the `--app` parameter requires a Rust crate name) and run its `start` subcommand.

* Optional parameters:

`--no-reset`: this will prevent the script cleaning up the WAL and database of the nodes in their configuration directory.

* The script will always build a release version of the application.

* The script will run the application in the foreground. When you press CTRL-C to stop the script, the application
instances will also be terminated.

* The application log can be found in the node's home directory in the `logs/node.log` file.

* The script overrides some of the configuration parameters for local testnet use:
```bash
export MALACHITE__CONSENSUS__P2P__PROTOCOL__TYPE="gossipsub"
export MALACHITE__CONSENSUS__VALUE_PAYLOAD="proposal-and-parts"
export MALACHITE__CONSENSUS__MAX_BLOCK_SIZE="50KiB"
export MALACHITE__CONSENSUS__TIMEOUT_PROPOSE="2s"
export MALACHITE__CONSENSUS__TIMEOUT_PROPOSE_DELTA="1s"
export MALACHITE__CONSENSUS__TIMEOUT_PREVOTE="1s"
export MALACHITE__CONSENSUS__TIMEOUT_PRECOMMIT="1s"
export MALACHITE__CONSENSUS__TIMEOUT_COMMIT="0s"
export MALACHITE__CONSENSUS__TIMEOUT_STEP="6s"
export MALACHITE__MEMPOOL__MAX_TX_COUNT="10000"
export MALACHITE__MEMPOOL__GOSSIP_BATCH_SIZE=0
export MALACHITE__TEST__TX_SIZE="1KiB"
export MALACHITE__TEST__TXS_PER_PART=256
export MALACHITE__TEST__TIME_ALLOWANCE_FACTOR=0.3
export MALACHITE__TEST__EXEC_TIME_PER_TX="0ms"
export MALACHITE__TEST__MAX_RETAIN_BLOCKS=10000
export MALACHITE__TEST__VOTE_EXTENSIONS__ENABLED="false"
export MALACHITE__TEST__VOTE_EXTENSIONS__SIZE="1KiB"
```

## Fish
The `spawn.fish` script is a generic script that can run using the [Fish](https://fishshell.com/) command language
interpreter.

* This script has additional functionality compared to the Bash script.
* How to use with mandatory parameters:
```fish
scripts/spawn.fish --nodes 5 --home $HOME/.malachite
```
The script will build the `informalsystems-malachitebft-example-channel` application by default, unless the name is
overwritten by the `--app` parameter. (the `--app` parameter requires a Rust crate name) Then it run the application's
`start` subcommand.

* Optional parameters:

`--no-reset`: this will prevent the script cleaning up the WAL and database of the nodes in their configuration directory.

`--app`: set the name of the application that will be built. The default is `informalsystems-malachitebft-example-channel`.

`--profile`: turn on profiling. The build profile will be set as `profiling` and the compiled binary will be read from
the `target/profiling` directory.

`--debug`: mutually exclusive to `--profile`. Sets the build profile to `dev` and the compiled binary directory path to
`target/debug`.

`--lldb`: enable the `rust-lldb` debugger before running the application and set a breakpoint on the `main` function.

* The script uses the `tmux` session manager, when creating the node processes.

* The script will build a release version of the application unless the `--profile` or `--debug` parameters are given.

* The script will run the application in the foreground. When you press CTRL-C to stop the script, the application
instances will also be terminated.

* The application log can be found in the node's home directory in the `logs/node.log` file.

* The script overrides some of the configuration parameters for local testnet use:
```bash
set -x MALACHITE__CONSENSUS__P2P__PROTOCOL__TYPE "gossipsub"
set -x MALACHITE__CONSENSUS__MAX_BLOCK_SIZE "2MiB"
set -x MALACHITE__CONSENSUS__TIMEOUT_PROPOSE "5s"
set -x MALACHITE__CONSENSUS__TIMEOUT_PREVOTE "3s"
set -x MALACHITE__CONSENSUS__TIMEOUT_PRECOMMIT "3s"
set -x MALACHITE__CONSENSUS__TIMEOUT_COMMIT "0s"
set -x MALACHITE__CONSENSUS__TIMEOUT_STEP "30s"

set -x MALACHITE__MEMPOOL__MAX_TX_COUNT 1000
set -x MALACHITE__MEMPOOL__GOSSIP_BATCH_SIZE 0
set -x MALACHITE__TEST__TX_SIZE "1 KiB"
set -x MALACHITE__TEST__TXS_PER_PART 1024
set -x MALACHITE__TEST__TIME_ALLOWANCE_FACTOR 0.5
set -x MALACHITE__TEST__EXEC_TIME_PER_TX "1ms"
set -x MALACHITE__TEST__MAX_RETAIN_BLOCKS 50
set -x MALACHITE__TEST__VOTE_EXTENSIONS__ENABLED false
set -x MALACHITE__TEST__VOTE_EXTENSIONS__SIZE "1KiB"
set -x MALACHITE__SYNC__ENABLED true
set -x MALACHITE__SYNC__REQUEST_TIMEOUT "30s"
```

## make
The `Makefile` configuration is a generic set of targets that can run using the GNU `make` command.

* How to use with mandatory parameters:
```bash
make -C scripts
```
The `-C` parameter switches the execution folder for `make` to the directory specified after it.

The command will build the application and run its `start` subcommand. Contrary to the shell solutions the applications
are started using `nohup` and are running in the background as shell jobs.

* Optional parameters:

`NODES_COUNT=5 make -C scripts`: set the number of nodes to spawn. The default is 5.

`NODES_HOME=$HOME/.malachite make -C scripts`: set the home directory for the nodes. The default is `$HOME/.malachite`.

`APP_BINARY=informalsystems-malachitebft-example-channel make -C scripts`: set the name of the application that will be
built and executed. The default is `informalsystems-malachitebft-example-channel`.

`RELEASE=1 make -C scripts`: set the build profile to `release`. The default is application build is `debug`.

* Additional parameters that are less used:

`MALACHITE_CODE_DIR`: set the directory where the Malachite code is located. The default is `../../code`.

`CC`: the cargo binary with path. Default is `$(which cargo)`.

* The script will build a debug version of the application unless the `RELEASE=1` parameters is given.

* The script will run the application in the background. If you run the `make -C scripts stop` command, the application
will stop.

* The application log can be found in the node's home directory in the `logs/nohup.out` file. The `make -C scripts logs`
command will list all the log files.

* The application configuration, logs, databases and WAL can be removed with `make -C scripts clean`.

* Other `Makefile` targets with obvious purpose: `build`, `testnet`, `start`, `restart`. The default target (`all`) uses
the `build`, `testnet` and `start` targets as dependency.
*
2 changes: 1 addition & 1 deletion code/scripts/spawn.fish
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ if ! set -q _flag_home
return 1
end

set app_name "informalsystems-malachitebft-starknet-app"
set app_name "informalsystems-malachitebft-example-channel"
set profile false
set debug false
set lldb false
Expand Down

0 comments on commit d9e6512

Please sign in to comment.