aboutsummaryrefslogtreecommitdiffstats
path: root/src/test
diff options
context:
space:
mode:
Diffstat (limited to 'src/test')
-rwxr-xr-xsrc/test/data/V2007/testOleV2007.accdbbin0 -> 8634368 bytes
-rw-r--r--src/test/java/com/healthmarketscience/jackcess/impl/JetFormatTest.java3
-rw-r--r--src/test/java/com/healthmarketscience/jackcess/util/OleBlobTest.java154
3 files changed, 156 insertions, 1 deletions
diff --git a/src/test/data/V2007/testOleV2007.accdb b/src/test/data/V2007/testOleV2007.accdb
new file mode 100755
index 0000000..398818e
--- /dev/null
+++ b/src/test/data/V2007/testOleV2007.accdb
Binary files differ
diff --git a/src/test/java/com/healthmarketscience/jackcess/impl/JetFormatTest.java b/src/test/java/com/healthmarketscience/jackcess/impl/JetFormatTest.java
index 8ff2232..c5028cc 100644
--- a/src/test/java/com/healthmarketscience/jackcess/impl/JetFormatTest.java
+++ b/src/test/java/com/healthmarketscience/jackcess/impl/JetFormatTest.java
@@ -46,7 +46,8 @@ public class JetFormatTest extends TestCase {
PROMOTION("testPromotion"),
COMPLEX("complexDataTest"),
UNSUPPORTED("unsupportedFieldsTest"),
- LINKED("linkerTest");
+ LINKED("linkerTest"),
+ BLOB("testOle");
private final String _basename;
diff --git a/src/test/java/com/healthmarketscience/jackcess/util/OleBlobTest.java b/src/test/java/com/healthmarketscience/jackcess/util/OleBlobTest.java
index 1c3e104..b519664 100644
--- a/src/test/java/com/healthmarketscience/jackcess/util/OleBlobTest.java
+++ b/src/test/java/com/healthmarketscience/jackcess/util/OleBlobTest.java
@@ -20,6 +20,8 @@ USA
package com.healthmarketscience.jackcess.util;
import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
import java.util.Arrays;
import com.healthmarketscience.jackcess.ColumnBuilder;
@@ -30,9 +32,15 @@ import static com.healthmarketscience.jackcess.DatabaseTest.*;
import com.healthmarketscience.jackcess.Row;
import com.healthmarketscience.jackcess.Table;
import com.healthmarketscience.jackcess.TableBuilder;
+import com.healthmarketscience.jackcess.complex.Attachment;
+import com.healthmarketscience.jackcess.complex.ComplexValueForeignKey;
import com.healthmarketscience.jackcess.impl.ByteUtil;
+import com.healthmarketscience.jackcess.impl.CompoundOleUtil;
import static com.healthmarketscience.jackcess.impl.JetFormatTest.*;
import junit.framework.TestCase;
+import org.apache.poi.poifs.filesystem.DocumentEntry;
+import org.apache.poi.poifs.filesystem.DocumentInputStream;
+import org.apache.poi.poifs.filesystem.NPOIFSFileSystem;
/**
*
@@ -149,4 +157,150 @@ public class OleBlobTest extends TestCase
db.close();
}
}
+
+ public void testReadBlob() throws Exception
+ {
+ for(TestDB testDb : TestDB.getSupportedForBasename(Basename.BLOB, true)) {
+ Database db = open(testDb);
+
+ Table t = db.getTable("Table1");
+
+ for(Row row : t) {
+
+ OleBlob oleBlob = null;
+ try {
+
+ String name = (String)row.get("name");
+ oleBlob = OleBlob.Builder.fromInternalData((byte[])row.get("ole_data"));
+ OleBlob.Content content = oleBlob.getContent();
+ Attachment attach = null;
+ if(content.getType() != OleBlob.ContentType.LINK) {
+ attach = ((ComplexValueForeignKey)row.get("attach_data"))
+ .getAttachments().get(0);
+ }
+
+ switch(content.getType()) {
+ case LINK:
+ OleBlob.LinkContent lc = (OleBlob.LinkContent)content;
+ if("test_link".equals(name)) {
+ assertEquals("Z:\\jackcess_test\\ole\\test_data.txt", lc.getLinkPath());
+ } else {
+ assertEquals("Z:\\jackcess_test\\ole\\test_datau2.txt", lc.getLinkPath());
+ }
+ break;
+
+ case SIMPLE_PACKAGE:
+ OleBlob.SimplePackageContent spc = (OleBlob.SimplePackageContent)content;
+ byte[] packageBytes = toByteArray(spc.getStream(), spc.length());
+ assertTrue(Arrays.equals(attach.getFileData(), packageBytes));
+ break;
+
+ case COMPOUND_STORAGE:
+ OleBlob.CompoundContent cc = (OleBlob.CompoundContent)content;
+ if(cc.hasContentsEntry()) {
+ OleBlob.CompoundContent.Entry entry = cc.getContentsEntry();
+ byte[] entryBytes = toByteArray(entry.getStream(), entry.length());
+ assertTrue(Arrays.equals(attach.getFileData(), entryBytes));
+ } else {
+
+ if("test_word.doc".equals(name)) {
+ checkCompoundEntries(cc,
+ "/%02OlePres000", 466,
+ "/WordDocument", 4096,
+ "/%05SummaryInformation", 4096,
+ "/%05DocumentSummaryInformation", 4096,
+ "/%03AccessObjSiteData", 56,
+ "/%02OlePres001", 1620,
+ "/1Table", 6380,
+ "/%01CompObj", 114,
+ "/%01Ole", 20);
+ checkCompoundStorage(cc, attach);
+ } else if("test_excel.xls".equals(name)) {
+ checkCompoundEntries(cc,
+ "/%02OlePres000", 1326,
+ "/%03AccessObjSiteData", 56,
+ "/%05SummaryInformation", 200,
+ "/%05DocumentSummaryInformation", 264,
+ "/%02OlePres001", 4208,
+ "/%01CompObj", 107,
+ "/Workbook", 13040,
+ "/%01Ole", 20);
+ // the excel data seems to be modified when embedded as ole,
+ // so we can't reallly test it against the attachment data
+ } else {
+ throw new RuntimeException("unexpected compound entry " + name);
+ }
+ }
+ break;
+
+ case OTHER:
+ OleBlob.OtherContent oc = (OleBlob.OtherContent)content;
+ byte[] otherBytes = toByteArray(oc.getStream(), oc.length());
+ assertTrue(Arrays.equals(attach.getFileData(), otherBytes));
+ break;
+
+ default:
+ throw new RuntimeException("unexpected type " + content.getType());
+ }
+
+ } finally {
+ ByteUtil.closeQuietly(oleBlob);
+ }
+ }
+
+ db.close();
+ }
+ }
+
+ private static void checkCompoundEntries(OleBlob.CompoundContent cc,
+ Object... entryInfo)
+ throws Exception
+ {
+ int idx = 0;
+ for(OleBlob.CompoundContent.Entry e : cc) {
+ String entryName = (String)entryInfo[idx];
+ int entryLen = (Integer)entryInfo[idx + 1];
+
+ assertEquals(entryName, e.getName());
+ assertEquals(entryLen, e.length());
+
+ idx += 2;
+ }
+ }
+
+ private static void checkCompoundStorage(OleBlob.CompoundContent cc,
+ Attachment attach)
+ throws Exception
+ {
+ File tmpData = File.createTempFile("attach_", ".dat");
+
+ try {
+ FileOutputStream fout = new FileOutputStream(tmpData);
+ fout.write(attach.getFileData());
+ fout.close();
+
+ NPOIFSFileSystem attachFs = new NPOIFSFileSystem(tmpData, true);
+
+ for(OleBlob.CompoundContent.Entry e : cc) {
+ DocumentEntry attachE = null;
+ try {
+ attachE = CompoundOleUtil.getDocumentEntry(e.getName(), attachFs.getRoot());
+ } catch(FileNotFoundException fnfe) {
+ // ignored, the ole data has extra entries
+ continue;
+ }
+
+ byte[] attachEBytes = toByteArray(new DocumentInputStream(attachE),
+ attachE.getSize());
+ byte[] entryBytes = toByteArray(e.getStream(), e.length());
+
+ assertTrue(Arrays.equals(attachEBytes, entryBytes));
+ }
+
+ ByteUtil.closeQuietly(attachFs);
+
+ } finally {
+ tmpData.delete();
+ }
+ }
}