summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java13
-rw-r--r--src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java14
-rw-r--r--test/data/V2007/unsupportedFieldsTestV2007.accdbbin0 -> 622592 bytes
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java60
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java38
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java3
6 files changed, 118 insertions, 10 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java b/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java
index d236afe..ba31a3b 100644
--- a/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java
+++ b/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java
@@ -167,6 +167,16 @@ public class ComplexValueForeignKey extends Number
return (List<SingleValue>)getValues();
}
+ @SuppressWarnings("unchecked")
+ public List<UnsupportedValue> getUnsupportedValues()
+ throws IOException
+ {
+ if(getComplexType() != ComplexDataType.UNSUPPORTED) {
+ throw new UnsupportedOperationException();
+ }
+ return (List<UnsupportedValue>)getValues();
+ }
+
public void reset() {
// discard any cached values
_values = null;
@@ -246,7 +256,8 @@ public class ComplexValueForeignKey extends Number
return value;
}
- public UnsupportedValue addUnsupportedValue(Map<String,Object> values)
+ public UnsupportedValue addUnsupportedValue(
+ Map<String,? extends Object> values)
throws IOException
{
reset();
diff --git a/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java b/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java
index 7275511..27ee434 100644
--- a/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java
+++ b/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java
@@ -59,8 +59,10 @@ public class UnsupportedColumnInfo extends ComplexColumnInfo<UnsupportedValue>
{
int id = (Integer)getPrimaryKeyColumn().getRowValue(rawValue);
- Map<String,Object> values = new LinkedHashMap<String,Object>(rawValue);
- values.remove(getPrimaryKeyColumn().getName());
+ Map<String,Object> values = new LinkedHashMap<String,Object>();
+ for(Column col : getValueColumns()) {
+ col.setRowValue(values, col.getRowValue(rawValue));
+ }
return new UnsupportedValueImpl(id, complexValueFk, values);
}
@@ -77,13 +79,15 @@ public class UnsupportedColumnInfo extends ComplexColumnInfo<UnsupportedValue>
return row;
}
- public static UnsupportedValue newValue(Map<String,Object> values) {
+ public static UnsupportedValue newValue(Map<String,? extends Object> values) {
return newValue(INVALID_COMPLEX_VALUE_ID, values);
}
public static UnsupportedValue newValue(
- ComplexValueForeignKey complexValueFk, Map<String,Object> values) {
- return new UnsupportedValueImpl(INVALID_ID, complexValueFk, values);
+ ComplexValueForeignKey complexValueFk,
+ Map<String,? extends Object> values) {
+ return new UnsupportedValueImpl(INVALID_ID, complexValueFk,
+ new LinkedHashMap<String,Object>(values));
}
private static class UnsupportedValueImpl extends ComplexValueImpl
diff --git a/test/data/V2007/unsupportedFieldsTestV2007.accdb b/test/data/V2007/unsupportedFieldsTestV2007.accdb
new file mode 100644
index 0000000..c7b1dea
--- /dev/null
+++ b/test/data/V2007/unsupportedFieldsTestV2007.accdb
Binary files differ
diff --git a/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java b/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java
index f9f4445..09ec547 100644
--- a/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/ComplexColumnTest.java
@@ -24,12 +24,13 @@ 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 static com.healthmarketscience.jackcess.JetFormatTest.*;
import com.healthmarketscience.jackcess.complex.Attachment;
import com.healthmarketscience.jackcess.complex.ComplexDataType;
import com.healthmarketscience.jackcess.complex.ComplexValueForeignKey;
import com.healthmarketscience.jackcess.complex.SingleValue;
+import com.healthmarketscience.jackcess.complex.UnsupportedValue;
import com.healthmarketscience.jackcess.complex.Version;
import junit.framework.TestCase;
@@ -155,7 +156,6 @@ public class ComplexColumnTest extends TestCase
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");
@@ -231,7 +231,6 @@ public class ComplexColumnTest extends TestCase
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");
@@ -298,6 +297,38 @@ public class ComplexColumnTest extends TestCase
}
}
+ public void testUnsupported() throws Exception
+ {
+ for(final TestDB testDB : TestDB.getSupportedForBasename(Basename.UNSUPPORTED)) {
+
+ Database db = openCopy(testDB);
+
+ Table t1 = db.getTable("Test");
+ Column col = t1.getColumn("UnknownComplex");
+ assertEquals(ComplexDataType.UNSUPPORTED,
+ col.getComplexInfo().getType());
+
+ for(Map<String,Object> row : t1) {
+ Integer rowId = (Integer)row.get("ID");
+ ComplexValueForeignKey complexValueFk =
+ (ComplexValueForeignKey)col.getRowValue(row);
+
+ if(rowId.equals(1)) {
+ checkUnsupportedValues(1, complexValueFk,
+ "RawData: FF FE 62 61 7A");
+ } else if(rowId.equals(2)) {
+ checkUnsupportedValues(2, complexValueFk, "RawData: FF FE 66 6F 6F", "RawData: FF FE 62 61 7A");
+ } else if(rowId.equals(3)) {
+ checkUnsupportedValues(3, complexValueFk);
+ } else {
+ assertTrue(false);
+ }
+ }
+
+ db.close();
+ }
+ }
+
private static void checkVersions(
int cValId, ComplexValueForeignKey complexValueFk,
String curValue, Object... versionInfos)
@@ -365,6 +396,29 @@ public class ComplexColumnTest extends TestCase
}
}
+ private static void checkUnsupportedValues(
+ int cValId, ComplexValueForeignKey complexValueFk,
+ String... expectedValues)
+ throws Exception
+ {
+ assertEquals(cValId, complexValueFk.get());
+
+ List<UnsupportedValue> values = complexValueFk.getUnsupportedValues();
+ if(expectedValues.length == 0) {
+ assertTrue(values.isEmpty());
+ } else {
+ assertEquals(expectedValues.length, values.size());
+ for(int i = 0; i < expectedValues.length; ++i) {
+ String value = expectedValues[i];
+ UnsupportedValue v = values.get(i);
+ assertEquals(1, v.getValues().size());
+ Object rv = v.get("Value");
+ assertTrue(Column.isRawData(rv));
+ assertEquals(value, rv.toString());
+ }
+ }
+ }
+
private static byte[] getFileBytes(String fname) throws Exception
{
if("test_data.txt".equals(fname)) {
diff --git a/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java b/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java
index 1f118ca..2c70a19 100644
--- a/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java
@@ -1157,6 +1157,44 @@ public class DatabaseTest extends TestCase {
db.close();
}
}
+
+ public void testUnsupportedColumns() throws Exception {
+ for (final TestDB testDB : TestDB.getSupportedForBasename(Basename.UNSUPPORTED)) {
+
+ Database db = open(testDB);
+ Table t = db.getTable("Test");
+ Column varCol = t.getColumn("UnknownVar");
+ assertEquals(DataType.UNSUPPORTED_VARLEN, varCol.getType());
+ Column fixCol = t.getColumn("UnknownFix");
+ assertEquals(DataType.UNSUPPORTED_FIXEDLEN, fixCol.getType());
+
+ List<String> varVals = Arrays.asList(
+ "RawData: FF FE 73 6F 6D 65 64 61 74 61",
+ "RawData: FF FE 6F 74 68 65 72 20 64 61 74 61",
+ null);
+ List<String> fixVals = Arrays.asList("RawData: 37 00 00 00",
+ "RawData: F3 FF FF FF",
+ "RawData: 02 00 00 00");
+
+ int idx = 0;
+ for(Map<String,Object> row : t) {
+ checkRawValue(varVals.get(idx), varCol.getRowValue(row));
+ checkRawValue(fixVals.get(idx), fixCol.getRowValue(row));
+ ++idx;
+ }
+ db.close();
+ }
+ }
+
+ private void checkRawValue(String expected, Object val)
+ {
+ if(expected != null) {
+ assertTrue(Column.isRawData(val));
+ assertEquals(expected, val.toString());
+ } else {
+ assertNull(val);
+ }
+ }
static Object[] createTestRow(String col1Val) {
return new Object[] {col1Val, "R", "McCune", 1234, (byte) 0xad, 555.66d,
diff --git a/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java b/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java
index 22dff2d..ec11dce 100644
--- a/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/JetFormatTest.java
@@ -42,7 +42,8 @@ public class JetFormatTest extends TestCase {
INDEX_CODES("testIndexCodes"),
INDEX_PROPERTIES("testIndexProperties"),
PROMOTION("testPromotion"),
- COMPLEX("complexDataTest");
+ COMPLEX("complexDataTest"),
+ UNSUPPORTED("unsupportedFieldsTest");
private final String _basename;