diff options
| author | Andre Bogus <bogusandre@gmail.com> | 2019-01-29 16:15:02 +0100 |
|---|---|---|
| committer | Andre Bogus <bogusandre@gmail.com> | 2019-01-30 09:11:17 +0100 |
| commit | b062b75559c1e6300324193873631e5e7beccfd7 (patch) | |
| tree | 46e999a55c1f662a30c2447116b038336321497a /src/liballoc/tests | |
| parent | 106b3e9fa4d53efc4e8eab47d1043789c88f99a5 (diff) | |
| download | rust-b062b75559c1e6300324193873631e5e7beccfd7.tar.gz rust-b062b75559c1e6300324193873631e5e7beccfd7.zip | |
override `VecDeque`'s `Iter::try_fold`
Diffstat (limited to 'src/liballoc/tests')
| -rw-r--r-- | src/liballoc/tests/vec_deque.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/src/liballoc/tests/vec_deque.rs b/src/liballoc/tests/vec_deque.rs index 76831ba65e3..c9d16a06b47 100644 --- a/src/liballoc/tests/vec_deque.rs +++ b/src/liballoc/tests/vec_deque.rs @@ -1433,3 +1433,40 @@ fn test_rotate_right_random() { } } } + +#[test] +fn test_try_fold_empty() { + assert_eq!(Some(0), VecDeque::<u32>::new().iter().try_fold(0, |_, _| None)); +} + +#[test] +fn test_try_fold_none() { + let v: VecDeque<u32> = (0..12).collect(); + assert_eq!(None, v.into_iter().try_fold(0, |a, b| + if b < 11 { Some(a + b) } else { None })); +} + +#[test] +fn test_try_fold_ok() { + let v: VecDeque<u32> = (0..12).collect(); + assert_eq!(Ok::<_, ()>(66), v.into_iter().try_fold(0, |a, b| Ok(a + b))); +} + +#[test] +fn test_try_fold_unit() { + let v: VecDeque<()> = std::iter::repeat(()).take(42).collect(); + assert_eq!(Some(()), v.into_iter().try_fold((), |(), ()| Some(()))); +} + +#[test] +fn test_try_fold_rotated() { + let mut v: VecDeque<_> = (0..12).collect(); + for n in 0..10 { + if n & 1 == 0 { + v.rotate_left(n); + } else { + v.rotate_right(n); + } + assert_eq!(Ok::<_, ()>(66), v.iter().try_fold(0, |a, b| Ok(a + b))); + } +} |
