use crate::common::BIT_FIELD_BASE_BITS;
use super::{BIT_FIELD_SHIFT_BITS, BitArray};
use crate::common::test_utils::arrays_are_equal;
use rand::RngExt;
#[test]
fn test_get_set() {
let mut array = BitArray::with_size(33);
for i in 0..33 {
assert!(!array.get(i));
array.set(i);
assert!(array.get(i));
}
}
#[test]
fn test_get_next_set1() {
let array = BitArray::with_size(32);
for i in 0..array.get_size() {
assert_eq!(32, array.getNextSet(i), "{i}");
}
let array = BitArray::with_size(33);
for i in 0..array.get_size() {
assert_eq!(33, array.getNextSet(i), "{i}");
}
}
#[test]
fn test_get_next_set2() {
let mut array = BitArray::with_size(33);
array.set(31);
for i in 0..array.get_size() {
assert_eq!(if i <= 31 { 31 } else { 33 }, array.getNextSet(i), "{i}");
}
array = BitArray::with_size(33);
array.set(32);
for i in 0..array.get_size() {
assert_eq!(32, array.getNextSet(i), "{i}");
}
}
#[test]
fn test_get_next_set3() {
let mut array = BitArray::with_size(63);
array.set(31);
array.set(32);
for i in 0..array.get_size() {
let expected;
if i <= 31 {
expected = 31;
} else if i == 32 {
expected = 32;
} else {
expected = 63;
}
assert_eq!(expected, array.getNextSet(i), "{i}");
}
}
#[test]
fn test_get_next_set4() {
let mut array = BitArray::with_size(63);
array.set(33);
array.set(40);
for i in 0..array.get_size() {
let expected;
if i <= 33 {
expected = 33;
} else if i <= 40 {
expected = 40;
} else {
expected = 63;
}
assert_eq!(expected, array.getNextSet(i), "{i}");
}
}
#[test]
fn test_get_next_set5() {
let mut r = rand::rng();
for _i in 0..10 {
let mut array = BitArray::with_size(1 + r.random_range(0..100));
let numSet = r.random_range(0..20);
for _j in 0..numSet {
array.set(r.random_range(0..array.get_size()));
}
let numQueries = r.random_range(0..20);
for _j in 0..numQueries {
let query = r.random_range(0..array.get_size());
let mut expected = query;
while expected < array.get_size() && !array.get(expected) {
expected += 1;
}
let actual = array.getNextSet(query);
assert_eq!(expected, actual);
}
}
}
#[test]
fn test_set_bulk() {
let mut array = BitArray::with_size(64);
array.setBulk(32, 0b11111111111111110000000000000000);
for i in 0..48 {
assert!(!array.get(i));
}
for i in 48..64 {
assert!(array.get(i));
}
}
#[test]
fn test_append_bit() {
let mut array = BitArray::new();
array.appendBits(0b11110, 6).expect("must append)");
let mut array_2 = BitArray::new();
array_2.appendBit(false);
array_2.appendBit(true);
array_2.appendBit(true);
array_2.appendBit(true);
array_2.appendBit(true);
array_2.appendBit(false);
assert_eq!(array.get_size(), array_2.get_size());
assert_eq!(array.getBitArray(), array_2.getBitArray())
}
#[test]
fn test_set_range() {
let mut array = BitArray::with_size(64);
array.setRange(28, 36).unwrap();
assert!(!array.get(27));
for i in 28..36 {
assert!(array.get(i));
}
assert!(!array.get(36));
}
#[test]
fn test_clear() {
let mut array = BitArray::with_size(32);
for i in 0..32 {
array.set(i);
}
array.clear();
for i in 0..32 {
assert!(!array.get(i));
}
}
#[test]
fn test_flip() {
let mut array = BitArray::with_size(32);
assert!(!array.get(5));
array.flip(5);
assert!(array.get(5));
array.flip(5);
assert!(!array.get(5));
}
#[test]
fn test_get_array() {
let mut array = BitArray::with_size(64);
array.set(0);
array.set(63);
let ints = array.getBitArray();
if BIT_FIELD_BASE_BITS == 64 {
assert_eq!(
ints,
&[9223372036854775809_usize.try_into().unwrap_or_default()]
)
} else if BIT_FIELD_BASE_BITS == 128 {
assert_eq!(
ints,
&[9223372036854775809_u128.try_into().unwrap_or_default()]
)
} else {
assert_eq!(1, ints[0]);
assert_eq!(0b10_00_00_00_00_00_00_00_00_00_00_00_00_00_00_00, ints[1]);
}
}
#[test]
fn test_is_range() {
let mut array = BitArray::with_size(64);
assert!(array.isRange(0, 64, false).unwrap());
assert!(!array.isRange(0, 64, true).unwrap());
array.set(32);
assert!(array.isRange(32, 33, true).unwrap());
array.set(31);
assert!(array.isRange(31, 33, true).unwrap());
array.set(34);
assert!(!array.isRange(31, 35, true).unwrap());
for i in 0..31 {
array.set(i);
}
assert!(array.isRange(0, 33, true).unwrap());
for i in 33..64 {
array.set(i);
}
assert!(array.isRange(0, 64, true).unwrap());
assert!(!array.isRange(0, 64, false).unwrap());
}
#[test]
fn reverse_algorithm_test() {
let oldBits: Vec<super::BitFieldBaseType> = vec![128, 256, 512, 6453324, 50934953];
for size in 1..160 {
let newBitsOriginal = reverse_original(&oldBits.clone(), size);
let mut newBitArray = BitArray::with_initial_values(oldBits.clone(), size);
newBitArray.reverse();
let newBitsNew = newBitArray.getBitArray();
assert!(
arrays_are_equal(&newBitsOriginal, newBitsNew, size / BIT_FIELD_BASE_BITS + 1),
"size: ({size}) : {newBitsOriginal:?}/{newBitsNew:?}"
);
}
}
#[test]
fn reverse_test_2() {
let initial_data: super::BitFieldBaseType = 0b00_00_11_00_00_00_00_00_00_00_00_00_00_00_00_00;
for x in 1..=32 {
let expected_data = reverse_original(&[initial_data], x);
let mut array = BitArray::with_size(x);
array.setBulk(0, initial_data);
assert_eq!(&[initial_data], array.getBitArray());
array.reverse();
assert_eq!(expected_data, array.getBitArray(), "for x = {x}");
}
}
#[test]
fn test_clone() {
let array = BitArray::with_size(32);
array.clone().set(0);
assert!(!array.get(0));
}
#[test]
fn test_equals() {
let mut a = BitArray::with_size(32);
let mut b = BitArray::with_size(32);
assert_eq!(a, b);
assert_ne!(a, BitArray::with_size(31));
a.set(16);
assert_ne!(a, b);
b.set(16);
assert_eq!(a, b);
}
#[test]
fn test_reverse_with_modification() {
let mut ba = BitArray::with_size(10);
ba.set(0);
ba.reverse();
assert!(ba.get(9));
assert!(!ba.get(0));
ba.set(8); ba.reverse();
assert!(ba.get(0), "Bit 0 should be set");
assert!(ba.get(1), "Bit 1 should be set (reverse of bit 8)");
}
#[test]
fn test_xor() {
let val_1: super::BitFieldBaseType = 0b01_00_11;
let val_2: super::BitFieldBaseType = 0b10_11_10;
let mut array_1 = BitArray::with_initial_values(vec![val_1], 32);
let array_2 = BitArray::with_initial_values(vec![val_2], 32);
array_1.xor(&array_2).expect("xor complete");
assert_eq!(array_1.getBitArray(), &[0b11_11_01]);
}
#[test]
fn test_xor_2() {
for i in 1..33 {
let val_1: super::BitFieldBaseType = 0b01_00_11;
let val_2: super::BitFieldBaseType = 0b10_01_10;
let mut array_1 = BitArray::new(); let mut array_2 = BitArray::new();
array_1.appendBits(val_1, i).expect("append");
array_2.appendBits(val_2, i).expect("append");
array_1.xor(&array_2).expect("xor complete");
match i {
1 => assert_eq!(array_1.getBitArray(), &[0b1]),
2 => assert_eq!(array_1.getBitArray(), &[0b10]),
3 => assert_eq!(array_1.getBitArray(), &[0b101]),
4 => assert_eq!(array_1.getBitArray(), &[0b10_10]),
5 => assert_eq!(array_1.getBitArray(), &[0b1_0101]),
6 => assert_eq!(array_1.getBitArray(), &[0b10_10_11]),
7..=24 => assert_eq!(array_1.getBitArray(), &[0b10_10_11 << (i - 6)], "{i}"),
_ => {
if BIT_FIELD_BASE_BITS == 32 {
assert_eq!(array_1.getBitArray(), &[0b10_10_11 << (i - 6), 0], "{i}")
} else {
assert_eq!(array_1.getBitArray(), &[0b10_10_11 << (i - 6)], "{i}")
}
}
}
}
}
fn reverse_original(
oldBits: &[super::BitFieldBaseType],
size: usize,
) -> Vec<super::BitFieldBaseType> {
let mut newBits = vec![0; oldBits.len()];
for i in 0..size {
if bit_set(oldBits, size - i - 1) {
newBits[i / BIT_FIELD_BASE_BITS] |= 1 << (i & BIT_FIELD_SHIFT_BITS);
}
}
newBits
}
fn bit_set(bits: &[super::BitFieldBaseType], i: usize) -> bool {
(bits[i / BIT_FIELD_BASE_BITS] & (1 << (i & BIT_FIELD_SHIFT_BITS))) != 0
}