45 lines
1.4 KiB
Rust
45 lines
1.4 KiB
Rust
use std::convert::TryFrom;
|
|
use std::ops::RangeBounds;
|
|
|
|
fn test_char_coverage<R>(n: usize, range: R)
|
|
where
|
|
R: Iterator<Item = char> + RangeBounds<char> + Clone,
|
|
{
|
|
use std::collections::HashSet;
|
|
|
|
let all: HashSet<char> = range.clone().collect();
|
|
let mut covered = HashSet::new();
|
|
for _ in 0..n {
|
|
let c = fastrand::char(range.clone());
|
|
assert!(all.contains(&c));
|
|
covered.insert(c);
|
|
}
|
|
assert_eq!(covered, all);
|
|
}
|
|
|
|
#[test]
|
|
fn test_char() {
|
|
// ASCII control chars.
|
|
let nul = 0u8 as char;
|
|
let soh = 1u8 as char;
|
|
let stx = 2u8 as char;
|
|
// Some undefined Hangul Jamo codepoints just before
|
|
// the surrogate area.
|
|
let last_jamo = char::try_from(0xd7ffu32).unwrap();
|
|
let penultimate_jamo = char::try_from(last_jamo as u32 - 1).unwrap();
|
|
// Private-use codepoints just after the surrogate area.
|
|
let first_private = char::try_from(0xe000u32).unwrap();
|
|
let second_private = char::try_from(first_private as u32 + 1).unwrap();
|
|
// Private-use codepoints at the end of Unicode space.
|
|
let last_private = std::char::MAX;
|
|
let penultimate_private = char::try_from(last_private as u32 - 1).unwrap();
|
|
|
|
test_char_coverage(100, nul..stx);
|
|
test_char_coverage(100, nul..=soh);
|
|
|
|
test_char_coverage(400, penultimate_jamo..second_private);
|
|
test_char_coverage(400, penultimate_jamo..=second_private);
|
|
|
|
test_char_coverage(100, penultimate_private..=last_private);
|
|
}
|