1 package org.apache.lucene.search;
4 * Licensed to the Apache Software Foundation (ASF) under one or more
5 * contributor license agreements. See the NOTICE file distributed with
6 * this work for additional information regarding copyright ownership.
7 * The ASF licenses this file to You under the Apache License, Version 2.0
8 * (the "License"); you may not use this file except in compliance with
9 * the License. You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
19 import java.util.HashSet;
22 import org.apache.lucene.document.Document;
23 import org.apache.lucene.document.Field.Index;
24 import org.apache.lucene.document.Field.Store;
25 import org.apache.lucene.document.Field;
26 import org.apache.lucene.index.IndexReader;
27 import org.apache.lucene.index.RandomIndexWriter;
28 import org.apache.lucene.index.Term;
29 import org.apache.lucene.search.BooleanClause.Occur;
30 import org.apache.lucene.store.Directory;
31 import org.apache.lucene.util.English;
32 import org.apache.lucene.util.LuceneTestCase;
34 public class TestQueryWrapperFilter extends LuceneTestCase {
36 public void testBasic() throws Exception {
37 Directory dir = newDirectory();
38 RandomIndexWriter writer = new RandomIndexWriter(random, dir);
39 Document doc = new Document();
40 doc.add(newField("field", "value", Store.NO, Index.ANALYZED));
41 writer.addDocument(doc);
42 IndexReader reader = writer.getReader();
45 TermQuery termQuery = new TermQuery(new Term("field", "value"));
47 // should not throw exception with primitive query
48 QueryWrapperFilter qwf = new QueryWrapperFilter(termQuery);
50 IndexSearcher searcher = newSearcher(reader);
51 TopDocs hits = searcher.search(new MatchAllDocsQuery(), qwf, 10);
52 assertEquals(1, hits.totalHits);
53 hits = searcher.search(new MatchAllDocsQuery(), new CachingWrapperFilter(qwf), 10);
54 assertEquals(1, hits.totalHits);
56 // should not throw exception with complex primitive query
57 BooleanQuery booleanQuery = new BooleanQuery();
58 booleanQuery.add(termQuery, Occur.MUST);
59 booleanQuery.add(new TermQuery(new Term("field", "missing")),
61 qwf = new QueryWrapperFilter(termQuery);
63 hits = searcher.search(new MatchAllDocsQuery(), qwf, 10);
64 assertEquals(1, hits.totalHits);
65 hits = searcher.search(new MatchAllDocsQuery(), new CachingWrapperFilter(qwf), 10);
66 assertEquals(1, hits.totalHits);
68 // should not throw exception with non primitive Query (doesn't implement
69 // Query#createWeight)
70 qwf = new QueryWrapperFilter(new FuzzyQuery(new Term("field", "valu")));
72 hits = searcher.search(new MatchAllDocsQuery(), qwf, 10);
73 assertEquals(1, hits.totalHits);
74 hits = searcher.search(new MatchAllDocsQuery(), new CachingWrapperFilter(qwf), 10);
75 assertEquals(1, hits.totalHits);
77 // test a query with no hits
78 termQuery = new TermQuery(new Term("field", "not_exist"));
79 qwf = new QueryWrapperFilter(termQuery);
80 hits = searcher.search(new MatchAllDocsQuery(), qwf, 10);
81 assertEquals(0, hits.totalHits);
82 hits = searcher.search(new MatchAllDocsQuery(), new CachingWrapperFilter(qwf), 10);
83 assertEquals(0, hits.totalHits);
89 // this test is for 3.x only, in 4.x we no longer support non-atomic readers passed to getDocIdSet():
90 public void test_LUCENE3442() throws Exception {
92 Directory dir = newDirectory();
93 RandomIndexWriter writer = new RandomIndexWriter(random, dir);
94 Document doc = new Document();
95 doc.add(newField("id", "1001", Store.YES, Index.NOT_ANALYZED));
96 doc.add(newField("text", "headline one group one", Store.YES, Index.ANALYZED));
97 writer.addDocument(doc);
98 IndexReader rdr = writer.getReader();
100 IndexSearcher searcher = new IndexSearcher(rdr);
101 TermQuery tq = new TermQuery(new Term("text", "headline"));
102 TopDocs results = searcher.search(tq, 5);
103 assertEquals(1, results.totalHits);
105 Filter f = new QueryWrapperFilter(tq);
106 // rdr may not be atomic (it isn't in most cases), TermQuery inside QWF should still work!
107 DocIdSet dis = f.getDocIdSet(rdr);
109 DocIdSetIterator it = dis.iterator();
111 int docId, count = 0;
112 while ((docId = it.nextDoc()) != DocIdSetIterator.NO_MORE_DOCS) {
113 assertEquals("1001", rdr.document(docId).get("id"));
116 assertEquals(1, count);
122 public void testRandom() throws Exception {
123 final Directory d = newDirectory();
124 final RandomIndexWriter w = new RandomIndexWriter(random, d);
125 w.w.getConfig().setMaxBufferedDocs(17);
126 final int numDocs = atLeast(100);
127 final Set<String> aDocs = new HashSet<String>();
128 for(int i=0;i<numDocs;i++) {
129 final Document doc = new Document();
131 if (random.nextInt(5) == 4) {
137 final Field f = newField("field", v, Field.Store.NO, Field.Index.NOT_ANALYZED);
139 doc.add(newField("id", ""+i, Field.Store.YES, Field.Index.NOT_ANALYZED));
143 final int numDelDocs = atLeast(10);
144 for(int i=0;i<numDelDocs;i++) {
145 final String delID = ""+random.nextInt(numDocs);
146 w.deleteDocuments(new Term("id", delID));
150 final IndexReader r = w.getReader();
152 final TopDocs hits = new IndexSearcher(r).search(new MatchAllDocsQuery(),
153 new QueryWrapperFilter(new TermQuery(new Term("field", "a"))),
155 assertEquals(aDocs.size(), hits.totalHits);
156 for(ScoreDoc sd: hits.scoreDocs) {
157 assertTrue(aDocs.contains(r.document(sd.doc).get("id")));
163 public void testThousandDocuments() throws Exception {
164 Directory dir = newDirectory();
165 RandomIndexWriter writer = new RandomIndexWriter(random, dir);
166 for (int i = 0; i < 1000; i++) {
167 Document doc = new Document();
168 doc.add(newField("field", English.intToEnglish(i), Field.Index.NOT_ANALYZED));
169 writer.addDocument(doc);
172 IndexReader reader = writer.getReader();
175 IndexSearcher searcher = newSearcher(reader);
177 for (int i = 0; i < 1000; i++) {
178 TermQuery termQuery = new TermQuery(new Term("field", English.intToEnglish(i)));
179 QueryWrapperFilter qwf = new QueryWrapperFilter(termQuery);
180 TopDocs td = searcher.search(new MatchAllDocsQuery(), qwf, 10);
181 assertEquals(1, td.totalHits);