LUCENE-4918: Highlighter closes the given IndexReader if QueryScorer is used with an external IndexReader.

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1465961 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Simon Willnauer 2013-04-09 10:50:57 +00:00
parent ccf99d3e6c
commit 75c03eb548
3 changed files with 34 additions and 6 deletions
lucene
CHANGES.txt
highlighter/src
java/org/apache/lucene/search/highlight
test/org/apache/lucene/search/highlight

View File

@ -232,6 +232,9 @@ Bug Fixes
* LUCENE-4913: FacetResultNode.ordinal was always 0 when all children * LUCENE-4913: FacetResultNode.ordinal was always 0 when all children
are returned. (Mike McCandless) are returned. (Mike McCandless)
* LUCENE-4918: Highlighter closes the given IndexReader if QueryScorer
is used with an external IndexReader. (Simon Willnauer, Sirvan Yahyaei)
Documentation Documentation
* LUCENE-4841: Added example SimpleSortedSetFacetsExample to show how * LUCENE-4841: Added example SimpleSortedSetFacetsExample to show how

View File

@ -69,7 +69,7 @@ public class WeightedSpanTermExtractor {
private boolean cachedTokenStream; private boolean cachedTokenStream;
private boolean wrapToCaching = true; private boolean wrapToCaching = true;
private int maxDocCharsToAnalyze; private int maxDocCharsToAnalyze;
private AtomicReader reader = null; private AtomicReader internalReader = null;
public WeightedSpanTermExtractor() { public WeightedSpanTermExtractor() {
@ -350,7 +350,7 @@ public class WeightedSpanTermExtractor {
} }
protected AtomicReaderContext getLeafContext() throws IOException { protected AtomicReaderContext getLeafContext() throws IOException {
if (reader == null) { if (internalReader == null) {
if(wrapToCaching && !(tokenStream instanceof CachingTokenFilter)) { if(wrapToCaching && !(tokenStream instanceof CachingTokenFilter)) {
assert !cachedTokenStream; assert !cachedTokenStream;
tokenStream = new CachingTokenFilter(new OffsetLimitTokenFilter(tokenStream, maxDocCharsToAnalyze)); tokenStream = new CachingTokenFilter(new OffsetLimitTokenFilter(tokenStream, maxDocCharsToAnalyze));
@ -361,9 +361,9 @@ public class WeightedSpanTermExtractor {
tokenStream.reset(); tokenStream.reset();
final IndexSearcher searcher = indexer.createSearcher(); final IndexSearcher searcher = indexer.createSearcher();
// MEM index has only atomic ctx // MEM index has only atomic ctx
reader = new DelegatingAtomicReader(((AtomicReaderContext)searcher.getTopReaderContext()).reader()); internalReader = new DelegatingAtomicReader(((AtomicReaderContext)searcher.getTopReaderContext()).reader());
} }
return reader.getContext(); return internalReader.getContext();
} }
/* /*
@ -468,7 +468,7 @@ public class WeightedSpanTermExtractor {
try { try {
extract(query, terms); extract(query, terms);
} finally { } finally {
IOUtils.close(reader); IOUtils.close(internalReader);
} }
return terms; return terms;
@ -516,7 +516,7 @@ public class WeightedSpanTermExtractor {
weightedSpanTerm.weight *= idf; weightedSpanTerm.weight *= idf;
} }
} finally { } finally {
IOUtils.close(reader); IOUtils.close(internalReader);
} }
return terms; return terms;

View File

@ -459,6 +459,31 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
numHighlights == 5); numHighlights == 5);
} }
public void testExternalReader() throws Exception {
query = new RegexpQuery(new Term(FIELD_NAME, "ken.*"));
searcher = new IndexSearcher(reader);
hits = searcher.search(query, 100);
int maxNumFragmentsRequired = 2;
QueryScorer scorer = new QueryScorer(query, reader, FIELD_NAME);
Highlighter highlighter = new Highlighter(this, scorer);
for (int i = 0; i < hits.totalHits; i++) {
String text = searcher.doc(hits.scoreDocs[i].doc).get(FIELD_NAME);
TokenStream tokenStream = analyzer.tokenStream(FIELD_NAME, new StringReader(text));
highlighter.setTextFragmenter(new SimpleFragmenter(40));
String result = highlighter.getBestFragments(tokenStream, text, maxNumFragmentsRequired,
"...");
if (VERBOSE) System.out.println("\t" + result);
}
assertTrue(reader.docFreq(new Term(FIELD_NAME, "hello")) > 0);
assertTrue("Failed to find correct number of highlights " + numHighlights + " found",
numHighlights == 5);
}
public void testNumericRangeQuery() throws Exception { public void testNumericRangeQuery() throws Exception {
// doesn't currently highlight, but make sure it doesn't cause exception either // doesn't currently highlight, but make sure it doesn't cause exception either
query = NumericRangeQuery.newIntRange(NUMERIC_FIELD_NAME, 2, 6, true, true); query = NumericRangeQuery.newIntRange(NUMERIC_FIELD_NAME, 2, 6, true, true);