LUCENE-6303: Make tests reproducible again.

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1663106 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Adrien Grand 2015-03-01 13:59:10 +00:00
parent b985737d1f
commit 4f3d2aeae5
5 changed files with 36 additions and 7 deletions

View File

@ -75,8 +75,8 @@ import org.apache.lucene.util.ThreadInterruptedException;
public class IndexSearcher { public class IndexSearcher {
// 32MB and at most 10,000 queries // 32MB and at most 10,000 queries
private static final QueryCache DEFAULT_QUERY_CACHE = new LRUQueryCache(10000, 1 << 25); private static QueryCache DEFAULT_QUERY_CACHE = new LRUQueryCache(10000, 1 << 25);
private static final QueryCachingPolicy DEFAULT_CACHING_POLICY = new UsageTrackingQueryCachingPolicy(); private static QueryCachingPolicy DEFAULT_CACHING_POLICY = new UsageTrackingQueryCachingPolicy();
final IndexReader reader; // package private for testing! final IndexReader reader; // package private for testing!
@ -106,7 +106,23 @@ public class IndexSearcher {
public static Similarity getDefaultSimilarity() { public static Similarity getDefaultSimilarity() {
return defaultSimilarity; return defaultSimilarity;
} }
/**
* Expert: set the default {@link QueryCache} instance.
* @lucene.internal
*/
public static void setDefaultQueryCache(QueryCache defaultQueryCache) {
DEFAULT_QUERY_CACHE = defaultQueryCache;
}
/**
* Expert: set the default {@link QueryCachingPolicy} instance.
* @lucene.internal
*/
public static void setDefaultQueryCachingPolicy(QueryCachingPolicy defaultQueryCachingPolicy) {
DEFAULT_CACHING_POLICY = defaultQueryCachingPolicy;
}
/** The Similarity implementation used by this searcher. */ /** The Similarity implementation used by this searcher. */
private Similarity similarity = defaultSimilarity; private Similarity similarity = defaultSimilarity;

View File

@ -602,7 +602,8 @@ public class TestBooleanQuery extends LuceneTestCase {
w.commit(); w.commit();
DirectoryReader reader = w.getReader(); DirectoryReader reader = w.getReader();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = newSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
PhraseQuery pq = new PhraseQuery(); PhraseQuery pq = new PhraseQuery();
pq.add(new Term("field", "a")); pq.add(new Term("field", "a"));
@ -633,6 +634,7 @@ public class TestBooleanQuery extends LuceneTestCase {
DirectoryReader reader = w.getReader(); DirectoryReader reader = w.getReader();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = new IndexSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
PhraseQuery pq = new PhraseQuery(); PhraseQuery pq = new PhraseQuery();
pq.add(new Term("field", "a")); pq.add(new Term("field", "a"));
@ -662,7 +664,8 @@ public class TestBooleanQuery extends LuceneTestCase {
w.commit(); w.commit();
DirectoryReader reader = w.getReader(); DirectoryReader reader = w.getReader();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = newSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
PhraseQuery pq = new PhraseQuery(); PhraseQuery pq = new PhraseQuery();
pq.add(new Term("field", "a")); pq.add(new Term("field", "a"));
@ -693,6 +696,7 @@ public class TestBooleanQuery extends LuceneTestCase {
DirectoryReader reader = w.getReader(); DirectoryReader reader = w.getReader();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = new IndexSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
PhraseQuery pq = new PhraseQuery(); PhraseQuery pq = new PhraseQuery();
pq.add(new Term("field", "a")); pq.add(new Term("field", "a"));
@ -723,6 +727,7 @@ public class TestBooleanQuery extends LuceneTestCase {
DirectoryReader reader = w.getReader(); DirectoryReader reader = w.getReader();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = new IndexSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
PhraseQuery pq = new PhraseQuery(); PhraseQuery pq = new PhraseQuery();
pq.add(new Term("field", "a")); pq.add(new Term("field", "a"));

View File

@ -214,7 +214,8 @@ public class TestConstantScoreQuery extends LuceneTestCase {
w.commit(); w.commit();
DirectoryReader reader = w.getReader(); DirectoryReader reader = w.getReader();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = newSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
PhraseQuery pq = new PhraseQuery(); PhraseQuery pq = new PhraseQuery();
pq.add(new Term("field", "a")); pq.add(new Term("field", "a"));

View File

@ -203,6 +203,7 @@ public class TestQueryWrapperFilter extends LuceneTestCase {
final IndexReader reader = writer.getReader(); final IndexReader reader = writer.getReader();
writer.close(); writer.close();
final IndexSearcher searcher = new IndexSearcher(reader); final IndexSearcher searcher = new IndexSearcher(reader);
searcher.setQueryCache(null); // to still have approximations
final Query query = new QueryWrapperFilter(new RandomApproximationQuery(new TermQuery(new Term("foo", "bar")), random())); final Query query = new QueryWrapperFilter(new RandomApproximationQuery(new TermQuery(new Term("foo", "bar")), random()));
final Weight weight = searcher.createNormalizedWeight(query, random().nextBoolean()); final Weight weight = searcher.createNormalizedWeight(query, random().nextBoolean());
final Scorer scorer = weight.scorer(reader.leaves().get(0), null); final Scorer scorer = weight.scorer(reader.leaves().get(0), null);

View File

@ -95,6 +95,7 @@ import org.apache.lucene.index.IndexReader.ReaderClosedListener;
import org.apache.lucene.index.TermsEnum.SeekStatus; import org.apache.lucene.index.TermsEnum.SeekStatus;
import org.apache.lucene.search.AssertingIndexSearcher; import org.apache.lucene.search.AssertingIndexSearcher;
import org.apache.lucene.search.DocIdSetIterator; import org.apache.lucene.search.DocIdSetIterator;
import org.apache.lucene.search.LRUQueryCache;
import org.apache.lucene.search.Query; import org.apache.lucene.search.Query;
import org.apache.lucene.search.QueryCachingPolicy; import org.apache.lucene.search.QueryCachingPolicy;
import org.apache.lucene.search.IndexSearcher; import org.apache.lucene.search.IndexSearcher;
@ -1649,6 +1650,12 @@ public abstract class LuceneTestCase extends Assert {
} }
} }
@Before
public void resetDefaultQueryCache() {
IndexSearcher.setDefaultQueryCache(new LRUQueryCache(10000, 1 << 25));
IndexSearcher.setDefaultQueryCachingPolicy(MAYBE_CACHE_POLICY);
}
/** /**
* Create a new searcher over the reader. This searcher might randomly use * Create a new searcher over the reader. This searcher might randomly use
* threads. * threads.
@ -1700,7 +1707,6 @@ public abstract class LuceneTestCase extends Assert {
ret = random.nextBoolean() ? new IndexSearcher(r) : new IndexSearcher(r.getContext()); ret = random.nextBoolean() ? new IndexSearcher(r) : new IndexSearcher(r.getContext());
} }
ret.setSimilarity(classEnvRule.similarity); ret.setSimilarity(classEnvRule.similarity);
ret.setQueryCachingPolicy(MAYBE_CACHE_POLICY);
return ret; return ret;
} else { } else {
int threads = 0; int threads = 0;