use ibc::core::channel::types::proto::v1::MsgChannelOpenAck as RawMsgChannelOpenAck;
use ibc::core::client::types::proto::v1::Height;
use ibc::core::host::types::identifiers::{ChannelId, PortId};
use ibc::core::primitives::prelude::*;
use super::dummy_proof;
use crate::fixtures::core::signer::dummy_bech32_account;
pub fn dummy_raw_msg_chan_open_ack(proof_height: u64) -> RawMsgChannelOpenAck {
RawMsgChannelOpenAck {
port_id: PortId::transfer().to_string(),
channel_id: ChannelId::zero().to_string(),
counterparty_channel_id: ChannelId::zero().to_string(),
counterparty_version: "".to_string(),
proof_try: dummy_proof(),
proof_height: Some(Height {
revision_number: 0,
revision_height: proof_height,
}),
signer: dummy_bech32_account(),
}
}
#[cfg(test)]
mod tests {
use ibc::core::channel::types::msgs::MsgChannelOpenAck;
use super::*;
#[test]
fn parse_channel_open_ack_msg() {
struct Test {
name: String,
raw: RawMsgChannelOpenAck,
want_pass: bool,
}
let proof_height = 20;
let default_raw_msg = dummy_raw_msg_chan_open_ack(proof_height);
let tests: Vec<Test> = vec![
Test {
name: "Good parameters".to_string(),
raw: default_raw_msg.clone(),
want_pass: true,
},
Test {
name: "Correct port identifier".to_string(),
raw: RawMsgChannelOpenAck {
port_id: "p34".to_string(),
..default_raw_msg.clone()
},
want_pass: true,
},
Test {
name: "Bad port, name too short".to_string(),
raw: RawMsgChannelOpenAck {
port_id: "p".to_string(),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "Bad port, name too long".to_string(),
raw: RawMsgChannelOpenAck {
port_id: "abcdezdfDfsdfgfddsfsfdsdfdfvxcvzxcvsgdfsdfwefwvsdfdsfdasgagadgsadgsdffghijklmnopqrstuabcdezdfDfsdfgfddsfsfdsdfdfvxcvzxcvsgdfsdfwefwvsdfdsfdasgagadgsadgsdffghijklmnopqrstu".to_string(),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "Correct channel identifier".to_string(),
raw: RawMsgChannelOpenAck {
channel_id: "channel-34".to_string(),
..default_raw_msg.clone()
},
want_pass: true,
},
Test {
name: "Bad channel, name too short".to_string(),
raw: RawMsgChannelOpenAck {
channel_id: "chshort".to_string(),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "Bad channel, name too long".to_string(),
raw: RawMsgChannelOpenAck {
channel_id: "channel-128391283791827398127398791283912837918273981273987912839".to_string(),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "[Counterparty] Correct channel identifier".to_string(),
raw: RawMsgChannelOpenAck {
counterparty_channel_id: "channel-34".to_string(),
..default_raw_msg.clone()
},
want_pass: true,
},
Test {
name: "[Counterparty] Bad channel, name too short".to_string(),
raw: RawMsgChannelOpenAck {
counterparty_channel_id: "chshort".to_string(),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "[Counterparty] Bad channel, name too long".to_string(),
raw: RawMsgChannelOpenAck {
counterparty_channel_id: "channel-128391283791827398127398791283912837918273981273987912839".to_string(),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "Empty counterparty version (allowed)".to_string(),
raw: RawMsgChannelOpenAck {
counterparty_version: " ".to_string(),
..default_raw_msg.clone()
},
want_pass: true,
},
Test {
name: "Arbitrary counterparty version (allowed)".to_string(),
raw: RawMsgChannelOpenAck {
counterparty_version: "v1.1.23-alpha".to_string(),
..default_raw_msg.clone()
},
want_pass: true,
},
Test {
name: "Bad proof height, height = 0".to_string(),
raw: RawMsgChannelOpenAck {
proof_height: Some(Height {
revision_number: 0,
revision_height: 0,
}),
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "Missing proof height".to_string(),
raw: RawMsgChannelOpenAck {
proof_height: None,
..default_raw_msg.clone()
},
want_pass: false,
},
Test {
name: "Missing proof try (object proof)".to_string(),
raw: RawMsgChannelOpenAck {
proof_try: Vec::new(),
..default_raw_msg
},
want_pass: false,
},
]
.into_iter()
.collect();
for test in tests {
let res_msg = MsgChannelOpenAck::try_from(test.raw.clone());
assert_eq!(
test.want_pass,
res_msg.is_ok(),
"MsgChanOpenAck::try_from raw failed for test {}, \nraw msg {:?} with error {:?}",
test.name,
test.raw,
res_msg.err(),
);
}
}
#[test]
fn to_and_from() {
let raw = dummy_raw_msg_chan_open_ack(100);
let msg = MsgChannelOpenAck::try_from(raw.clone()).unwrap();
let raw_back = RawMsgChannelOpenAck::from(msg.clone());
let msg_back = MsgChannelOpenAck::try_from(raw_back.clone()).unwrap();
assert_eq!(raw, raw_back);
assert_eq!(msg, msg_back);
}
}