Crate clone_cw_multi_test
source ·Expand description
Multitest is a design to simulate a blockchain environment in pure Rust. This allows us to run unit tests that involve contract -> contract, and contract -> bank interactions. This is not intended to be a full blockchain app but to simulate the Cosmos SDK x/wasm module close enough to gain confidence in multi-contract deployments before testing them on a live blockchain.
To understand the design of this module, please refer to ../DESIGN.md
Modules§
- MultiTest add-ons
Structs§
- Router is a persisted state. You can query this. Execution generally happens on the RouterCache, which then can be atomically committed or rolled back. We offer .execute() as a wrapper around cache, execute, commit/rollback process.
- Utility to build App in stages. When particular properties are not explicitly set, then default values are used.
- Contract data includes information about contract, equivalent of
ContractInfoinwasmdinterface. - Wraps the exported functions from a contract and provides the normalized format Place T4 and E4 at the end, as we just want default placeholders for most contracts that don’t have sudo
- Default contract address generator used in WasmKeeper.
Enums§
- We use it to allow calling into modules from another module in sudo mode. Things like gov proposals belong here.
Constants§
Traits§
- Common address generator interface.
- Provides a custom interface for generating checksums for contract code. This is crucial for ensuring code integrity and is particularly useful in environments where code verification is a key part of the contract deployment process. This trait defines a method to calculate checksum based on the creator’s address and a unique code identifier.
- Interface to call into a Contract.
- Module interface.
Functions§
- Creates new default
Appimplementation working with customized exec and query messages. Outside ofAppimplementation to make type elision better.
Type Aliases§
- Type alias for default build
Appto make its storing simpler in typical scenario - This is essential to create a custom app with custom module.