From cb3b8085ccf3b3c2a52a4d431b2a3befd98c1ef2 Mon Sep 17 00:00:00 2001 From: James Ahlborn Date: Wed, 26 Oct 2011 02:57:23 +0000 Subject: add 2007 complex test db git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@581 f203690c-595d-4dc9-a70b-905162fa7fd2 --- test/data/V2007/complexDataTestV2007.accdb | Bin 0 -> 524288 bytes .../jackcess/ComplexColumnTest.java | 344 +++++++++++---------- .../jackcess/JetFormatTest.java | 3 +- 3 files changed, 179 insertions(+), 168 deletions(-) create mode 100755 test/data/V2007/complexDataTestV2007.accdb (limited to 'test') diff --git a/test/data/V2007/complexDataTestV2007.accdb b/test/data/V2007/complexDataTestV2007.accdb new file mode 100755 index 0000000..3f9ff36 Binary files /dev/null and b/test/data/V2007/complexDataTestV2007.accdb differ diff --git a/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java b/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java index d853f6f..a0664c4 100644 --- a/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java +++ b/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java @@ -8,6 +8,7 @@ import java.util.Date; import java.util.List; import java.util.Map; +import static com.healthmarketscience.jackcess.JetFormatTest.*; import static com.healthmarketscience.jackcess.DatabaseTest.*; import com.healthmarketscience.jackcess.complex.Attachment; import com.healthmarketscience.jackcess.complex.ComplexDataType; @@ -30,189 +31,198 @@ public class ComplexColumnTest extends TestCase public void testVersions() throws Exception { - Database db = DatabaseTest.openCopy(Database.FileFormat.V2007, new File("/data2/jackcess_test/complexDataTest.accdb")); - db.setTimeZone(TEST_TZ); - - Table t1 = db.getTable("Table1"); - Column col = t1.getColumn("append-memo-data"); - assertTrue(col.isAppendOnly()); - Column verCol = col.getVersionHistoryColumn(); - assertNotNull(verCol); - assertEquals(ComplexDataType.VERSION_HISTORY, - verCol.getComplexInfo().getType()); - - for(Map row : t1) { - String rowId = (String)row.get("id"); - ComplexValueForeignKey complexValueFk = - (ComplexValueForeignKey)verCol.getRowValue(row); - - String curValue = (String)col.getRowValue(row); + for(final TestDB testDB : TestDB.getSupportedForBasename(Basename.COMPLEX)) { - if(rowId.equals("row1")) { - checkVersions(1, complexValueFk, curValue); - } else if(rowId.equals("row2")) { - checkVersions(2, complexValueFk, curValue, - "row2-memo", new Date(1315876862334L)); - } else if(rowId.equals("row3")) { - checkVersions(3, complexValueFk, curValue, - "row3-memo-again", new Date(1315876965382L), - "row3-memo-revised", new Date(1315876953077L), - "row3-memo", new Date(1315876879126L)); - } else if(rowId.equals("row4")) { - checkVersions(4, complexValueFk, curValue, - "row4-memo", new Date(1315876945758L)); - } else { - assertTrue(false); + Database db = openCopy(testDB); + db.setTimeZone(TEST_TZ); + + Table t1 = db.getTable("Table1"); + Column col = t1.getColumn("append-memo-data"); + assertTrue(col.isAppendOnly()); + Column verCol = col.getVersionHistoryColumn(); + assertNotNull(verCol); + assertEquals(ComplexDataType.VERSION_HISTORY, + verCol.getComplexInfo().getType()); + + for(Map row : t1) { + String rowId = (String)row.get("id"); + ComplexValueForeignKey complexValueFk = + (ComplexValueForeignKey)verCol.getRowValue(row); + + String curValue = (String)col.getRowValue(row); + + if(rowId.equals("row1")) { + checkVersions(1, complexValueFk, curValue); + } else if(rowId.equals("row2")) { + checkVersions(2, complexValueFk, curValue, + "row2-memo", new Date(1315876862334L)); + } else if(rowId.equals("row3")) { + checkVersions(3, complexValueFk, curValue, + "row3-memo-again", new Date(1315876965382L), + "row3-memo-revised", new Date(1315876953077L), + "row3-memo", new Date(1315876879126L)); + } else if(rowId.equals("row4")) { + checkVersions(4, complexValueFk, curValue, + "row4-memo", new Date(1315876945758L)); + } else { + assertTrue(false); + } } - } - Object[] row8 = {"row8", Column.AUTO_NUMBER, "some-data", "row8-memo", - Column.AUTO_NUMBER, Column.AUTO_NUMBER}; - t1.addRow(row8); - - ComplexValueForeignKey row8ValFk = (ComplexValueForeignKey) - verCol.getRowValue(row8); - Date upTime = new Date(); - row8ValFk.addVersion("row8-memo", upTime); - checkVersions(8, row8ValFk, "row8-memo", - "row8-memo", upTime); - - Cursor cursor = Cursor.createCursor(t1); - assertTrue(cursor.findRow(t1.getColumn("id"), "row3")); - ComplexValueForeignKey row3ValFk = (ComplexValueForeignKey) - cursor.getCurrentRowValue(verCol); - cursor.setCurrentRowValue(col, "new-value"); - Version v = row3ValFk.addVersion("new-value", upTime); - checkVersions(3, row3ValFk, "new-value", - "new-value", upTime, - "row3-memo-again", new Date(1315876965382L), - "row3-memo-revised", new Date(1315876953077L), - "row3-memo", new Date(1315876879126L)); - - try { - v.update(); - fail("UnsupportedOperationException should have been thrown"); - } catch(UnsupportedOperationException expected) { - // success - } + Object[] row8 = {"row8", Column.AUTO_NUMBER, "some-data", "row8-memo", + Column.AUTO_NUMBER, Column.AUTO_NUMBER}; + t1.addRow(row8); + + ComplexValueForeignKey row8ValFk = (ComplexValueForeignKey) + verCol.getRowValue(row8); + Date upTime = new Date(); + row8ValFk.addVersion("row8-memo", upTime); + checkVersions(8, row8ValFk, "row8-memo", + "row8-memo", upTime); + + Cursor cursor = Cursor.createCursor(t1); + assertTrue(cursor.findRow(t1.getColumn("id"), "row3")); + ComplexValueForeignKey row3ValFk = (ComplexValueForeignKey) + cursor.getCurrentRowValue(verCol); + cursor.setCurrentRowValue(col, "new-value"); + Version v = row3ValFk.addVersion("new-value", upTime); + checkVersions(3, row3ValFk, "new-value", + "new-value", upTime, + "row3-memo-again", new Date(1315876965382L), + "row3-memo-revised", new Date(1315876953077L), + "row3-memo", new Date(1315876879126L)); + + try { + v.update(); + fail("UnsupportedOperationException should have been thrown"); + } catch(UnsupportedOperationException expected) { + // success + } - db.close(); + db.close(); + } } public void testAttachments() throws Exception { - Database db = DatabaseTest.openCopy(Database.FileFormat.V2007, new File("/data2/jackcess_test/complexDataTest.accdb")); - db.setTimeZone(TEST_TZ); - - Table t1 = db.getTable("Table1"); - Column col = t1.getColumn("attach-data"); - assertEquals(ComplexDataType.ATTACHMENT, - col.getComplexInfo().getType()); - - for(Map row : t1) { - String rowId = (String)row.get("id"); - ComplexValueForeignKey complexValueFk = - (ComplexValueForeignKey)col.getRowValue(row); - - if(rowId.equals("row1")) { - checkAttachments(1, complexValueFk); - } else if(rowId.equals("row2")) { - checkAttachments(2, complexValueFk, "test_data.txt", "test_data2.txt"); - } else if(rowId.equals("row3")) { - checkAttachments(3, complexValueFk); - } else if(rowId.equals("row4")) { - checkAttachments(4, complexValueFk, "test_data2.txt"); - } else { - assertTrue(false); + for(final TestDB testDB : TestDB.getSupportedForBasename(Basename.COMPLEX)) { + + Database db = openCopy(testDB); + db.setTimeZone(TEST_TZ); + + Table t1 = db.getTable("Table1"); + Column col = t1.getColumn("attach-data"); + assertEquals(ComplexDataType.ATTACHMENT, + col.getComplexInfo().getType()); + + for(Map row : t1) { + String rowId = (String)row.get("id"); + ComplexValueForeignKey complexValueFk = + (ComplexValueForeignKey)col.getRowValue(row); + + if(rowId.equals("row1")) { + checkAttachments(1, complexValueFk); + } else if(rowId.equals("row2")) { + checkAttachments(2, complexValueFk, "test_data.txt", "test_data2.txt"); + } else if(rowId.equals("row3")) { + checkAttachments(3, complexValueFk); + } else if(rowId.equals("row4")) { + checkAttachments(4, complexValueFk, "test_data2.txt"); + } else { + assertTrue(false); + } } - } - Object[] row8 = {"row8", Column.AUTO_NUMBER, "some-data", "row8-memo", - Column.AUTO_NUMBER, Column.AUTO_NUMBER}; - t1.addRow(row8); - - ComplexValueForeignKey row8ValFk = (ComplexValueForeignKey) - col.getRowValue(row8); - row8ValFk.addAttachment(null, "test_data.txt", "txt", - getFileBytes("test_data.txt"), null, null); - checkAttachments(8, row8ValFk, "test_data.txt"); - - Cursor cursor = Cursor.createCursor(t1); - assertTrue(cursor.findRow(t1.getColumn("id"), "row4")); - ComplexValueForeignKey row4ValFk = (ComplexValueForeignKey) - cursor.getCurrentRowValue(col); - Attachment a = row4ValFk.addAttachment(null, "test_data.txt", "txt", - getFileBytes("test_data.txt"), null, - null); - checkAttachments(4, row4ValFk, "test_data2.txt", "test_data.txt"); - - a.setFileType("xml"); - a.setFileName("some_data.xml"); - byte[] newBytes = "this is not xml".getBytes("US-ASCII"); - a.setFileData(newBytes); - a.update(); - - Attachment updated = row4ValFk.getAttachments().get(1); - assertNotSame(updated, a); - assertEquals("xml", updated.getFileType()); - assertEquals("some_data.xml", updated.getFileName()); - assertTrue(Arrays.equals(newBytes, updated.getFileData())); + Object[] row8 = {"row8", Column.AUTO_NUMBER, "some-data", "row8-memo", + Column.AUTO_NUMBER, Column.AUTO_NUMBER}; + t1.addRow(row8); + + ComplexValueForeignKey row8ValFk = (ComplexValueForeignKey) + col.getRowValue(row8); + row8ValFk.addAttachment(null, "test_data.txt", "txt", + getFileBytes("test_data.txt"), null, null); + checkAttachments(8, row8ValFk, "test_data.txt"); + + Cursor cursor = Cursor.createCursor(t1); + assertTrue(cursor.findRow(t1.getColumn("id"), "row4")); + ComplexValueForeignKey row4ValFk = (ComplexValueForeignKey) + cursor.getCurrentRowValue(col); + Attachment a = row4ValFk.addAttachment(null, "test_data.txt", "txt", + getFileBytes("test_data.txt"), null, + null); + checkAttachments(4, row4ValFk, "test_data2.txt", "test_data.txt"); + + a.setFileType("xml"); + a.setFileName("some_data.xml"); + byte[] newBytes = "this is not xml".getBytes("US-ASCII"); + a.setFileData(newBytes); + a.update(); + + Attachment updated = row4ValFk.getAttachments().get(1); + assertNotSame(updated, a); + assertEquals("xml", updated.getFileType()); + assertEquals("some_data.xml", updated.getFileName()); + assertTrue(Arrays.equals(newBytes, updated.getFileData())); - db.close(); + db.close(); + } } public void testMultiValues() throws Exception { - Database db = DatabaseTest.openCopy(Database.FileFormat.V2007, new File("/data2/jackcess_test/complexDataTest.accdb")); - db.setTimeZone(TEST_TZ); - - Table t1 = db.getTable("Table1"); - Column col = t1.getColumn("multi-value-data"); - assertEquals(ComplexDataType.MULTI_VALUE, - col.getComplexInfo().getType()); - - for(Map row : t1) { - String rowId = (String)row.get("id"); - ComplexValueForeignKey complexValueFk = - (ComplexValueForeignKey)col.getRowValue(row); - - if(rowId.equals("row1")) { - checkMultiValues(1, complexValueFk); - } else if(rowId.equals("row2")) { - checkMultiValues(2, complexValueFk, "value1", "value4"); - } else if(rowId.equals("row3")) { - checkMultiValues(3, complexValueFk, - "value1", "value2", "value3", "value4"); - } else if(rowId.equals("row4")) { - checkMultiValues(4, complexValueFk); - } else { - assertTrue(false); - } - } - - Object[] row8 = {"row8", Column.AUTO_NUMBER, "some-data", "row8-memo", - Column.AUTO_NUMBER, Column.AUTO_NUMBER}; - t1.addRow(row8); - - ComplexValueForeignKey row8ValFk = (ComplexValueForeignKey) - col.getRowValue(row8); - row8ValFk.addMultiValue("value1"); - row8ValFk.addMultiValue("value2"); - checkMultiValues(8, row8ValFk, "value1", "value2"); - - Cursor cursor = Cursor.createCursor(t1); - assertTrue(cursor.findRow(t1.getColumn("id"), "row2")); - ComplexValueForeignKey row2ValFk = (ComplexValueForeignKey) - cursor.getCurrentRowValue(col); - SingleValue v = row2ValFk.addMultiValue("value2"); - row2ValFk.addMultiValue("value3"); - checkMultiValues(2, row2ValFk, "value1", "value4", "value2", "value3"); - - v.set("value5"); - v.update(); - checkMultiValues(2, row2ValFk, "value1", "value4", "value5", "value3"); + for(final TestDB testDB : TestDB.getSupportedForBasename(Basename.COMPLEX)) { + + Database db = openCopy(testDB); + db.setTimeZone(TEST_TZ); + + Table t1 = db.getTable("Table1"); + Column col = t1.getColumn("multi-value-data"); + assertEquals(ComplexDataType.MULTI_VALUE, + col.getComplexInfo().getType()); + + for(Map row : t1) { + String rowId = (String)row.get("id"); + ComplexValueForeignKey complexValueFk = + (ComplexValueForeignKey)col.getRowValue(row); + + if(rowId.equals("row1")) { + checkMultiValues(1, complexValueFk); + } else if(rowId.equals("row2")) { + checkMultiValues(2, complexValueFk, "value1", "value4"); + } else if(rowId.equals("row3")) { + checkMultiValues(3, complexValueFk, + "value1", "value2", "value3", "value4"); + } else if(rowId.equals("row4")) { + checkMultiValues(4, complexValueFk); + } else { + assertTrue(false); + } + } + + Object[] row8 = {"row8", Column.AUTO_NUMBER, "some-data", "row8-memo", + Column.AUTO_NUMBER, Column.AUTO_NUMBER}; + t1.addRow(row8); + + ComplexValueForeignKey row8ValFk = (ComplexValueForeignKey) + col.getRowValue(row8); + row8ValFk.addMultiValue("value1"); + row8ValFk.addMultiValue("value2"); + checkMultiValues(8, row8ValFk, "value1", "value2"); + + Cursor cursor = Cursor.createCursor(t1); + assertTrue(cursor.findRow(t1.getColumn("id"), "row2")); + ComplexValueForeignKey row2ValFk = (ComplexValueForeignKey) + cursor.getCurrentRowValue(col); + SingleValue v = row2ValFk.addMultiValue("value2"); + row2ValFk.addMultiValue("value3"); + checkMultiValues(2, row2ValFk, "value1", "value4", "value2", "value3"); + + v.set("value5"); + v.update(); + checkMultiValues(2, row2ValFk, "value1", "value4", "value5", "value3"); - db.close(); + db.close(); + } } private static void checkVersions( diff --git a/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java b/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java index e60bf96..22dff2d 100644 --- a/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java +++ b/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java @@ -41,7 +41,8 @@ public class JetFormatTest extends TestCase { TEST2("test2"), INDEX_CODES("testIndexCodes"), INDEX_PROPERTIES("testIndexProperties"), - PROMOTION("testPromotion"); + PROMOTION("testPromotion"), + COMPLEX("complexDataTest"); private final String _basename; -- cgit v1.2.3