/poa-network-monitor

Tests for POA network health checks. Moved to https://github.com/poanetwork/poa-network-monitor

Primary LanguageJavaScript

poa-network-monitor

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 contract
  • common 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 results
  • scripts 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 url
  • config-sample.toml is example of file with settings. Needs to be renamed to config.toml and filled with valid settings (as account and password)

Setup

Run Parity nodes

1. Install Parity and obtain spec.json and bootnodes.txt files using these instructions: POA Installation.
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

Add repository path to the environment variable

Bash scripts run on cron in it's directory so need to use absolute path.
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

Edit the configuration file

Rename config-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.

Create test accounts

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
For sending txs test (missing-rounds.js)
1. Create 2 accounts (in each network), add POA to the one of them. For the Sokol network test POA can be added here
2. Add created addresses and passwords to the Sending txs test section of the config.toml file. addressFrom.. must be address with POA
For sending txs via public RPC test (txs-public-rpc-test.js)
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.

Setup scripts for running monitor and tests.

Tests
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;
Reorgs
Run reorgs test for the each network:
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.

Monitor
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.

Add scripts to the crontab

Run 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

Run web server

cd $POA_MONITOR_PATH
nohup node $POA_MONITOR_PATH/webapp/index.js >> $POA_MONITOR_PATH/logs/web_server.log 2>&1 &