1
0
mirror of https://github.com/danog/strum.git synced 2024-12-03 18:07:52 +01:00
strum/strum_tests/tests/enum_iter.rs
Nevsor 8db6a31332 Implemented DoubleEndedIterator for EnumIter. (#60)
* Implemented DoubleEndedIterator for EnumIter.

* Fixed overlapping behaviour of next and next_back.

* Changed names of tests I accidentally swapped.

* Fixed size_hint() for EnumIter.

* Implemented more efficient version of nth() for EnumIter.

* Added another test of  `next` and `next_back`, where the last call is to `next`.
2019-12-19 14:44:30 -08:00

177 lines
3.8 KiB
Rust

extern crate strum;
#[macro_use]
extern crate strum_macros;
use strum::IntoEnumIterator;
#[derive(Debug, Eq, PartialEq, EnumIter)]
enum Week {
Sunday,
Monday,
Tuesday,
Wednesday,
Thursday,
Friday,
Saturday,
}
#[test]
fn simple_test() {
let results = Week::iter().collect::<Vec<_>>();
let expected = vec![
Week::Sunday,
Week::Monday,
Week::Tuesday,
Week::Wednesday,
Week::Thursday,
Week::Friday,
Week::Saturday,
];
assert_eq!(expected, results);
}
#[derive(Debug, Eq, PartialEq, EnumIter)]
enum Complicated<U: Default, V: Default> {
A(U),
B { v: V },
C,
}
#[test]
fn complicated_test() {
let results = Complicated::iter().collect::<Vec<_>>();
let expected = vec![
Complicated::A(0),
Complicated::B { v: String::new() },
Complicated::C,
];
assert_eq!(expected, results);
}
#[test]
fn len_test() {
let mut i = Complicated::<(), ()>::iter();
assert_eq!(3, i.len());
i.next();
assert_eq!(2, i.len());
i.next();
assert_eq!(1, i.len());
i.next();
assert_eq!(0, i.len());
i.next();
assert_eq!(0, i.size_hint().1.unwrap());
}
#[test]
fn double_ended_len_test() {
let mut i = Complicated::<(), ()>::iter();
assert_eq!(3, i.len());
i.next_back();
assert_eq!(2, i.len());
i.next();
assert_eq!(1, i.len());
i.next_back();
assert_eq!(0, i.len());
}
#[test]
fn clone_test() {
let mut i = Week::iter();
i.next();
i.next();
let mut i_cloned = i.clone();
assert_eq!(Some(Week::Tuesday), i.next());
assert_eq!(Some(Week::Tuesday), i_cloned.next());
i.next();
i.next();
assert_eq!(Some(Week::Friday), i.next());
assert_eq!(Some(Week::Wednesday), i_cloned.next());
}
#[test]
fn cycle_test() {
let results = Week::iter().cycle().take(10).collect::<Vec<_>>();
let expected = vec![
Week::Sunday,
Week::Monday,
Week::Tuesday,
Week::Wednesday,
Week::Thursday,
Week::Friday,
Week::Saturday,
Week::Sunday,
Week::Monday,
Week::Tuesday,
];
assert_eq!(expected, results);
}
#[test]
fn reverse_test() {
let results = Week::iter().rev().collect::<Vec<_>>();
let expected = vec![
Week::Saturday,
Week::Friday,
Week::Thursday,
Week::Wednesday,
Week::Tuesday,
Week::Monday,
Week::Sunday,
];
assert_eq!(expected, results);
}
#[test]
fn take_from_both_sides_test() {
let mut iter = Week::iter();
assert_eq!(Some(Week::Sunday), iter.next());
assert_eq!(Some(Week::Saturday), iter.next_back());
assert_eq!(Some(Week::Friday), iter.next_back());
assert_eq!(Some(Week::Monday), iter.next());
assert_eq!(Some(Week::Tuesday), iter.next());
assert_eq!(Some(Week::Wednesday), iter.next());
assert_eq!(Some(Week::Thursday), iter.next_back());
assert_eq!(None, iter.next());
assert_eq!(None, iter.next_back());
}
#[test]
fn take_from_both_sides_test2() {
let mut iter = Week::iter();
assert_eq!(Some(Week::Sunday), iter.next());
assert_eq!(Some(Week::Saturday), iter.next_back());
assert_eq!(Some(Week::Friday), iter.next_back());
assert_eq!(Some(Week::Monday), iter.next());
assert_eq!(Some(Week::Tuesday), iter.next());
assert_eq!(Some(Week::Wednesday), iter.next());
assert_eq!(Some(Week::Thursday), iter.next());
assert_eq!(None, iter.next_back());
assert_eq!(None, iter.next());
}
#[test]
fn take_nth_test() {
let mut iter = Week::iter();
assert_eq!(Some(Week::Tuesday), iter.nth(2));
assert_eq!(Some(Week::Saturday), iter.nth_back(0));
assert_eq!(Some(Week::Thursday), iter.nth_back(1));
assert_eq!(None, iter.nth(1));
assert_eq!(None, iter.next());
assert_eq!(None, iter.next_back());
}