summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/CursorTest.java60
1 files changed, 53 insertions, 7 deletions
diff --git a/test/src/java/com/healthmarketscience/jackcess/CursorTest.java b/test/src/java/com/healthmarketscience/jackcess/CursorTest.java
index c87b29e..f6b829d 100644
--- a/test/src/java/com/healthmarketscience/jackcess/CursorTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/CursorTest.java
@@ -142,6 +142,15 @@ public class CursorTest extends TestCase {
assertEquals(3, cursor.moveNextRows(3));
assertFalse(cursor.isBeforeFirst());
assertFalse(cursor.isAfterLast());
+
+ Map<String,Object> expectedRow = cursor.getCurrentRow();
+ Cursor.Savepoint savepoint = cursor.getSavepoint();
+ assertEquals(2, cursor.movePreviousRows(2));
+ assertEquals(2, cursor.moveNextRows(2));
+ assertTrue(cursor.moveToNextRow());
+ assertTrue(cursor.moveToPreviousRow());
+ assertEquals(expectedRow, cursor.getCurrentRow());
+
while(cursor.moveToNextRow()) {
foundRows.add(cursor.getCurrentRow());
}
@@ -150,6 +159,17 @@ public class CursorTest extends TestCase {
assertTrue(cursor.isAfterLast());
assertEquals(0, cursor.moveNextRows(3));
+
+ cursor.beforeFirst();
+ assertTrue(cursor.isBeforeFirst());
+ assertFalse(cursor.isAfterLast());
+
+ cursor.afterLast();
+ assertFalse(cursor.isBeforeFirst());
+ assertTrue(cursor.isAfterLast());
+
+ cursor.restoreSavepoint(savepoint);
+ assertEquals(expectedRow, cursor.getCurrentRow());
}
public void testSearch() throws Exception {
@@ -157,14 +177,14 @@ public class CursorTest extends TestCase {
Table table = db.getTable("test");
Cursor cursor = Cursor.createCursor(table);
- doTestSearch(table, cursor);
+ doTestSearch(table, cursor, null);
db.close();
}
- private void doTestSearch(Table table, Cursor cursor) throws Exception {
- List<Map<String,Object>> expectedRows = createTestTableData();
-
+ private void doTestSearch(Table table, Cursor cursor, Index index)
+ throws Exception
+ {
assertTrue(cursor.findRow(table.getColumn("id"), 3));
assertEquals(createExpectedRow("id", 3,
"value", "data" + 3),
@@ -178,16 +198,42 @@ public class CursorTest extends TestCase {
cursor.getCurrentRow());
assertFalse(cursor.findRow(createExpectedRow(
- "id", 13,
- "value", "data" + 8)));
+ "id", 8,
+ "value", "data" + 13)));
+ assertFalse(cursor.findRow(table.getColumn("id"), 13));
assertEquals(createExpectedRow("id", 6,
"value", "data" + 6),
cursor.getCurrentRow());
+
+ assertTrue(cursor.findRow(createExpectedRow(
+ "value", "data" + 7)));
+ assertEquals(createExpectedRow("id", 7,
+ "value", "data" + 7),
+ cursor.getCurrentRow());
+
+ assertTrue(cursor.findRow(table.getColumn("value"), "data" + 2));
+ assertEquals(createExpectedRow("id", 2,
+ "value", "data" + 2),
+ cursor.getCurrentRow());
assertEquals("data" + 9,
Cursor.findValue(table,
table.getColumn("value"),
table.getColumn("id"), 9));
+ assertEquals(createExpectedRow("id", 9,
+ "value", "data" + 9),
+ Cursor.findRow(table,
+ createExpectedRow("id", 9)));
+ if(index != null) {
+ assertEquals("data" + 9,
+ Cursor.findValue(table, index,
+ table.getColumn("value"),
+ table.getColumn("id"), 9));
+ assertEquals(createExpectedRow("id", 9,
+ "value", "data" + 9),
+ Cursor.findRow(table, index,
+ createExpectedRow("id", 9)));
+ }
}
public void testReverse() throws Exception {
@@ -343,7 +389,7 @@ public class CursorTest extends TestCase {
Table table = db.getTable("test");
Index idx = table.getIndexes().get(0);
Cursor cursor = Cursor.createIndexCursor(table, idx);
- doTestSearch(table, cursor);
+ doTestSearch(table, cursor, idx);
db.close();
}