arrow2 0.15.0

Unofficial implementation of Apache Arrow spec in safe Rust
Documentation
use arrow2::array::*;

use super::test_equal;

#[test]
fn test_boolean_equal() {
    let a = BooleanArray::from_slice([false, false, true]);
    let b = BooleanArray::from_slice([false, false, true]);
    test_equal(&a, &b, true);

    let b = BooleanArray::from_slice([false, false, false]);
    test_equal(&a, &b, false);
}

#[test]
fn test_boolean_equal_null() {
    let a = BooleanArray::from(vec![Some(false), None, None, Some(true)]);
    let b = BooleanArray::from(vec![Some(false), None, None, Some(true)]);
    test_equal(&a, &b, true);

    let b = BooleanArray::from(vec![None, None, None, Some(true)]);
    test_equal(&a, &b, false);

    let b = BooleanArray::from(vec![Some(true), None, None, Some(true)]);
    test_equal(&a, &b, false);
}

#[test]
fn test_boolean_equal_offset() {
    let a = BooleanArray::from_slice(vec![false, true, false, true, false, false, true]);
    let b = BooleanArray::from_slice(vec![true, false, false, false, true, false, true, true]);
    test_equal(&a, &b, false);

    let a_slice = a.slice(2, 3);
    let b_slice = b.slice(3, 3);
    test_equal(&a_slice, &b_slice, true);

    let a_slice = a.slice(3, 4);
    let b_slice = b.slice(4, 4);
    test_equal(&a_slice, &b_slice, false);

    // Elements fill in `u8`'s exactly.
    let mut vector = vec![false, false, true, true, true, true, true, true];
    let a = BooleanArray::from_slice(vector.clone());
    let b = BooleanArray::from_slice(vector.clone());
    test_equal(&a, &b, true);

    // Elements fill in `u8`s + suffix bits.
    vector.push(true);
    let a = BooleanArray::from_slice(vector.clone());
    let b = BooleanArray::from_slice(vector);
    test_equal(&a, &b, true);
}