typst/vendor/zerotrie/tests/ignorecase_test.rs
Sergey Konev a8d83b9bab
Some checks failed
Continuous integration / Tests (push) Blocked by required conditions
Continuous integration / Tests (windows-latest) (push) Waiting to run
Continuous integration / Check clippy, formatting, and documentation (push) Failing after 20s
Continuous integration / Tests (ubuntu-latest) (push) Failing after 22s
Continuous integration / Check fuzzers (push) Failing after 18s
Continuous integration / Check mininum Rust version (push) Failing after 20s
Fixed vendoring
2024-10-16 15:22:14 +03:00

47 lines
1.5 KiB
Rust

// This file is part of ICU4X. For terms of use, please see the file
// called LICENSE at the top level of the ICU4X source tree
// (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).
use zerotrie::ZeroAsciiIgnoreCaseTrie;
mod testdata {
include!("data/data.rs");
}
use testdata::strings_to_litemap;
#[test]
fn test_ignore_case_coverage() {
let litemap = strings_to_litemap(&["", "aBc", "aBcD", "aBce", "aBcF", "aBcghi"]);
// Test both construction paths
ZeroAsciiIgnoreCaseTrie::try_from(&litemap).unwrap();
let trie = litemap
.iter()
.map(|(k, v)| (*k, *v))
.collect::<ZeroAsciiIgnoreCaseTrie<Vec<u8>>>();
// Test lookup
for (k, v) in litemap.iter() {
assert_eq!(trie.get(k), Some(*v), "normal: {k:?}");
let k_upper = k
.iter()
.map(|c| c.to_ascii_uppercase())
.collect::<Vec<u8>>();
assert_eq!(trie.get(k_upper), Some(*v), "upper: {k:?}");
let k_lower = k
.iter()
.map(|c| c.to_ascii_lowercase())
.collect::<Vec<u8>>();
assert_eq!(trie.get(k_lower), Some(*v), "lower: {k:?}");
}
// Test mixed-case strings
let problematic_strs = &["A", "ab", "abc", "aBcd", "aBcgHi"];
for problematic_str in problematic_strs {
let mut litemap = litemap.clone();
litemap.insert(problematic_str.as_bytes(), 100);
ZeroAsciiIgnoreCaseTrie::try_from(&litemap).expect_err(problematic_str);
}
}