You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@lucene.apache.org by rm...@apache.org on 2013/01/29 19:39:47 UTC

svn commit: r1440050 - /lucene/dev/branches/lucene4547/lucene/core/src/test/org/apache/lucene/index/Test2BBinaryDocValues.java

Author: rmuir
Date: Tue Jan 29 18:39:47 2013
New Revision: 1440050

URL: http://svn.apache.org/viewvc?rev=1440050&view=rev
Log:
add variable length byte[] test

Modified:
    lucene/dev/branches/lucene4547/lucene/core/src/test/org/apache/lucene/index/Test2BBinaryDocValues.java

Modified: lucene/dev/branches/lucene4547/lucene/core/src/test/org/apache/lucene/index/Test2BBinaryDocValues.java
URL: http://svn.apache.org/viewvc/lucene/dev/branches/lucene4547/lucene/core/src/test/org/apache/lucene/index/Test2BBinaryDocValues.java?rev=1440050&r1=1440049&r2=1440050&view=diff
==============================================================================
--- lucene/dev/branches/lucene4547/lucene/core/src/test/org/apache/lucene/index/Test2BBinaryDocValues.java (original)
+++ lucene/dev/branches/lucene4547/lucene/core/src/test/org/apache/lucene/index/Test2BBinaryDocValues.java Tue Jan 29 18:39:47 2013
@@ -21,6 +21,8 @@ import org.apache.lucene.analysis.MockAn
 import org.apache.lucene.document.BinaryDocValuesField;
 import org.apache.lucene.document.Document;
 import org.apache.lucene.store.BaseDirectoryWrapper;
+import org.apache.lucene.store.ByteArrayDataInput;
+import org.apache.lucene.store.ByteArrayDataOutput;
 import org.apache.lucene.store.MockDirectoryWrapper;
 import org.apache.lucene.util.BytesRef;
 import org.apache.lucene.util.LuceneTestCase;
@@ -93,4 +95,64 @@ public class Test2BBinaryDocValues exten
     r.close();
     dir.close();
   }
+  
+  // indexes Integer.MAX_VALUE docs with a variable binary field
+  // nocommit: broken ram accounting? ant test  -Dtestcase=Test2BBinaryDocValues -Dtests.method=testVariableBinary -Dtests.seed=FD50D16920062578 -Dtests.slow=true -Dtests.docvaluesformat=Disk -Dtests.locale=sr_ME_#Latn -Dtests.timezone=America/Argentina/Tucuman -Dtests.file.encoding=UTF-8
+  public void testVariableBinary() throws Exception {
+    BaseDirectoryWrapper dir = newFSDirectory(_TestUtil.getTempDir("2BVariableBinary"));
+    if (dir instanceof MockDirectoryWrapper) {
+      ((MockDirectoryWrapper)dir).setThrottling(MockDirectoryWrapper.Throttling.NEVER);
+    }
+    
+    IndexWriter w = new IndexWriter(dir,
+        new IndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer(random()))
+        .setMaxBufferedDocs(IndexWriterConfig.DISABLE_AUTO_FLUSH)
+        .setRAMBufferSizeMB(256.0)
+        .setMergeScheduler(new ConcurrentMergeScheduler())
+        .setMergePolicy(newLogMergePolicy(false, 10))
+        .setOpenMode(IndexWriterConfig.OpenMode.CREATE));
+
+    Document doc = new Document();
+    byte bytes[] = new byte[4];
+    ByteArrayDataOutput encoder = new ByteArrayDataOutput(bytes);
+    BytesRef data = new BytesRef(bytes);
+    BinaryDocValuesField dvField = new BinaryDocValuesField("dv", data);
+    doc.add(dvField);
+    
+    for (int i = 0; i < Integer.MAX_VALUE; i++) {
+      encoder.reset(bytes);
+      encoder.writeVInt(i % 65535); // 1, 2, or 3 bytes
+      data.length = encoder.getPosition();
+      w.addDocument(doc);
+      if (i % 100000 == 0) {
+        System.out.println("indexed: " + i);
+        System.out.flush();
+      }
+    }
+    
+    w.forceMerge(1);
+    w.close();
+    
+    System.out.println("verifying...");
+    System.out.flush();
+    
+    DirectoryReader r = DirectoryReader.open(dir);
+    int expectedValue = 0;
+    ByteArrayDataInput input = new ByteArrayDataInput();
+    for (AtomicReaderContext context : r.leaves()) {
+      AtomicReader reader = context.reader();
+      BytesRef scratch = new BytesRef(bytes);
+      BinaryDocValues dv = reader.getBinaryDocValues("dv");
+      for (int i = 0; i < reader.maxDoc(); i++) {
+        dv.get(i, scratch);
+        input.reset(scratch.bytes, scratch.offset, scratch.length);
+        assertEquals(expectedValue % 65535, input.readVInt());
+        assertTrue(input.eof());
+        expectedValue++;
+      }
+    }
+    
+    r.close();
+    dir.close();
+  }
 }