aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Ahlborn <jtahlborn@yahoo.com>2014-09-22 02:52:37 +0000
committerJames Ahlborn <jtahlborn@yahoo.com>2014-09-22 02:52:37 +0000
commit8249b36e989a4151061741d4be70d957ef5ed864 (patch)
treec02c76e9aae9bf181c0a82a0d831f2e7d15c2ce4
parent94148f092f4b65b3abde48a38f80076c6d4f9f78 (diff)
downloadjackcess-8249b36e989a4151061741d4be70d957ef5ed864.tar.gz
jackcess-8249b36e989a4151061741d4be70d957ef5ed864.zip
add unit test for iteration early exit fix
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@882 f203690c-595d-4dc9-a70b-905162fa7fd2
-rw-r--r--src/main/java/com/healthmarketscience/jackcess/impl/ColumnImpl.java8
-rw-r--r--src/test/java/com/healthmarketscience/jackcess/CursorTest.java58
2 files changed, 60 insertions, 6 deletions
diff --git a/src/main/java/com/healthmarketscience/jackcess/impl/ColumnImpl.java b/src/main/java/com/healthmarketscience/jackcess/impl/ColumnImpl.java
index 0fbe7c2..5e3fe88 100644
--- a/src/main/java/com/healthmarketscience/jackcess/impl/ColumnImpl.java
+++ b/src/main/java/com/healthmarketscience/jackcess/impl/ColumnImpl.java
@@ -223,9 +223,6 @@ public class ColumnImpl implements Column, Comparable<ColumnImpl> {
/**
* Read a column definition in from a buffer
- * @param table owning table
- * @param buffer Buffer containing column definition
- * @param offset Offset in the buffer at which the column definition starts
* @usage _advanced_method_
*/
ColumnImpl(InitArgs args)
@@ -1538,12 +1535,12 @@ public class ColumnImpl implements Column, Comparable<ColumnImpl> {
* understanding the data. Useful for wrapping unparseable data for
* re-writing.
*/
- static RawData rawDataWrapper(byte[] bytes) {
+ public static RawData rawDataWrapper(byte[] bytes) {
return new RawData(bytes);
}
/**
- * Returs {@code true} if the given value is "raw" column data,
+ * Returns {@code true} if the given value is "raw" column data,
* {@code false} otherwise.
* @usage _advanced_method_
*/
@@ -1554,7 +1551,6 @@ public class ColumnImpl implements Column, Comparable<ColumnImpl> {
/**
* Writes the column definitions into a table definition buffer.
* @param buffer Buffer to write to
- * @param columns List of Columns to write definitions for
*/
protected static void writeDefinitions(TableCreator creator, ByteBuffer buffer)
throws IOException
diff --git a/src/test/java/com/healthmarketscience/jackcess/CursorTest.java b/src/test/java/com/healthmarketscience/jackcess/CursorTest.java
index d8beff3..caf048a 100644
--- a/src/test/java/com/healthmarketscience/jackcess/CursorTest.java
+++ b/src/test/java/com/healthmarketscience/jackcess/CursorTest.java
@@ -38,6 +38,7 @@ import java.util.TreeSet;
import static com.healthmarketscience.jackcess.Database.*;
import static com.healthmarketscience.jackcess.DatabaseTest.*;
+import com.healthmarketscience.jackcess.impl.ColumnImpl;
import com.healthmarketscience.jackcess.impl.JetFormatTest;
import static com.healthmarketscience.jackcess.impl.JetFormatTest.*;
import com.healthmarketscience.jackcess.impl.RowIdImpl;
@@ -1285,5 +1286,62 @@ public class CursorTest extends TestCase {
assertEquals(id - 1, cursor.getCurrentRow().get("id"));
}
+ public void testIterationEarlyExit() throws Exception {
+ for (final FileFormat fileFormat : JetFormatTest.SUPPORTED_FILEFORMATS) {
+
+ Database db = create(fileFormat);
+
+ Table table = new TableBuilder("test")
+ .addColumn(new ColumnBuilder("id", DataType.LONG))
+ .addColumn(new ColumnBuilder("value", DataType.TEXT))
+ .addColumn(new ColumnBuilder("memo", DataType.MEMO))
+ .addIndex(new IndexBuilder("value_idx")
+ .addColumns("value"))
+ .toTable(db);
+
+ for(int i = 0; i < 20; ++i) {
+ Object memo = "memo-" + i;
+ table.addRow(i, "val-" + (i/2), memo);
+ }
+
+ // generate an "invalid" memo
+ byte[] b = new byte[12];
+ b[3] = (byte)0xC0;
+ table.addRow(20, "val-9", ColumnImpl.rawDataWrapper(b));
+
+ IndexCursor cursor = CursorBuilder.createCursor(
+ table.getIndex("value_idx"));
+
+ try {
+ cursor.newIterable()
+ .addMatchPattern("value", "val-9")
+ .addMatchPattern("memo", "anything")
+ .iterator().hasNext();
+ fail("RuntimeIOException should have been thrown");
+ } catch(RuntimeIOException ignored) {
+ // success
+ }
+
+ List<Row> rows = new ArrayList<Row>();
+ for (Row row : cursor.newIterable()
+ .addMatchPattern("value", "val-5")
+ .addMatchPattern("memo", "memo-11")) {
+ rows.add(row);
+ }
+
+ assertEquals(rows, createExpectedTable(
+ createExpectedRow("id", 11,
+ "value", "val-5",
+ "memo", "memo-11")));
+
+ assertFalse(cursor.newIterable()
+ .addMatchPattern("value", "val-31")
+ .addMatchPattern("memo", "anything")
+ .iterator().hasNext());
+
+ db.close();
+ }
+ }
+
}