summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Ahlborn <jtahlborn@yahoo.com>2008-04-17 02:09:16 +0000
committerJames Ahlborn <jtahlborn@yahoo.com>2008-04-17 02:09:16 +0000
commit6f9ccc356d24f21bff5675a5bc7bd228fc9f32a4 (patch)
treed2642b73e9558de51dc028c48262a38891ca12ea
parent6845efc53cc544de8466c42c9f43364245889f0b (diff)
downloadjackcess-6f9ccc356d24f21bff5675a5bc7bd228fc9f32a4.tar.gz
jackcess-6f9ccc356d24f21bff5675a5bc7bd228fc9f32a4.zip
more big index tests; minor bug fix
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@334 f203690c-595d-4dc9-a70b-905162fa7fd2
-rw-r--r--src/java/com/healthmarketscience/jackcess/IndexPageCache.java21
-rw-r--r--test/data/bigIndexTest.mdbbin0 -> 114688 bytes
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/BigIndexTest.java77
3 files changed, 68 insertions, 30 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/IndexPageCache.java b/src/java/com/healthmarketscience/jackcess/IndexPageCache.java
index f8046d4..0c0d890 100644
--- a/src/java/com/healthmarketscience/jackcess/IndexPageCache.java
+++ b/src/java/com/healthmarketscience/jackcess/IndexPageCache.java
@@ -610,6 +610,7 @@ public class IndexPageCache
// clear the root page
rootMain._leaf = false;
+ rootMain._childTailPageNumber = INVALID_INDEX_PAGE_NUMBER;
rootExtra._entries = new ArrayList<Entry>();
rootExtra._entryPrefix = EMPTY_PREFIX;
rootExtra._totalEntrySize = 0;
@@ -869,6 +870,7 @@ public class IndexPageCache
throw new IllegalStateException("Prev page " + prevMain +
" does not ref " + dpMain);
}
+ validatePeerStatus(dpMain, prevMain);
}
DataPageMain nextMain = _dataPages.get(dpMain._nextPageNumber);
@@ -877,6 +879,25 @@ public class IndexPageCache
throw new IllegalStateException("Next page " + nextMain +
" does not ref " + dpMain);
}
+ validatePeerStatus(dpMain, nextMain);
+ }
+ }
+
+ private void validatePeerStatus(DataPageMain dpMain, DataPageMain peerMain)
+ throws IOException
+ {
+ if(dpMain._leaf != peerMain._leaf) {
+ throw new IllegalStateException("Mismatched peer status " +
+ dpMain._leaf + " " + peerMain._leaf);
+ }
+ if(!dpMain._leaf) {
+ if((dpMain._parentPageNumber != null) &&
+ (peerMain._parentPageNumber != null) &&
+ ((int)dpMain._parentPageNumber != (int)peerMain._parentPageNumber)) {
+ throw new IllegalStateException("Mismatched node parents " +
+ dpMain._parentPageNumber + " " +
+ peerMain._parentPageNumber);
+ }
}
}
diff --git a/test/data/bigIndexTest.mdb b/test/data/bigIndexTest.mdb
new file mode 100644
index 0000000..abbb14d
--- /dev/null
+++ b/test/data/bigIndexTest.mdb
Binary files differ
diff --git a/test/src/java/com/healthmarketscience/jackcess/BigIndexTest.java b/test/src/java/com/healthmarketscience/jackcess/BigIndexTest.java
index fdca807..73f1a9c 100644
--- a/test/src/java/com/healthmarketscience/jackcess/BigIndexTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/BigIndexTest.java
@@ -65,60 +65,75 @@ public class BigIndexTest extends TestCase {
public void testComplexIndex() throws Exception
{
// this file has an index with "compressed" entries and node pages
- File origFile = new File("test/data/compIndexTest.mdb");
- Database db = open(origFile);
+ Database db = open(new File("test/data/compIndexTest.mdb"));
Table t = db.getTable("Table1");
Index index = t.getIndex("CD_AGENTE");
assertFalse(index.isInitialized());
assertEquals(512, countRows(t));
assertEquals(512, index.getEntryCount());
db.close();
+ }
+
+ public void testBigIndex() throws Exception
+ {
+ // this file has an index with "compressed" entries and node pages
+ File origFile = new File("test/data/bigIndexTest.mdb");
+ Database db = open(origFile);
+ Table t = db.getTable("Table1");
+ Index index = t.getIndex("col1");
+ assertFalse(index.isInitialized());
+ assertEquals(0, countRows(t));
+ assertEquals(0, index.getEntryCount());
+ db.close();
DatabaseTest._autoSync = false;
try {
+
+ String extraText = " some random text to fill out the index and make it fill up pages";
// copy to temp file and attempt to edit
db = openCopy(origFile);
t = db.getTable("Table1");
- index = t.getIndex("CD_AGENTE");
+ index = t.getIndex("col1");
System.out.println("BigIndexTest: Index type: " + index.getClass());
// add 10,000 (pseudo) random entries to the table
Random rand = new Random(13L);
- for(int i = 0; i < 10000; ++i) {
- Integer nextInt = rand.nextInt();
+ for(int i = 0; i < 2000; ++i) {
+ int nextInt = rand.nextInt(Integer.MAX_VALUE);
+ String nextVal = "" + nextInt + extraText;
if(((i + 1) % 3333) == 0) {
- nextInt = null;
+ nextVal = null;
}
- t.addRow(nextInt,
- "this is some row data " + nextInt,
- "this is some more row data " + nextInt);
+ t.addRow(nextVal, "this is some row data " + nextInt);
}
((BigIndex)index).validate();
db.flush();
t = db.getTable("Table1");
- index = t.getIndex("CD_AGENTE");
+ index = t.getIndex("col1");
// make sure all entries are there and correctly ordered
- int lastValue = Integer.MAX_VALUE;
+ String lastValue = " ";
int rowCount = 0;
- List<Integer> firstTwo = new ArrayList<Integer>();
+ List<String> firstTwo = new ArrayList<String>();
for(Map<String,Object> row : Cursor.createIndexCursor(t, index)) {
- Integer tmpVal = (Integer)row.get("CD_AGENTE");
- int val = ((tmpVal != null) ? (int)tmpVal : Integer.MIN_VALUE);
+ String val = (String)row.get("col1");
+ if(val == null) {
+ val = "ZZZZZZZ";
+ }
assertTrue("" + val + " <= " + lastValue + " " + rowCount,
- val <= lastValue);
+ lastValue.compareTo(val) <= 0);
if(firstTwo.size() < 2) {
- firstTwo.add(tmpVal);
+ firstTwo.add(val);
}
lastValue = val;
++rowCount;
}
- assertEquals(10512, rowCount);
+ assertEquals(2000, rowCount);
((BigIndex)index).validate();
@@ -132,9 +147,9 @@ public class BigIndexTest extends TestCase {
((BigIndex)index).validate();
- List<Integer> found = new ArrayList<Integer>();
+ List<String> found = new ArrayList<String>();
for(Map<String,Object> row : Cursor.createIndexCursor(t, index)) {
- found.add((Integer)row.get("CD_AGENTE"));
+ found.add((String)row.get("col1"));
}
assertEquals(firstTwo, found);
@@ -158,17 +173,19 @@ public class BigIndexTest extends TestCase {
}
}
- public void x_testBigIndex() throws Exception
- {
- File f = new File("test/data/databaseTest19731_ind.mdb");
- Database db = open(f);
- Table t = db.getTable("test");
- System.out.println("FOO reading index");
- Index index = t.getIndexes().get(0);
- index.initialize();
- System.out.println(index);
- db.close();
- }
+// public void testBigIndex2() throws Exception
+// {
+// File f = new File("test/data/databaseTest19731_ind.mdb");
+// Database db = open(f);
+// Table t = db.getTable("test");
+// System.out.println("FOO reading index");
+// Index index = t.getIndexes().get(0);
+// index.initialize();
+// index.forceInit();
+// index.validate();
+// System.out.println(index);
+// db.close();
+// }
}