1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
use crate::{
scenario::model::{Step, TransferStep, TxTransfer, ValidatorRewardStep},
tx_mock::TxFunctionName,
};
use crate::{
sc_call::tx_esdt_transfers_from_scenario, tx_execution::execute_sc_call, tx_mock::TxInput,
world_mock::BlockchainMock,
};
impl BlockchainMock {
pub fn perform_transfer(&mut self, transfer_step: TransferStep) -> &mut Self {
self.with_borrowed(|state| ((), execute(state, &transfer_step.tx)));
self.scenario_trace
.steps
.push(Step::Transfer(transfer_step));
self
}
pub fn perform_validator_reward(
&mut self,
validator_rewards_step: ValidatorRewardStep,
) -> &mut Self {
self.increase_validator_reward(
&validator_rewards_step.tx.to.to_address(),
&validator_rewards_step.tx.egld_value.value,
);
self.scenario_trace
.steps
.push(Step::ValidatorReward(validator_rewards_step));
self
}
}
fn execute(mut state: BlockchainMock, tx_transfer: &TxTransfer) -> BlockchainMock {
let tx_input = TxInput {
from: tx_transfer.from.value.clone(),
to: tx_transfer.to.value.clone(),
egld_value: tx_transfer.egld_value.value.clone(),
esdt_values: tx_esdt_transfers_from_scenario(tx_transfer.esdt_value.as_slice()),
func_name: TxFunctionName::EMPTY,
args: Vec::new(),
gas_limit: tx_transfer.gas_limit.value,
gas_price: tx_transfer.gas_price.value,
..Default::default()
};
state.increase_account_nonce(&tx_input.from);
let (tx_result, state) = execute_sc_call(tx_input, state);
tx_result.assert_ok();
state
}