If you wish you can also run E2E tests independently
go test ./testutil/e2e/ -run ^TestLavaProtocol$ -v -timeout 1200s
If this is the first time you run the e2e after fetching a branch and you didn't compile the protobufs first run:
(Make sure that GOPATH is defined in your environment)
Init and build the SDK:
cd ecosystem/lava-sdk
./scripts/init_sdk.sh -s
yarn build
cd -
Build lavajs:
cd ./ecosystem/lavajs
yarn e2e-setup
cd -
Now you can run the test running:
go test ./testutil/e2e/ -run ^TestLavaSDK -v -timeout 1200s
yarn --cwd ./ecosystem/lava-sdk/ build; yarn --cwd ./ecosystem/lavajs/ e2e-setup;
go test ./testutil/e2e/ -v -timeout 1200s
This E2E performs the steps below to test if the system is working as expected.
- Start lava in developer mode (equivalent to running the command "ignite chain serve" ).
- Check if lava is done booting up by sending a GRPC request.
- Send Spec and Plan proposals and stake providers and clients.
- Check if the proposals and stakes are properly executed.
- Start the JSONRPC Proxy.
- Start the JSONRPC Provider.
- Start the JSONRPC Gateway.
- Check if the JSONRPC Gateway is working as expected by sending a query through the gateway.
- Start the Tendermint Provider using the running lava process as RPC.
- Start the Tenderming Gateway.
- Check if the Tendermint Gateway is working as expected by sending a query through the gateway.
- Start the REST Provider using the running lava process as RPC.
- Start the REST Provider.
- Check if the REST Gateway is working as expected by sending a query through the gateway.
- Send multiple requests through each gateway.
- Check if a gateway responds with an error.
- Check if payments are paid.
- Start lava in emergency mode.
- Wait until downtime and 2 virtual epochs will be passed.
- Send requests to check that max CU was increased.
After the steps above are finished (even if a step fails and the E2E ends) the E2E will save all the captured logs.
The allowed error list contains a list of errors that is allowed to happen during tests. The key is the error substring that can be seen in the logs. The value is the description on why this error is allowed.