@Test
public void test_arcreader() {
String in_file;
InputStream in;
ByteCountingInputStream bcin;
ArcReader reader;
ArcRecordBase record;
Payload payload;
PayloadWithHeaderAbstract payloadWithHeader;
InputStream in_payload;
byte[] tmpBuf = new byte[8192];
int read;
Object[][] expectedDiagnoses;
int records;
String tmpStr;
MessageDigest md_block = null;
if (blockAlgo != null) {
try {
md_block = MessageDigest.getInstance(blockAlgo);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
MessageDigest md_payload = null;
if (payloadAlgo != null) {
try {
md_payload = MessageDigest.getInstance(payloadAlgo);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
byte[] block_digest;
byte[] payload_digest;
try {
/*
* Uncompressed.
*/
in_file = "IAH-20080430204825-00000-blackbook.arc";
in = this.getClass().getClassLoader().getResourceAsStream(in_file);
bcin = new ByteCountingInputStream(in);
reader = ArcReaderFactory.getReader(bcin, 8192);
reader.setBlockDigestAlgorithm(blockAlgo);
reader.setBlockDigestEncoding(blockBase);
reader.setBlockDigestEnabled(true);
reader.setPayloadDigestAlgorithm(payloadAlgo);
reader.setPayloadDigestEncoding(payloadBase);
reader.setPayloadDigestEnabled(true);
records = 0;
while ((record = reader.getNextRecord()) != null) {
payload = record.getPayload();
Assert.assertEquals(record.payload, payload);
payloadWithHeader = null;
if (payload != null) {
Assert.assertTrue(record.hasPayload());
payloadWithHeader = payload.getPayloadHeaderWrapped();
} else {
Assert.assertFalse(record.hasPayload());
}
if (md_payload != null) {
md_payload.reset();
}
if (md_block != null && payload != null) {
md_block.reset();
}
block_digest = null;
payload_digest = null;
if (md_payload != null && payloadWithHeader != null) {
md_block.update(payloadWithHeader.getHeader());
//System.out.println("--");
//System.out.println(new String(payloadWithHeader.getHeader()));
//System.out.println("--");
in_payload = payloadWithHeader.getPayloadInputStream();
while ((read = in_payload.read(tmpBuf)) != -1) {
md_block.update(tmpBuf, 0, read);
md_payload.update(tmpBuf, 0, read);
}
} else if (md_block != null && payload != null) {
in_payload = payload.getInputStream();
while ((read = in_payload.read(tmpBuf)) != -1) {
md_block.update(tmpBuf, 0, read);
}
}
Assert.assertFalse(record.isClosed());
record.close();
Assert.assertTrue(record.isClosed());
++records;
if (md_block != null && payload != null) {
block_digest = md_block.digest();
//System.out.println("b1: " + Base16.encodeArray(block_digest));
//System.out.println("b2: " + Base16.encodeArray(payload.getDigest()));
Assert.assertArrayEquals(block_digest, payload.getDigest());
Assert.assertEquals(blockAlgo, record.computedBlockDigest.algorithm);
if (!"base2".equals(blockBase)) {
Assert.assertEquals(blockBase, record.computedBlockDigest.encoding);
} else {
Assert.assertNull(record.computedBlockDigest.encoding);
}
Assert.assertArrayEquals(record.computedBlockDigest.digestBytes, payload.getDigest());
} else {
Assert.assertNull(record.computedBlockDigest);
}
if (md_payload != null && payloadWithHeader != null) {
payload_digest = md_payload.digest();
//System.out.println("p1: " + Base16.encodeArray(payload_digest));
//System.out.println("p2: " + Base16.encodeArray(payloadWithHeader.getDigest()));
Assert.assertArrayEquals(payload_digest, payloadWithHeader.getDigest());
Assert.assertEquals(payloadAlgo, record.computedPayloadDigest.algorithm);
if (!"base2".equals(payloadBase)) {
Assert.assertEquals(payloadBase, record.computedPayloadDigest.encoding);
} else {
Assert.assertNull(record.computedPayloadDigest.encoding);
}
Assert.assertArrayEquals(record.computedPayloadDigest.digestBytes, payloadWithHeader.getDigest());
} else {
Assert.assertNull(record.computedPayloadDigest);
}
if (!"base2".equals(blockBase) && !"base2".equals(payloadBase)) {
Assert.assertTrue(record.isCompliant());
Assert.assertFalse(record.diagnostics.hasErrors());
Assert.assertFalse(record.diagnostics.hasWarnings());
} else {
Assert.assertFalse(record.isCompliant());
if (payloadWithHeader != null) {
expectedDiagnoses = new Object[][] {
{DiagnosisType.INVALID_DATA, "Block digest encoding scheme", 1},
{DiagnosisType.INVALID_DATA, "Payload digest encoding scheme", 1}
};
} else if (payload != null) {
expectedDiagnoses = new Object[][] {
{DiagnosisType.INVALID_DATA, "Block digest encoding scheme", 1},
};
} else {
expectedDiagnoses = new Object[0][0];
}
TestBaseUtils.compareDiagnoses(expectedDiagnoses, record.diagnostics.getErrors());
Assert.assertFalse(record.diagnostics.hasWarnings());
}
tmpStr = record.toString();
Assert.assertNotNull(tmpStr);
}
Assert.assertEquals(300, records);
Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
reader.close();
Assert.assertEquals(300, records);
Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
/*
* Compressed.
*/
in_file = "IAH-20080430204825-00000-blackbook.arc.gz";
in = this.getClass().getClassLoader().getResourceAsStream(in_file);
bcin = new ByteCountingInputStream(in);
reader = ArcReaderFactory.getReader(bcin, 8192);
reader.setBlockDigestAlgorithm(blockAlgo);
reader.setBlockDigestEncoding(blockBase);
reader.setBlockDigestEnabled(true);
reader.setPayloadDigestAlgorithm(payloadAlgo);
reader.setPayloadDigestEncoding(payloadBase);
reader.setPayloadDigestEnabled(true);
records = 0;
while ((record = reader.getNextRecord()) != null) {
payload = record.getPayload();
Assert.assertEquals(record.payload, payload);
payloadWithHeader = null;
if (payload != null) {
Assert.assertTrue(record.hasPayload());
payloadWithHeader = payload.getPayloadHeaderWrapped();
} else {
Assert.assertFalse(record.hasPayload());
}
if (md_payload != null) {
md_payload.reset();
}
if (md_block != null && payload != null) {
md_block.reset();
}
block_digest = null;
payload_digest = null;
if (md_payload != null && payloadWithHeader != null) {
md_block.update(payloadWithHeader.getHeader());
//System.out.println("--");
//System.out.println(new String(payloadWithHeader.getHeader()));
//System.out.println("--");
in_payload = payloadWithHeader.getPayloadInputStream();
while ((read = in_payload.read(tmpBuf)) != -1) {
md_block.update(tmpBuf, 0, read);
md_payload.update(tmpBuf, 0, read);
}
} else if (md_block != null && payload != null) {
in_payload = payload.getInputStream();
while ((read = in_payload.read(tmpBuf)) != -1) {
md_block.update(tmpBuf, 0, read);
}
}
Assert.assertFalse(record.isClosed());
record.close();
Assert.assertTrue(record.isClosed());
++records;
if (md_block != null && payload != null) {
block_digest = md_block.digest();
//System.out.println("b1: " + Base16.encodeArray(block_digest));
//System.out.println("b2: " + Base16.encodeArray(payload.getDigest()));
Assert.assertArrayEquals(block_digest, payload.getDigest());
Assert.assertEquals(blockAlgo, record.computedBlockDigest.algorithm);
if (!"base2".equals(blockBase)) {
Assert.assertEquals(blockBase, record.computedBlockDigest.encoding);
} else {
Assert.assertNull(record.computedBlockDigest.encoding);
}
Assert.assertArrayEquals(record.computedBlockDigest.digestBytes, payload.getDigest());
} else {
Assert.assertNull(record.computedBlockDigest);
}
if (md_payload != null && payloadWithHeader != null) {
payload_digest = md_payload.digest();
//System.out.println("p1: " + Base16.encodeArray(payload_digest));
//System.out.println("p2: " + Base16.encodeArray(payloadWithHeader.getDigest()));
Assert.assertArrayEquals(payload_digest, payloadWithHeader.getDigest());
Assert.assertEquals(payloadAlgo, record.computedPayloadDigest.algorithm);
if (!"base2".equals(payloadBase)) {
Assert.assertEquals(payloadBase, record.computedPayloadDigest.encoding);
} else {
Assert.assertNull(record.computedPayloadDigest.encoding);
}
Assert.assertArrayEquals(record.computedPayloadDigest.digestBytes, payloadWithHeader.getDigest());
} else {
Assert.assertNull(record.computedPayloadDigest);
}
if (!"base2".equals(blockBase) && !"base2".equals(payloadBase)) {
Assert.assertTrue(record.isCompliant());
Assert.assertFalse(record.diagnostics.hasErrors());
Assert.assertFalse(record.diagnostics.hasWarnings());
} else {
Assert.assertFalse(record.isCompliant());
if (payloadWithHeader != null) {
expectedDiagnoses = new Object[][] {
{DiagnosisType.INVALID_DATA, "Block digest encoding scheme", 1},
{DiagnosisType.INVALID_DATA, "Payload digest encoding scheme", 1}
};
} else if (payload != null) {
expectedDiagnoses = new Object[][] {
{DiagnosisType.INVALID_DATA, "Block digest encoding scheme", 1},
};
} else {
expectedDiagnoses = new Object[0][0];
}
TestBaseUtils.compareDiagnoses(expectedDiagnoses, record.diagnostics.getErrors());
Assert.assertFalse(record.diagnostics.hasWarnings());
}
tmpStr = record.toString();
Assert.assertNotNull(tmpStr);
}
Assert.assertEquals(300, records);
Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
reader.close();
Assert.assertEquals(300, records);
Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
/*
* Small file.
*/
in_file = "small_BNF.arc";
in = this.getClass().getClassLoader().getResourceAsStream(in_file);
bcin = new ByteCountingInputStream(in);
reader = ArcReaderFactory.getReader(bcin, 8192);
reader.setBlockDigestAlgorithm(blockAlgo);
reader.setBlockDigestEncoding(blockBase);
reader.setBlockDigestEnabled(true);
reader.setPayloadDigestAlgorithm(payloadAlgo);
reader.setPayloadDigestEncoding(payloadBase);
reader.setPayloadDigestEnabled(true);
records = 0;
while ((record = reader.getNextRecord()) != null) {
payload = record.getPayload();
Assert.assertEquals(record.payload, payload);
payloadWithHeader = null;
if (payload != null) {
Assert.assertTrue(record.hasPayload());
payloadWithHeader = payload.getPayloadHeaderWrapped();
} else {
Assert.assertFalse(record.hasPayload());
}
if (md_payload != null) {
md_payload.reset();
}
if (md_block != null && payload != null) {
md_block.reset();
}
block_digest = null;
payload_digest = null;
if (md_payload != null && payloadWithHeader != null) {
md_block.update(payloadWithHeader.getHeader());
//System.out.println("--");
//System.out.println(new String(payloadWithHeader.getHeader()));
//System.out.println("--");
in_payload = payloadWithHeader.getPayloadInputStream();
while ((read = in_payload.read(tmpBuf)) != -1) {
md_block.update(tmpBuf, 0, read);
md_payload.update(tmpBuf, 0, read);
}
} else if (md_block != null && payload != null) {
in_payload = payload.getInputStream();
while ((read = in_payload.read(tmpBuf)) != -1) {
md_block.update(tmpBuf, 0, read);
}
}
Assert.assertFalse(record.isClosed());
record.close();
Assert.assertTrue(record.isClosed());
++records;
if (md_block != null && payload != null) {
block_digest = md_block.digest();
//System.out.println("b1: " + Base16.encodeArray(block_digest));
//System.out.println("b2: " + Base16.encodeArray(payload.getDigest()));
Assert.assertArrayEquals(block_digest, payload.getDigest());
Assert.assertEquals(blockAlgo, record.computedBlockDigest.algorithm);
if (!"base2".equals(blockBase)) {
Assert.assertEquals(blockBase, record.computedBlockDigest.encoding);
} else {
Assert.assertNull(record.computedBlockDigest.encoding);
}
Assert.assertArrayEquals(record.computedBlockDigest.digestBytes, payload.getDigest());
} else {
Assert.assertNull(record.computedBlockDigest);
}
if (md_payload != null && payloadWithHeader != null) {
payload_digest = md_payload.digest();
//System.out.println("p1: " + Base16.encodeArray(payload_digest));
//System.out.println("p2: " + Base16.encodeArray(payloadWithHeader.getDigest()));
Assert.assertArrayEquals(payload_digest, payloadWithHeader.getDigest());
Assert.assertEquals(payloadAlgo, record.computedPayloadDigest.algorithm);
if (!"base2".equals(payloadBase)) {
Assert.assertEquals(payloadBase, record.computedPayloadDigest.encoding);
} else {
Assert.assertNull(record.computedPayloadDigest.encoding);
}
Assert.assertArrayEquals(record.computedPayloadDigest.digestBytes, payloadWithHeader.getDigest());
} else {
Assert.assertNull(record.computedPayloadDigest);
}
if (!"base2".equals(blockBase) && !"base2".equals(payloadBase)) {
Assert.assertTrue(record.isCompliant());
Assert.assertFalse(record.diagnostics.hasErrors());
Assert.assertFalse(record.diagnostics.hasWarnings());
} else {
Assert.assertFalse(record.isCompliant());
if (payloadWithHeader != null) {
expectedDiagnoses = new Object[][] {
{DiagnosisType.INVALID_DATA, "Block digest encoding scheme", 1},
{DiagnosisType.INVALID_DATA, "Payload digest encoding scheme", 1}
};
} else if (payload != null) {
expectedDiagnoses = new Object[][] {
{DiagnosisType.INVALID_DATA, "Block digest encoding scheme", 1},
};
} else {
expectedDiagnoses = new Object[0][0];
}
TestBaseUtils.compareDiagnoses(expectedDiagnoses, record.diagnostics.getErrors());
Assert.assertFalse(record.diagnostics.hasWarnings());
}
tmpStr = record.toString();
Assert.assertNotNull(tmpStr);
}
Assert.assertEquals(6, records);
Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
reader.close();
Assert.assertEquals(6, records);
Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
} catch (IOException e) {
e.printStackTrace();
Assert.fail("Unexpected exception!");
}
}