// Copyright (c) 2024 Paul Fariello // // This Source Code Form is subject to the terms of the Mozilla Public // License, v. 2.0. If a copy of the MPL was not distributed with this // file, You can obtain one at http://mozilla.org/MPL/2.0/. use crate::message::MessagePayload; generate_element!( /// Defines associated out of band url. Oob, "x", OOB, children: [ /// The associated URL. url: Required = ("url", OOB) => String, /// An optionnal description of the out of band data. desc: Option = ("desc", OOB) => String, ] ); impl MessagePayload for Oob {} #[cfg(test)] mod tests { use super::*; use crate::util::error::Error; use crate::Element; #[cfg(target_pointer_width = "32")] #[test] fn test_size() { assert_size!(Oob, 24); } #[cfg(target_pointer_width = "64")] #[test] fn test_size() { assert_size!(Oob, 48); } #[test] fn test_simple() { let elem: Element = "http://example.org" .parse() .unwrap(); Oob::try_from(elem).unwrap(); } #[test] fn test_with_desc() { let elem: Element = "http://example.orgExample website" .parse() .unwrap(); Oob::try_from(elem).unwrap(); } #[test] fn test_invalid_child() { let elem: Element = "".parse().unwrap(); let error = Oob::try_from(elem).unwrap_err(); let message = match error { Error::ParseError(string) => string, _ => panic!(), }; assert_eq!(message, "Missing child url in x element."); } }