Sha256: 802a8980424d5c62408aea4af91b7515636597623b06a32dd2344df378c4fde1

Contents?: true

Size: 1.88 KB

Versions: 13

Compression:

Stored size: 1.88 KB

Contents

use itertools::free::zip_eq;
use itertools::multizip;
use itertools::EitherOrBoth::{Both, Left, Right};
use itertools::Itertools;

#[test]
fn zip_longest_fused() {
    let a = [Some(1), None, Some(3), Some(4)];
    let b = [1, 2, 3];

    let unfused = a
        .iter()
        .batching(|it| *it.next().unwrap())
        .zip_longest(b.iter().cloned());
    itertools::assert_equal(unfused, vec![Both(1, 1), Right(2), Right(3)]);
}

#[test]
fn test_zip_longest_size_hint() {
    let c = (1..10).cycle();
    let v: &[_] = &[0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
    let v2 = &[10, 11, 12];

    assert_eq!(c.zip_longest(v.iter()).size_hint(), (std::usize::MAX, None));

    assert_eq!(v.iter().zip_longest(v2.iter()).size_hint(), (10, Some(10)));
}

#[test]
fn test_double_ended_zip_longest() {
    let xs = [1, 2, 3, 4, 5, 6];
    let ys = [1, 2, 3, 7];
    let a = xs.iter().copied();
    let b = ys.iter().copied();
    let mut it = a.zip_longest(b);
    assert_eq!(it.next(), Some(Both(1, 1)));
    assert_eq!(it.next(), Some(Both(2, 2)));
    assert_eq!(it.next_back(), Some(Left(6)));
    assert_eq!(it.next_back(), Some(Left(5)));
    assert_eq!(it.next_back(), Some(Both(4, 7)));
    assert_eq!(it.next(), Some(Both(3, 3)));
    assert_eq!(it.next(), None);
}

#[test]
fn test_double_ended_zip() {
    let xs = [1, 2, 3, 4, 5, 6];
    let ys = [1, 2, 3, 7];
    let a = xs.iter().copied();
    let b = ys.iter().copied();
    let mut it = multizip((a, b));
    assert_eq!(it.next_back(), Some((4, 7)));
    assert_eq!(it.next_back(), Some((3, 3)));
    assert_eq!(it.next_back(), Some((2, 2)));
    assert_eq!(it.next_back(), Some((1, 1)));
    assert_eq!(it.next_back(), None);
}

#[should_panic]
#[test]
fn zip_eq_panic1() {
    let a = [1, 2];
    let b = [1, 2, 3];

    zip_eq(&a, &b).count();
}

#[should_panic]
#[test]
fn zip_eq_panic2() {
    let a: [i32; 0] = [];
    let b = [1, 2, 3];

    zip_eq(&a, &b).count();
}

Version data entries

13 entries across 13 versions & 1 rubygems

Version Path
wasmtime-29.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-28.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-27.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-26.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-25.0.2 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-25.0.1 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-25.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-24.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-23.0.2 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-22.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-21.0.1 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-20.0.2 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs
wasmtime-20.0.0 ./ext/cargo-vendor/itertools-0.12.1/tests/zip.rs