Run your private testnet with single validator
Intro
The fastest and easiest way to test KLY abilities is to run a local single-node network. This network contains only 1 node which is validator too.
This allows you to check transactions sending, contracts calls and major part of available KLY features.
Prepare genesis and configs
As you remember, to run or join any network you need genesis and configs.
Genesis is a common startpoint where state of accounts pre-set and your node take the data about the first epoch.
Configs are set of files that you can change in a flexible way to play with your node abilities, use plugins, change the node keypair, JSON-RPC routes and so on!
First of all - choose the location where genesis, configs and chain data will be stored. Imagine that it's directory $HOME/klyntar
Now, create the subdirectorites for genesis and configs
Set configuration files
Go to CONFIGS directory and add the following files (configs for 2 virtual machines + own node configuration) there
Set genesis
Now, go to GENESIS directory and add the appropriate genesis file there
Finally
Now, the hierarchy should looks like this
Once you run your node, the structure will be
These three directories contain everything necessary for the correct operation of the node
Prepare the env variables
In the environment variables you should specify the core launch mode (testnet/mainnet
) and the path to a directory with 3 subdirectories (mentioned earlier). You can set these variables in your shell configuration files (e.g., .bashrc
or .zshrc
), depending on your OS.
Set appropriate first epoch time
In order to run your local testnet correctly, you need to make some changes to the genesis file. Namely, you need to set the start time of the current epoch.
To get the current time, use the following JS snippet
Now, modify the genesis.json
:
Now, you can run your node. From your console run:
And you have to see the following:
Keep it work
Once you run node, leave this console and start to work with KLY. Now you can call APIs, create/send transactions, interact with smart-contracts and so on
IMPORTANT
Due to the nature of consensus, the network must generate at least 1 block per epoch in order to correctly change epochs and continue fault-tolerant work
Last updated