fix clone() case that could incorrectly leave stored fields files open

git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@757185 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael McCandless 2009-03-22 13:21:58 +00:00
parent 04c0d1f81a
commit c6f7aa41a3
2 changed files with 18 additions and 4 deletions

View File

@ -676,10 +676,7 @@ class SegmentReader extends DirectoryIndexReader {
clone.freqStream = freqStream; clone.freqStream = freqStream;
clone.proxStream = proxStream; clone.proxStream = proxStream;
clone.termVectorsReaderOrig = termVectorsReaderOrig; clone.termVectorsReaderOrig = termVectorsReaderOrig;
clone.fieldsReaderOrig = fieldsReaderOrig;
if (fieldsReaderOrig != null) {
clone.fieldsReaderOrig = (FieldsReader) fieldsReaderOrig.clone();
}
if (doClone) { if (doClone) {
if (deletedDocs != null) { if (deletedDocs != null) {

View File

@ -20,6 +20,8 @@ package org.apache.lucene.index;
import org.apache.lucene.index.SegmentReader.Norm; import org.apache.lucene.index.SegmentReader.Norm;
import org.apache.lucene.search.Similarity; import org.apache.lucene.search.Similarity;
import org.apache.lucene.analysis.SimpleAnalyzer; import org.apache.lucene.analysis.SimpleAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.store.LockObtainFailedException; import org.apache.lucene.store.LockObtainFailedException;
import org.apache.lucene.store.MockRAMDirectory; import org.apache.lucene.store.MockRAMDirectory;
@ -440,4 +442,19 @@ public class TestIndexReaderClone extends LuceneTestCase {
r1.close(); r1.close();
dir1.close(); dir1.close();
} }
public void testCloseStoredFields() throws Exception {
final Directory dir = new MockRAMDirectory();
IndexWriter w = new IndexWriter(dir, new SimpleAnalyzer(), IndexWriter.MaxFieldLength.UNLIMITED);
w.setUseCompoundFile(false);
Document doc = new Document();
doc.add(new Field("field", "yes it's stored", Field.Store.YES, Field.Index.ANALYZED));
w.addDocument(doc);
w.close();
IndexReader r1 = IndexReader.open(dir);
IndexReader r2 = (IndexReader) r1.clone(false);
r1.close();
r2.close();
dir.close();
}
} }