use crate::common::BitArray;
fn getUnsignedInt(v: &BitArray) -> u64 {
let mut result: u64 = 0;
const OFFSET: usize = 0;
for i in 0..32 {
if v.get(OFFSET + i) {
result |= 1 << (31 - i);
}
}
result
}
#[test]
fn testAppendBit() {
let mut v = BitArray::new();
assert_eq!(0, v.getSizeInBytes());
v.appendBit(true);
assert_eq!(1, v.get_size());
assert_eq!(0x80000000, getUnsignedInt(&v));
v.appendBit(false);
assert_eq!(2, v.get_size());
assert_eq!(0x80000000, getUnsignedInt(&v));
v.appendBit(true);
assert_eq!(3, v.get_size());
assert_eq!(0xa0000000, getUnsignedInt(&v));
v.appendBit(false);
assert_eq!(4, v.get_size());
assert_eq!(0xa0000000, getUnsignedInt(&v));
v.appendBit(true);
assert_eq!(5, v.get_size());
assert_eq!(0xa8000000, getUnsignedInt(&v));
v.appendBit(false);
assert_eq!(6, v.get_size());
assert_eq!(0xa8000000, getUnsignedInt(&v));
v.appendBit(true);
assert_eq!(7, v.get_size());
assert_eq!(0xaa000000, getUnsignedInt(&v));
v.appendBit(false);
assert_eq!(8, v.get_size());
assert_eq!(0xaa000000, getUnsignedInt(&v));
v.appendBit(true);
assert_eq!(9, v.get_size());
assert_eq!(0xaa800000, getUnsignedInt(&v));
v.appendBit(false);
assert_eq!(10, v.get_size());
assert_eq!(0xaa800000, getUnsignedInt(&v));
}
#[test]
fn testAppendBits() {
let mut v = BitArray::new();
v.appendBits(0x1, 1).expect("append");
assert_eq!(1, v.get_size());
assert_eq!(0x80000000, getUnsignedInt(&v));
let mut v = BitArray::new();
v.appendBits(0xff, 8).expect("append");
assert_eq!(8, v.get_size());
assert_eq!(0xff000000, getUnsignedInt(&v));
let mut v = BitArray::new();
v.appendBits(0xff7, 12).expect("append");
assert_eq!(12, v.get_size());
assert_eq!(0xff700000, getUnsignedInt(&v));
}
#[test]
fn testNumBytes() {
let mut v = BitArray::new();
assert_eq!(0, v.getSizeInBytes());
v.appendBit(false);
assert_eq!(1, v.getSizeInBytes());
v.appendBits(0, 7).expect("append");
assert_eq!(1, v.getSizeInBytes());
v.appendBits(0, 8).expect("append");
assert_eq!(2, v.getSizeInBytes());
v.appendBits(0, 1).expect("append");
assert_eq!(3, v.getSizeInBytes());
}
#[test]
fn testAppendBitVector() {
let mut v1 = BitArray::new();
v1.appendBits(0xbe, 8).expect("append");
let mut v2 = BitArray::new();
v2.appendBits(0xef, 8).expect("append");
v1.appendBitArray(v2);
assert_eq!(" X.XXXXX. XXX.XXXX", v1.to_string());
}
#[test]
fn testXOR() {
let mut v1 = BitArray::new();
v1.appendBits(0x5555aaaa, 32).expect("append");
let mut v2 = BitArray::new();
v2.appendBits(0xaaaa5555, 32).expect("append");
v1.xor(&v2).expect("xor");
assert_eq!(0xffffffff, getUnsignedInt(&v1));
}
#[test]
fn testXOR2() {
let mut v1 = BitArray::new();
v1.appendBits(0x2a, 7).expect("append"); let mut v2 = BitArray::new();
v2.appendBits(0x55, 7).expect("append"); v1.xor(&v2).expect("xor");
assert_eq!(0xfe000000, getUnsignedInt(&v1)); }
#[test]
fn testAt() {
let mut v = BitArray::new();
v.appendBits(0xdead, 16).expect("append"); assert!(v.get(0));
assert!(v.get(1));
assert!(!v.get(2));
assert!(v.get(3));
assert!(v.get(4));
assert!(v.get(5));
assert!(v.get(6));
assert!(!v.get(7));
assert!(v.get(8));
assert!(!v.get(9));
assert!(v.get(10));
assert!(!v.get(11));
assert!(v.get(12));
assert!(v.get(13));
assert!(!v.get(14));
assert!(v.get(15));
}
#[test]
fn testToString() {
let mut v = BitArray::new();
v.appendBits(0xdead, 16).expect("append"); assert_eq!(" XX.XXXX. X.X.XX.X", v.to_string());
}