mirror of
https://github.com/fluencelabs/tendermint
synced 2025-05-16 08:31:19 +00:00
* validate reactor messages Refs #2683 * validate blockchain messages Refs #2683 * validate evidence messages Refs #2683 * todo * check ProposalPOL and signature sizes * add a changelog entry * check addr is valid when we add it to the addrbook * validate incoming netAddr (not just nil check!) * fixes after Bucky's review * check timestamps * beef up block#ValidateBasic * move some checks into bcBlockResponseMessage * update Gopkg.lock Fix ``` grouped write of manifest, lock and vendor: failed to export github.com/tendermint/go-amino: fatal: failed to unpack tree object 6dcc6ddc143e116455c94b25c1004c99e0d0ca12 ``` by running `dep ensure -update` * bump year since now we check it * generate test/p2p/data on the fly using tendermint testnet * allow sync chains older than 1 year * use full path when creating a testnet * move testnet gen to test/docker/Dockerfile * relax LastCommitRound check Refs #2737 * fix conflicts after merge * add small comment * some ValidateBasic updates * fixes * AppHash length is not fixed
52 lines
1.6 KiB
Markdown
52 lines
1.6 KiB
Markdown
# Tendermint P2P Tests
|
|
|
|
These scripts facilitate setting up and testing a local testnet using docker containers.
|
|
|
|
Setup your own local testnet as follows.
|
|
|
|
For consistency, we assume all commands are run from the Tendermint repository root (ie. $GOPATH/src/github.com/tendermint/tendermint).
|
|
|
|
First, build the docker image:
|
|
|
|
```
|
|
docker build -t tendermint_tester -f ./test/docker/Dockerfile .
|
|
```
|
|
|
|
Now create the docker network:
|
|
|
|
```
|
|
docker network create --driver bridge --subnet 172.57.0.0/16 my_testnet
|
|
```
|
|
|
|
This gives us a new network with IP addresses in the rage `172.57.0.0 - 172.57.255.255`.
|
|
Peers on the network can have any IP address in this range.
|
|
For our four node network, let's pick `172.57.0.101 - 172.57.0.104`.
|
|
Since we use Tendermint's default listening port of 26656, our list of seed nodes will look like:
|
|
|
|
```
|
|
172.57.0.101:26656,172.57.0.102:26656,172.57.0.103:26656,172.57.0.104:26656
|
|
```
|
|
|
|
Now we can start up the peers. We already have config files setup in `test/p2p/data/`.
|
|
Let's use a for-loop to start our peers:
|
|
|
|
```
|
|
for i in $(seq 1 4); do
|
|
docker run -d \
|
|
--net=my_testnet\
|
|
--ip="172.57.0.$((100 + $i))" \
|
|
--name local_testnet_$i \
|
|
--entrypoint tendermint \
|
|
-e TMHOME=/go/src/github.com/tendermint/tendermint/test/p2p/data/mach$((i-1)) \
|
|
tendermint_tester node --p2p.persistent_peers 172.57.0.101:26656,172.57.0.102:26656,172.57.0.103:26656,172.57.0.104:26656 --proxy_app=kvstore
|
|
done
|
|
```
|
|
|
|
If you now run `docker ps`, you'll see your containers!
|
|
|
|
We can confirm they are making blocks by checking the `/status` message using `curl` and `jq` to pretty print the output json:
|
|
|
|
```
|
|
curl 172.57.0.101:26657/status | jq .
|
|
```
|