summary refs log tree commit diff
path: root/src/liballoc/tests
diff options
context:
space:
mode:
authorAndre Bogus <bogusandre@gmail.com>2019-01-29 16:15:02 +0100
committerAndre Bogus <bogusandre@gmail.com>2019-01-30 09:11:17 +0100
commitb062b75559c1e6300324193873631e5e7beccfd7 (patch)
tree46e999a55c1f662a30c2447116b038336321497a /src/liballoc/tests
parent106b3e9fa4d53efc4e8eab47d1043789c88f99a5 (diff)
downloadrust-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.rs37
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)));
+    }
+}