Tests for network health checks and monitoring.
network-test
folder contains tests and helper script. Use the command line arguments to detect network name and url. If no command line arguments received, parameters from the toml file will be used.
test-data
folder contains test blocks for checking missing-round test.
contracts
folder contains abi and address of needed contractcommon
folder contains file with configuration information obtained from toml file and dao for working with sqlite database.webapp
folder contains web server for retrieving test resultsscripts
folder contains script for new accounts creating and bash scripts for running tests and monitor.test-runner.sh
file contains logic to prevent duplicate test executions using PID files. It takes name of the test as argument and executes bash script for running this test.test-result-monitor.js
file checks test results via web server and send alert to slack channel. Also uses the command line arguments to detect network name and urlconfig-sample.toml
is example of file with settings. Needs to be renamed toconfig.toml
and filled with valid settings (as account and password)
2. Clone Github repository:
git clone https://github.com/Natalya11444/poa-network-monitor.git
Install dependencies
cd poa-network-monitor
npm install
3.Run parity nodes
For running parity node enable JSONRPC when connecting to POA Network on Parity --jsonrpc-apis all
For running two nodes for the each network it's needed to specify different ports for them.
Example of running Sokol node on ubuntu:
nohup parity --chain /path/to/sokol/spec.json --reserved-peers /path/to/sokol/bootnodes.txt --jsonrpc-apis all --port 30300 --jsonrpc-port 8540 --ws-port 8450 --ui-port 8180 --no-ipc > /path/to/logs/parity-sokol.log 2>&1 &
url will be http://localhost:8540
For the Core node:
nohup parity --chain /path/to/core/spec.json --reserved-peers /path/to/core/bootnodes.txt --jsonrpc-apis all --port 30301 --jsonrpc-port 8541 --ws-port 8451 --ui-port 8181 --no-ipc > /path/to/logs/parity-core.log 2>&1 &
url will be http://localhost:8541
1.Run in the terminal
sudo nano /etc/environment
2.Add repository path to the file:
POA_MONITOR_PATH="/home/user/poa-network-monitor"
3.Logout from the current user and login again so environment variables changes take place
Renameconfig-sample.toml
to the config.toml
(or copy and rename). Specify slackWebHookUrl
. Webhook can be created as here.
Other settings can be changed too, accounts creation is described below.
For account creating newAccount.js script can be used.
It will create encrypted account using specified password and print it's address.
For the Sokol:
cd $POA_MONITOR_PATH
node $POA_MONITOR_PATH/scripts/newAccount.js sokol http://localhost:8540 password
Core:
cd $POA_MONITOR_PATH
node $POA_MONITOR_PATH/scripts/newAccount.js core http://localhost:8541 password
2. Add created addresses and passwords to the
Sending txs test
section of the config.toml
file. addressFrom..
must be address with POA
This test can't unlock account as it uses remote node, so it creates raw tx and signs with private key. For getting public and private keys it uses keystore file. 1.Create 2 accounts in each network, add POA to the one of them.
2.Add created addresses and passwords to the
Sending txs via public RPC test
section of the config.toml file. 3.Add path to the keystore of the account with poa (
keyStorePath
parameter).
Keystore file is usually located in the ~/.local/share/io.parity.ethereum/keys/
folder.
Bash scripts for running tests and monitor are located in the scripts
folder. They can be used for adding to cron. Before using first is needed to make them executable. Run in the terminal:
chmod +x $POA_MONITOR_PATH/scripts/test-runner.sh
chmod +x $POA_MONITOR_PATH/scripts/missing-rounds-sokol.sh
chmod +x $POA_MONITOR_PATH/scripts/missing-rounds-core.sh
chmod +x $POA_MONITOR_PATH/scripts/mining-reward-sokol.sh
chmod +x $POA_MONITOR_PATH/scripts/mining-reward-core.sh
chmod +x $POA_MONITOR_PATH/scripts/txs-sokol.sh
chmod +x $POA_MONITOR_PATH/scripts/txs-core.sh
chmod +x $POA_MONITOR_PATH/scripts/txs-public-rpc-sokol.sh
chmod +x $POA_MONITOR_PATH/scripts/txs-public-rpc-core.sh
chmod +x $POA_MONITOR_PATH/scripts/monitor-sokol.sh
chmod +x $POA_MONITOR_PATH/scripts/monitor-core.sh
Example script for running separate test:
#!/bin/sh
cd $POA_MONITOR_PATH; node $POA_MONITOR_PATH/network-test/missing-rounds.js sokol http://localhost:8540 >> $POA_MONITOR_PATH/logs/missing-rounds-sokol-log 2>&1;
node $POA_MONITOR_PATH/network-test/missing-rounds.js core http://localhost:8541 >> $POA_MONITOR_PATH/logs/missing-rounds-core-log 2>&1;
nohup node $POA_MONITOR_PATH/network-test/reorgs-check.js core ws://localhost:8451 >> $POA_MONITOR_PATH/logs/reorgs_core.log 2>&1 &
nohup node $POA_MONITOR_PATH/network-test/reorgs-check.js sokol ws://localhost:8450 >> $POA_MONITOR_PATH/logs/reorgs_sokol.log 2>&1 &
Test for reorgs runs continuously so it's not needed to add it on cron.
When running monitor the time in seconds can be specified for checking last result.Script for separate run:
#!/bin/sh <br>
cd $POA_MONITOR_PATH; node $POA_MONITOR_PATH/test-result-monitor.js sokol 1800 >> $POA_MONITOR_PATH/logs/monitor-sokol-log 2>&1;
node $POA_MONITOR_PATH/test-result-monitor.js core 1800 >> $POA_MONITOR_PATH/logs/monitor-core-log 2>&1
Scripts for monitor running are located in the scripts
folder.
sudo crontab -e -u user
Crontab example with timeout:
*/10 * * * * timeout -s 2 8m $POA_MONITOR_PATH/scripts/test-runner.sh missing-rounds-sokol
*/12 * * * * timeout -s 2 8m $POA_MONITOR_PATH/scripts/test-runner.sh missing-rounds-core
*/16 * * * * timeout -s 2 8m $POA_MONITOR_PATH/scripts/test-runner.sh mining-reward-sokol
*/18 * * * * timeout -s 2 8m $POA_MONITOR_PATH/scripts/test-runner.sh mining-reward-core
0,30 * * * * timeout -s 2 25m $POA_MONITOR_PATH/scripts/test-runner.sh txs-sokol
5,35 * * * * timeout -s 2 25m $POA_MONITOR_PATH/scripts/test-runner.sh txs-core
*/15 * * * * timeout -s 2 12m $POA_MONITOR_PATH/scripts/test-runner.sh txs-public-rpc-sokol
*/17 * * * * timeout -s 2 12m $POA_MONITOR_PATH/scripts/test-runner.sh txs-public-rpc-core
0,30 * * * * timeout -s 2 15m $POA_MONITOR_PATH/scripts/test-runner.sh monitor-sokol
5,35 * * * * timeout -s 2 15m $POA_MONITOR_PATH/scripts/test-runner.sh monitor-core
cd $POA_MONITOR_PATH
nohup node $POA_MONITOR_PATH/webapp/index.js >> $POA_MONITOR_PATH/logs/web_server.log 2>&1 &