/*
* Copyright 2008 ZXing authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package ntu.com.google.zxing.qrcode.encoder;
import ntu.com.google.zxing.common.BitArray;
import org.junit.Assert;
import org.junit.Test;
/**
* @author satorux@google.com (Satoru Takabayashi) - creator
* @author dswitkin@google.com (Daniel Switkin) - ported from C++
*/
public class BitVectorTestCase extends Assert {
private static long getUnsignedInt(BitArray v, int index) {
long result = 0L;
for (int i = 0, offset = index << 3; i < 32; i++) {
if (v.get(offset + i)) {
result |= 1L << (31 - i);
}
}
return result;
}
@Test
public void testAppendBit() {
BitArray v = new BitArray();
assertEquals(0, v.getSizeInBytes());
// 1
v.appendBit(true);
assertEquals(1, v.getSize());
assertEquals(0x80000000L, getUnsignedInt(v, 0));
// 10
v.appendBit(false);
assertEquals(2, v.getSize());
assertEquals(0x80000000L, getUnsignedInt(v, 0));
// 101
v.appendBit(true);
assertEquals(3, v.getSize());
assertEquals(0xa0000000L, getUnsignedInt(v, 0));
// 1010
v.appendBit(false);
assertEquals(4, v.getSize());
assertEquals(0xa0000000L, getUnsignedInt(v, 0));
// 10101
v.appendBit(true);
assertEquals(5, v.getSize());
assertEquals(0xa8000000L, getUnsignedInt(v, 0));
// 101010
v.appendBit(false);
assertEquals(6, v.getSize());
assertEquals(0xa8000000L, getUnsignedInt(v, 0));
// 1010101
v.appendBit(true);
assertEquals(7, v.getSize());
assertEquals(0xaa000000L, getUnsignedInt(v, 0));
// 10101010
v.appendBit(false);
assertEquals(8, v.getSize());
assertEquals(0xaa000000L, getUnsignedInt(v, 0));
// 10101010 1
v.appendBit(true);
assertEquals(9, v.getSize());
assertEquals(0xaa800000L, getUnsignedInt(v, 0));
// 10101010 10
v.appendBit(false);
assertEquals(10, v.getSize());
assertEquals(0xaa800000L, getUnsignedInt(v, 0));
}
@Test
public void testAppendBits() {
{
BitArray v = new BitArray();
v.appendBits(0x1, 1);
assertEquals(1, v.getSize());
assertEquals(0x80000000L, getUnsignedInt(v, 0));
}
{
BitArray v = new BitArray();
v.appendBits(0xff, 8);
assertEquals(8, v.getSize());
assertEquals(0xff000000L, getUnsignedInt(v, 0));
}
{
BitArray v = new BitArray();
v.appendBits(0xff7, 12);
assertEquals(12, v.getSize());
assertEquals(0xff700000L, getUnsignedInt(v, 0));
}
}
@Test
public void testNumBytes() {
BitArray v = new BitArray();
assertEquals(0, v.getSizeInBytes());
v.appendBit(false);
// 1 bit was added in the vector, so 1 byte should be consumed.
assertEquals(1, v.getSizeInBytes());
v.appendBits(0, 7);
assertEquals(1, v.getSizeInBytes());
v.appendBits(0, 8);
assertEquals(2, v.getSizeInBytes());
v.appendBits(0, 1);
// We now have 17 bits, so 3 bytes should be consumed.
assertEquals(3, v.getSizeInBytes());
}
@Test
public void testAppendBitVector() {
BitArray v1 = new BitArray();
v1.appendBits(0xbe, 8);
BitArray v2 = new BitArray();
v2.appendBits(0xef, 8);
v1.appendBitArray(v2);
// beef = 1011 1110 1110 1111
assertEquals(" X.XXXXX. XXX.XXXX", v1.toString());
}
@Test
public void testXOR() {
{
BitArray v1 = new BitArray();
v1.appendBits(0x5555aaaa, 32);
BitArray v2 = new BitArray();
v2.appendBits(0xaaaa5555, 32);
v1.xor(v2);
assertEquals(0xffffffffL, getUnsignedInt(v1, 0));
}
{
BitArray v1 = new BitArray();
v1.appendBits(0x2a, 7); // 010 1010
BitArray v2 = new BitArray();
v2.appendBits(0x55, 7); // 101 0101
v1.xor(v2);
assertEquals(0xfe000000L, getUnsignedInt(v1, 0)); // 1111 1110
}
}
@Test
public void testAt() {
BitArray v = new BitArray();
v.appendBits(0xdead, 16); // 1101 1110 1010 1101
assertTrue(v.get(0));
assertTrue(v.get(1));
assertFalse(v.get(2));
assertTrue(v.get(3));
assertTrue(v.get(4));
assertTrue(v.get(5));
assertTrue(v.get(6));
assertFalse(v.get(7));
assertTrue(v.get(8));
assertFalse(v.get(9));
assertTrue(v.get(10));
assertFalse(v.get(11));
assertTrue(v.get(12));
assertTrue(v.get(13));
assertFalse(v.get(14));
assertTrue(v.get(15));
}
@Test
public void testToString() {
BitArray v = new BitArray();
v.appendBits(0xdead, 16); // 1101 1110 1010 1101
assertEquals(" XX.XXXX. X.X.XX.X", v.toString());
}
}