App
The App
structure represents the blockchain simulator. Creating App
mimics the startup of a real-life blockchain within tests that utilize MultiTest
.
default
The most straightforward way to create an App
is by using the default
method, which is the equivalent of calling the new
constructor with an empty initialization
callback no_init
.
use cw_multi_test::App;
let app = App::default();
use cw_multi_test::{no_init, App};
let app = App::new(no_init);
In both cases, the newly created App
object simulates a blockchain with the default
settings as summarized in the chapter Features summary.
new
Using the App::new
constructor enables additional initialization of the blockchain
at startup, prior to executing any tests. Initialization is done inside the callback function passed
as an argument to the new
constructor (lines 7-13 in the code snippet shown below).
Initialization callback function takes three arguments:
- router - provides access to other modules of the blockchain,
- api - provides access to CosmWasm API,
- storage - provides access to the blockchain’s storage.
An example of funds initialization inside the custom callback function is shown below:
use cosmwasm_std::coin;
use cw_multi_test::App;
let me = "me";
let my_funds = vec![coin(20, "OSMO")];
let app = App::new(|router, api, storage| {
let my_address = api.addr_make(me);
router
.bank
.init_balance(storage, &my_address, my_funds)
.unwrap();
});
let my_coins = app
.wrap()
.query_all_balances(app.api().addr_make(me))
.unwrap();
assert_eq!(1, my_coins.len());
assert_eq!("20OSMO", my_coins[0].to_string());
no_init
The no_init
function serves as an empty chain initialization callback, offering
a convenient option when no specific chain initialization is required. Usually used when calling
App::new
or AppBuilder::build
methods.