// Copyright (c) 2018 Emmanuel Gil Peyrot // // 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/. #![deny(missing_docs)] generate_elem_id!( /// Represents a global, memorable, friendly or informal name chosen by a user. Nick, "nick", NICK ); #[cfg(test)] mod tests { use super::*; use try_from::TryFrom; use minidom::Element; use error::Error; #[test] fn test_simple() { let elem: Element = "Link Mauve".parse().unwrap(); let nick = Nick::try_from(elem).unwrap(); assert_eq!(&nick.0, "Link Mauve"); } #[test] fn test_serialise() { let elem1 = Element::from(Nick(String::from("Link Mauve"))); let elem2: Element = "Link Mauve".parse().unwrap(); assert_eq!(elem1, elem2); } #[test] fn test_invalid() { let elem: Element = "".parse().unwrap(); let error = Nick::try_from(elem).unwrap_err(); let message = match error { Error::ParseError(string) => string, _ => panic!(), }; assert_eq!(message, "Unknown child in nick element."); } #[test] fn test_invalid_attribute() { let elem: Element = "".parse().unwrap(); let error = Nick::try_from(elem).unwrap_err(); let message = match error { Error::ParseError(string) => string, _ => panic!(), }; assert_eq!(message, "Unknown attribute in nick element."); } }