cosmos-sdk/tests/systemtests
2024-06-10 09:07:31 +00:00
..
.gitignore chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
cli.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
genesis_io.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
go.mod build(deps): Bump github.com/cosmos/gogoproto from 1.4.12 to 1.5.0 (#20563) 2024-06-06 08:26:02 +00:00
go.sum build(deps): Bump github.com/cosmos/gogoproto from 1.4.12 to 1.5.0 (#20563) 2024-06-06 08:26:02 +00:00
main_test.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
Makefile chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
README.md chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
rpc_client.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
staking_test.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
system.go fix: remove some duplicate words (#20605) 2024-06-10 09:07:31 +00:00
test_runner.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
testnet_init.go chore: move systemtests to tests folder (#20290) 2024-05-06 13:52:26 +00:00
upgrade_test.go fix: Bump CometBFT versions (#20481) 2024-05-30 10:43:54 +00:00

Testing

Test framework for system tests. Starts and interacts with a (multi node) blockchain in Go. Supports

  • CLI
  • Servers
  • Events
  • RPC

Uses:

  • testify
  • gjson
  • sjson Server and client side are executed on the host machine

Developer

Test strategy

System tests cover the full stack via cli and a running (multi node) network. They are more expensive (in terms of time/ cpu) to run compared to unit or integration tests. Therefore, we focus on the critical path and do not cover every condition.

Execute a single test

go test -tags system_test -count=1 -v . --run TestStakeUnstake  -verbose

Test cli parameters

  • -verbose verbose output
  • -wait-time duration - time to wait for chain events (default 30s)
  • -nodes-count int - number of nodes in the cluster (default 4)

Port ranges

With n nodes:

  • 26657 - 26657+n - RPC
  • 1317 - 1317+n - API
  • 9090 - 9090+n - GRPC
  • 16656 - 16656+n - P2P

For example Node 3 listens on 26660 for RPC calls

Resources

Disclaimer

This is based on the system test framework in wasmd built by Confio.