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
55
56
57
58
59
60
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
use std::fmt;
use crate::errors::StdError;
use crate::types::Empty;
use super::attribute::Attribute;
use super::cosmos_msg::CosmosMsg;
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct InitResponse<T = Empty>
where
T: Clone + fmt::Debug + PartialEq + JsonSchema,
{
pub messages: Vec<CosmosMsg<T>>,
pub attributes: Vec<Attribute>,
}
impl<T> Default for InitResponse<T>
where
T: Clone + fmt::Debug + PartialEq + JsonSchema,
{
fn default() -> Self {
InitResponse {
messages: vec![],
attributes: vec![],
}
}
}
pub type InitResult<U = Empty> = Result<InitResponse<U>, StdError>;
#[cfg(test)]
mod test {
use super::super::BankMsg;
use super::*;
use crate::addresses::HumanAddr;
use crate::{coins, from_slice, to_vec};
#[test]
fn can_serialize_and_deserialize_init_response() {
let original = InitResponse {
messages: vec![BankMsg::Send {
from_address: HumanAddr::from("me"),
to_address: HumanAddr::from("you"),
amount: coins(1015, "earth"),
}
.into()],
attributes: vec![Attribute {
key: "action".to_string(),
value: "release".to_string(),
}],
};
let serialized = to_vec(&original).expect("encode contract result");
let deserialized: InitResponse = from_slice(&serialized).expect("decode contract result");
assert_eq!(deserialized, original);
}
}