Revision control
Copy as Markdown
Other Tools
use unic_langid::LanguageIdentifier;
#[cfg(feature = "unic-langid-macros")]
use unic_langid::{langid, langid_slice, langids};
#[test]
fn basic_test() {
let loc: LanguageIdentifier = "en-US".parse().expect("Malformed Language Identifier");
assert_eq!(&loc.to_string(), "en-US");
}
#[test]
#[cfg(feature = "unic-langid-macros")]
fn langid_macro_test() {
let loc = langid!("en-US");
assert_eq!(&loc.to_string(), "en-US");
// ensure it can be used in a const context
const _: LanguageIdentifier = langid!("en-US");
}
#[test]
#[cfg(feature = "unic-langid-macros")]
fn langids_macro_test() {
let langids = langids!["en-US", "pl", "de-AT", "Pl-Latn-PL"];
assert_eq!(langids.len(), 4);
assert_eq!(langids.get(3).unwrap().language.as_str(), "pl");
// check trailing comma
langids!["en-US", "pl",];
}
#[test]
#[cfg(feature = "unic-langid-macros")]
fn langid_slice_macro_test() {
let langids = langids!["en-US", "pl", "de-AT", "Pl-Latn-PL"];
// ensure it can be used in a const context
const CONST_LANGIDS: &[LanguageIdentifier] =
langid_slice!["en-US", "pl", "de-AT", "Pl-Latn-PL"];
assert_eq!(CONST_LANGIDS, langids.as_slice());
// check trailing comma
let _ = langid_slice!["en-US", "pl",];
}
#[test]
fn langid_ord() {
let mut input = vec!["en-Latn", "en-US"];
let mut langids: Vec<LanguageIdentifier> = input.iter().map(|l| l.parse().unwrap()).collect();
assert_eq!(
langids
.iter()
.map(|l: &LanguageIdentifier| l.to_string())
.collect::<Vec<_>>(),
&["en-Latn", "en-US"]
);
input.sort();
assert_eq!(input, &["en-Latn", "en-US"]);
langids.sort();
assert_eq!(
langids
.iter()
.map(|l: &LanguageIdentifier| l.to_string())
.collect::<Vec<_>>(),
&["en-US", "en-Latn"]
);
}