Lava E2E
If you wish you can also run E2E tests independently:
- Lava Protocol E2:
go test ./testutil/e2e/ -run ^TestLavaProtocol$ -v -timeout 1200s
- Lava SDK E2E:
yarn --cwd ./ecosystem/lava-sdk/ build; yarn --cwd ./ecosystem/lavajs/ e2e-setup;
go test ./testutil/e2e/ -run ^TestLavaSDK -v -timeout 1200s
Run all our E2E using the following command (from the root) - NOT STABLE
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.
Allowed Error List
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.