mirror of
https://github.com/status-im/status-go.git
synced 2025-01-22 20:54:23 +00:00
1795620df0
* test_: run on host
Overview
Functional tests for status-go
Table of Contents
How to Install
- Install Docker and Docker Compose
- Install Python 3.10.14
- In
./tests-functional
, runpip install -r requirements.txt
- Optional (for test development): Use Python virtual environment for better dependency management. You can follow the guide here:
How to Run
Running dev RPC (anvil with contracts)
- In
./tests-functional
rundocker compose -f docker-compose.anvil.yml up --remove-orphans --build
, as result:- an anvil container with ChainID 31337 exposed on
0.0.0.0:8545
will start running - Status-im contracts will be deployed to the network
- an anvil container with ChainID 31337 exposed on
Run tests
- In
./tests-functional
rundocker compose -f docker-compose.anvil.yml -f docker-compose.test.status-go.yml -f docker-compose.status-go.local.yml up --build --remove-orphans
, as result:- a container with status-backend will be created with endpoint exposed on
0.0.0.0:3333
- status-go will use anvil as RPCURL with ChainID 31337
- Status-im contracts will be deployed to the network
- a container with status-backend will be created with endpoint exposed on
- In
./tests-functional/tests
directory runpytest -m rpc
- To run tests against binary run
pytest -m <your mark> --url=http:<binary_url>:<binary_port> --user_dir=/<path>
Implementation details
- Functional tests are implemented in
./tests-functional/tests
based on pytest - Every test has two types of verifications:
verify_is_valid_json_rpc_response()
checks for status code 200, non-empty response, JSON-RPC structure, presence of theresult
field, and expected ID.jsonschema.validate()
is used to check that the response contains expected data, including required fields and types. Schemas are stored in/schemas/wallet_MethodName
- New schemas can be generated using
./tests-functional/schema_builder.py
by passing a response to theCustomSchemaBuilder(schema_name).create_schema(response.json())
method, should be used only on test creation phase, please searchhow to create schema:
to see an example in a test