From 70497648605fd00bed3a62a41605a9aeb410662d Mon Sep 17 00:00:00 2001 From: James Ahlborn Date: Wed, 11 Jun 2014 22:23:04 +0000 Subject: Add Cursor.findRow(RowId) for moving to a specific Table row using only the RowId git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@864 f203690c-595d-4dc9-a70b-905162fa7fd2 --- .../healthmarketscience/jackcess/CursorTest.java | 70 ++++++++++++++++++++++ 1 file changed, 70 insertions(+) (limited to 'src/test/java') diff --git a/src/test/java/com/healthmarketscience/jackcess/CursorTest.java b/src/test/java/com/healthmarketscience/jackcess/CursorTest.java index bafee57..cf55e2b 100644 --- a/src/test/java/com/healthmarketscience/jackcess/CursorTest.java +++ b/src/test/java/com/healthmarketscience/jackcess/CursorTest.java @@ -1205,5 +1205,75 @@ public class CursorTest extends TestCase { } } + public void testFindByRowId() throws Exception { + for (final FileFormat fileFormat : JetFormatTest.SUPPORTED_FILEFORMATS) { + Database db = createTestTable(fileFormat); + + Table table = db.getTable("test"); + Cursor cursor = CursorBuilder.createCursor(table); + doTestFindByRowId(cursor); + db.close(); + } + } + + public void testFindByRowIdIndex() throws Exception { + for (final TestDB indexCursorDB : INDEX_CURSOR_DBS) { + Database db = createTestIndexTable(indexCursorDB); + + Table table = db.getTable("test"); + Index idx = table.getIndexes().get(0); + + assertTable(createUnorderedTestTableData(), table); + + Cursor cursor = CursorBuilder.createCursor(idx); + doTestFindByRowId(cursor); + + db.close(); + } + } + + private static void doTestFindByRowId(Cursor cursor) + throws Exception + { + for(int i = 0; i < 3; ++i) { + cursor.moveToNextRow(); + } + + Row r1 = cursor.getCurrentRow(); + + for(int i = 0; i < 3; ++i) { + cursor.moveToNextRow(); + } + + Row r2 = cursor.getCurrentRow(); + + doTestFindByRowId(cursor, r1, 2); + + doTestFindByRowId(cursor, r2, 5); + } + + private static void doTestFindByRowId(Cursor cursor, Row row, int id) + throws Exception + { + cursor.reset(); + assertTrue(cursor.findRow(row.getId())); + Row rFound = cursor.getCurrentRow(); + assertEquals(id, rFound.get("id")); + assertEquals(row, rFound); + Cursor.Savepoint save = cursor.getSavepoint(); + + assertTrue(cursor.moveToNextRow()); + assertEquals(id + 1, cursor.getCurrentRow().get("id")); + + cursor.restoreSavepoint(save); + + assertTrue(cursor.moveToPreviousRow()); + assertEquals(id - 1, cursor.getCurrentRow().get("id")); + + assertFalse(cursor.findRow(RowIdImpl.FIRST_ROW_ID)); + + assertEquals(id - 1, cursor.getCurrentRow().get("id")); + } + } -- cgit v1.2.3