1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
use std::str::FromStr;
pub struct RangeFilter {
from: usize,
to: usize,
}
impl RangeFilter {
pub fn includes(&self, index: usize) -> bool {
index >= self.from && index <= self.to
}
}
impl FromStr for RangeFilter {
type Err = ();
fn from_str(s: &str) -> Result<RangeFilter, Self::Err> {
let bounds: Vec<usize> = s
.splitn(2, ':')
.map(|x| x.parse::<usize>())
.flatten()
.collect();
if bounds.len() == 2 {
return Ok(RangeFilter {
from: bounds[0],
to: bounds[1],
});
}
if let Ok(index) = s.parse::<usize>() {
return Ok(RangeFilter {
from: index,
to: index,
});
}
Err(())
}
}
#[cfg(test)]
mod tests {
use crate::selectors::test::test_filter_event_index;
use crate::testdata;
#[test]
fn test_index_single() {
let filtered = test_filter_event_index(&testdata::TEST_EVENT_MULTIDAY, 1, &["1"]);
assert!(filtered)
}
#[test]
fn test_index_single_negative() {
let filtered = test_filter_event_index(&testdata::TEST_EVENT_MULTIDAY, 5, &["1"]);
assert_eq!(false, filtered)
}
#[test]
fn test_index_range_lower() {
let filtered = test_filter_event_index(&testdata::TEST_EVENT_MULTIDAY, 1, &["1:3"]);
assert!(filtered)
}
#[test]
fn test_index_range_middle() {
let filtered = test_filter_event_index(&testdata::TEST_EVENT_MULTIDAY, 2, &["1:3"]);
assert!(filtered)
}
#[test]
fn test_index_range_upper() {
let filtered = test_filter_event_index(&testdata::TEST_EVENT_MULTIDAY, 3, &["1:3"]);
assert!(filtered)
}
#[test]
fn test_index_range_negative() {
let filtered = test_filter_event_index(&testdata::TEST_EVENT_MULTIDAY, 4, &["1:3"]);
assert_eq!(false, filtered)
}
}
|