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 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
use crate::id::{ChannelId, GuildId, MessageId}; use serde::{Deserialize, Serialize}; #[derive(Clone, Debug, Deserialize, Eq, Hash, PartialEq, Serialize)] pub struct MessageReference { #[serde(skip_serializing_if = "Option::is_none")] pub channel_id: Option<ChannelId>, #[serde(skip_serializing_if = "Option::is_none")] pub guild_id: Option<GuildId>, #[serde(skip_serializing_if = "Option::is_none")] pub message_id: Option<MessageId>, #[serde(skip_serializing_if = "Option::is_none")] pub fail_if_not_exists: Option<bool>, } #[cfg(test)] mod tests { use super::{ChannelId, GuildId, MessageId, MessageReference}; use serde_test::Token; #[test] fn test_minimal() { let value = MessageReference { channel_id: Some(ChannelId(1)), guild_id: None, message_id: None, fail_if_not_exists: None, }; serde_test::assert_tokens( &value, &[ Token::Struct { name: "MessageReference", len: 1, }, Token::Str("channel_id"), Token::Some, Token::NewtypeStruct { name: "ChannelId" }, Token::Str("1"), Token::StructEnd, ], ); } #[test] fn test_complete() { let value = MessageReference { channel_id: Some(ChannelId(1)), guild_id: Some(GuildId(2)), message_id: Some(MessageId(3)), fail_if_not_exists: Some(false), }; serde_test::assert_tokens( &value, &[ Token::Struct { name: "MessageReference", len: 4, }, Token::Str("channel_id"), Token::Some, Token::NewtypeStruct { name: "ChannelId" }, Token::Str("1"), Token::Str("guild_id"), Token::Some, Token::NewtypeStruct { name: "GuildId" }, Token::Str("2"), Token::Str("message_id"), Token::Some, Token::NewtypeStruct { name: "MessageId" }, Token::Str("3"), Token::Str("fail_if_not_exists"), Token::Some, Token::Bool(false), Token::StructEnd, ], ); } }