LUCENE-3458: Change BooleanFilter to have only a single clauses ArrayList (so toString() works in order). It now behaves more like BooleanQuery, implements Iterable<FilterClause>, and allows adding Filters without creating FilterClause. Also cleaned up formatting and Test.

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1175385 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Uwe Schindler 2011-09-25 12:48:56 +00:00
parent 0ea0ca6b60
commit f0ca4c49ef
4 changed files with 177 additions and 160 deletions

View File

@ -90,6 +90,11 @@ New Features
* LUCENE-1889: Add MultiTermQuery support for FVH. (Mike Sokolov via Koji Sekiguchi) * LUCENE-1889: Add MultiTermQuery support for FVH. (Mike Sokolov via Koji Sekiguchi)
* LUCENE-3458: Change BooleanFilter to have only a single clauses ArrayList
(so toString() works in order). It now behaves more like BooleanQuery,
implements Iterable<FilterClause>, and allows adding Filters without
creating FilterClause. (Uwe Schindler)
Bug Fixes Bug Fixes
* LUCENE-3417: DictionaryCompoundWordFilter did not properly add tokens from the * LUCENE-3417: DictionaryCompoundWordFilter did not properly add tokens from the

View File

@ -20,6 +20,7 @@ package org.apache.lucene.queries;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Iterator;
import org.apache.lucene.index.IndexReader; import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexReader.AtomicReaderContext; import org.apache.lucene.index.IndexReader.AtomicReaderContext;
@ -38,11 +39,9 @@ import org.apache.lucene.util.FixedBitSet;
* The resulting Filter is NOT'd with the NOT Filters * The resulting Filter is NOT'd with the NOT Filters
* The resulting Filter is AND'd with the MUST Filters * The resulting Filter is AND'd with the MUST Filters
*/ */
public class BooleanFilter extends Filter { public class BooleanFilter extends Filter implements Iterable<FilterClause> {
List<Filter> shouldFilters = null; private final List<FilterClause> clauses = new ArrayList<FilterClause>();
List<Filter> notFilters = null;
List<Filter> mustFilters = null;
/** /**
* Returns the a DocIdSetIterator representing the Boolean composition * Returns the a DocIdSetIterator representing the Boolean composition
@ -52,9 +51,10 @@ public class BooleanFilter extends Filter {
public DocIdSet getDocIdSet(AtomicReaderContext context) throws IOException { public DocIdSet getDocIdSet(AtomicReaderContext context) throws IOException {
FixedBitSet res = null; FixedBitSet res = null;
final IndexReader reader = context.reader; final IndexReader reader = context.reader;
if (shouldFilters != null) {
for (int i = 0; i < shouldFilters.size(); i++) { for (final FilterClause fc : clauses) {
final DocIdSetIterator disi = getDISI(shouldFilters, i, context); if (fc.getOccur() == Occur.SHOULD) {
final DocIdSetIterator disi = getDISI(fc.getFilter(), context);
if (disi == null) continue; if (disi == null) continue;
if (res == null) { if (res == null) {
res = new FixedBitSet(reader.maxDoc()); res = new FixedBitSet(reader.maxDoc());
@ -63,22 +63,22 @@ public class BooleanFilter extends Filter {
} }
} }
if (notFilters != null) { for (final FilterClause fc : clauses) {
for (int i = 0; i < notFilters.size(); i++) { if (fc.getOccur() == Occur.MUST_NOT) {
if (res == null) { if (res == null) {
res = new FixedBitSet(reader.maxDoc()); res = new FixedBitSet(reader.maxDoc());
res.set(0, reader.maxDoc()); // NOTE: may set bits on deleted docs res.set(0, reader.maxDoc()); // NOTE: may set bits on deleted docs
} }
final DocIdSetIterator disi = getDISI(notFilters, i, context); final DocIdSetIterator disi = getDISI(fc.getFilter(), context);
if (disi != null) { if (disi != null) {
res.andNot(disi); res.andNot(disi);
} }
} }
} }
if (mustFilters != null) { for (final FilterClause fc : clauses) {
for (int i = 0; i < mustFilters.size(); i++) { if (fc.getOccur() == Occur.MUST) {
final DocIdSetIterator disi = getDISI(mustFilters, i, context); final DocIdSetIterator disi = getDISI(fc.getFilter(), context);
if (disi == null) { if (disi == null) {
return DocIdSet.EMPTY_DOCIDSET; // no documents can match return DocIdSet.EMPTY_DOCIDSET; // no documents can match
} }
@ -94,33 +94,37 @@ public class BooleanFilter extends Filter {
return res != null ? res : DocIdSet.EMPTY_DOCIDSET; return res != null ? res : DocIdSet.EMPTY_DOCIDSET;
} }
private static DocIdSetIterator getDISI(Filter filter, AtomicReaderContext context)
throws IOException {
final DocIdSet set = filter.getDocIdSet(context);
return (set == null || set == DocIdSet.EMPTY_DOCIDSET) ? null : set.iterator();
}
/** /**
* Adds a new FilterClause to the Boolean Filter container * Adds a new FilterClause to the Boolean Filter container
* @param filterClause A FilterClause object containing a Filter and an Occur parameter * @param filterClause A FilterClause object containing a Filter and an Occur parameter
*/ */
public void add(FilterClause filterClause) { public void add(FilterClause filterClause) {
if (filterClause.getOccur().equals(Occur.MUST)) { clauses.add(filterClause);
if (mustFilters == null) {
mustFilters = new ArrayList<Filter>();
}
mustFilters.add(filterClause.getFilter());
} else if (filterClause.getOccur().equals(Occur.SHOULD)) {
if (shouldFilters == null) {
shouldFilters = new ArrayList<Filter>();
}
shouldFilters.add(filterClause.getFilter());
} else if (filterClause.getOccur().equals(Occur.MUST_NOT)) {
if (notFilters == null) {
notFilters = new ArrayList<Filter>();
}
notFilters.add(filterClause.getFilter());
}
} }
private DocIdSetIterator getDISI(List<Filter> filters, int index, AtomicReaderContext context) public final void add(Filter filter, Occur occur) {
throws IOException { add(new FilterClause(filter, occur));
final DocIdSet set = filters.get(index).getDocIdSet(context); }
return (set == null) ? null : set.iterator();
/**
* Returns the list of clauses
*/
public List<FilterClause> clauses() {
return clauses;
}
/** Returns an iterator on the clauses in this query. It implements the {@link Iterable} interface to
* make it possible to do:
* <pre>for (FilterClause clause : booleanFilter) {}</pre>
*/
public final Iterator<FilterClause> iterator() {
return clauses().iterator();
} }
@Override @Override
@ -133,44 +137,26 @@ public class BooleanFilter extends Filter {
return false; return false;
} }
BooleanFilter other = (BooleanFilter)obj; final BooleanFilter other = (BooleanFilter)obj;
return equalFilters(notFilters, other.notFilters) return clauses.equals(other.clauses);
&& equalFilters(mustFilters, other.mustFilters)
&& equalFilters(shouldFilters, other.shouldFilters);
}
private boolean equalFilters(List<Filter> filters1, List<Filter> filters2) {
return (filters1 == filters2) || ((filters1 != null) && filters1.equals(filters2));
} }
@Override @Override
public int hashCode() { public int hashCode() {
int hash = 7; return 657153718 ^ clauses.hashCode();
hash = 31 * hash + (null == mustFilters ? 0 : mustFilters.hashCode());
hash = 31 * hash + (null == notFilters ? 0 : notFilters.hashCode());
hash = 31 * hash + (null == shouldFilters ? 0 : shouldFilters.hashCode());
return hash;
} }
/** Prints a user-readable version of this query. */ /** Prints a user-readable version of this Filter. */
@Override @Override
public String toString() { public String toString() {
StringBuilder buffer = new StringBuilder(); final StringBuilder buffer = new StringBuilder("BooleanFilter(");
buffer.append("BooleanFilter("); final int minLen = buffer.length();
appendFilters(shouldFilters, "", buffer); for (final FilterClause c : clauses) {
appendFilters(mustFilters, "+", buffer); if (buffer.length() > minLen) {
appendFilters(notFilters, "-", buffer);
buffer.append(")");
return buffer.toString();
}
private void appendFilters(List<Filter> filters, String occurString, StringBuilder buffer) {
if (filters != null) {
for (Filter filter : filters) {
buffer.append(' '); buffer.append(' ');
buffer.append(occurString);
buffer.append(filter.toString());
} }
buffer.append(c);
} }
return buffer.append(')').toString();
} }
} }

View File

@ -26,7 +26,7 @@ import org.apache.lucene.search.Filter;
* (Follows the boolean logic in BooleanClause for composition * (Follows the boolean logic in BooleanClause for composition
* of queries.) * of queries.)
*/ */
public class FilterClause { public final class FilterClause {
private final Occur occur; private final Occur occur;
private final Filter filter; private final Filter filter;
@ -58,4 +58,25 @@ public class FilterClause {
return occur; return occur;
} }
@Override
public boolean equals(Object o) {
if (o == this)
return true;
if (o == null || !(o instanceof FilterClause))
return false;
final FilterClause other = (FilterClause)o;
return this.filter.equals(other.filter)
&& this.occur == other.occur;
}
@Override
public int hashCode() {
return filter.hashCode() ^ occur.hashCode();
}
@Override
public String toString() {
return occur.toString() + filter.toString();
}
} }

View File

@ -26,7 +26,7 @@ import org.apache.lucene.index.IndexReader.AtomicReaderContext;
import org.apache.lucene.index.RandomIndexWriter; import org.apache.lucene.index.RandomIndexWriter;
import org.apache.lucene.index.SlowMultiReaderWrapper; import org.apache.lucene.index.SlowMultiReaderWrapper;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause; import org.apache.lucene.search.BooleanClause.Occur;
import org.apache.lucene.search.DocIdSetIterator; import org.apache.lucene.search.DocIdSetIterator;
import org.apache.lucene.search.Filter; import org.apache.lucene.search.Filter;
import org.apache.lucene.search.TermRangeFilter; import org.apache.lucene.search.TermRangeFilter;
@ -120,7 +120,7 @@ public class BooleanFilterTest extends LuceneTestCase {
} }
private void tstFilterCard(String mes, int expected, Filter filt) private void tstFilterCard(String mes, int expected, Filter filt)
throws Throwable { throws Exception {
// BooleanFilter never returns null DIS or null DISI! // BooleanFilter never returns null DIS or null DISI!
DocIdSetIterator disi = filt.getDocIdSet(new AtomicReaderContext(reader)).iterator(); DocIdSetIterator disi = filt.getDocIdSet(new AtomicReaderContext(reader)).iterator();
int actual = 0; int actual = 0;
@ -131,176 +131,181 @@ public class BooleanFilterTest extends LuceneTestCase {
} }
public void testShould() throws Throwable { public void testShould() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getTermsFilter("price", "030"), Occur.SHOULD);
tstFilterCard("Should retrieves only 1 doc", 1, booleanFilter); tstFilterCard("Should retrieves only 1 doc", 1, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getWrappedTermQuery("price", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getWrappedTermQuery("price", "030"), Occur.SHOULD);
tstFilterCard("Should retrieves only 1 doc", 1, booleanFilter); tstFilterCard("Should retrieves only 1 doc", 1, booleanFilter);
} }
public void testShoulds() throws Throwable { public void testShoulds() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "010", "020"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "010", "020"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getRangeFilter("price", "020", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "020", "030"), Occur.SHOULD);
tstFilterCard("Shoulds are Ored together", 5, booleanFilter); tstFilterCard("Shoulds are Ored together", 5, booleanFilter);
} }
public void testShouldsAndMustNot() throws Throwable { public void testShouldsAndMustNot() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "010", "020"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "010", "020"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getRangeFilter("price", "020", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "020", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getTermsFilter("inStock", "N"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getTermsFilter("inStock", "N"), Occur.MUST_NOT);
tstFilterCard("Shoulds Ored but AndNot", 4, booleanFilter); tstFilterCard("Shoulds Ored but AndNot", 4, booleanFilter);
booleanFilter.add(new FilterClause(getTermsFilter("inStock", "Maybe"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getTermsFilter("inStock", "Maybe"), Occur.MUST_NOT);
tstFilterCard("Shoulds Ored but AndNots", 3, booleanFilter); tstFilterCard("Shoulds Ored but AndNots", 3, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "010", "020"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "010", "020"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getRangeFilter("price", "020", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "020", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getWrappedTermQuery("inStock", "N"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getWrappedTermQuery("inStock", "N"), Occur.MUST_NOT);
tstFilterCard("Shoulds Ored but AndNot", 4, booleanFilter); tstFilterCard("Shoulds Ored but AndNot", 4, booleanFilter);
booleanFilter.add(new FilterClause(getWrappedTermQuery("inStock", "Maybe"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getWrappedTermQuery("inStock", "Maybe"), Occur.MUST_NOT);
tstFilterCard("Shoulds Ored but AndNots", 3, booleanFilter); tstFilterCard("Shoulds Ored but AndNots", 3, booleanFilter);
} }
public void testShouldsAndMust() throws Throwable { public void testShouldsAndMust() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "010", "020"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "010", "020"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getRangeFilter("price", "020", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "020", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getTermsFilter("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("accessRights", "admin"), Occur.MUST);
tstFilterCard("Shoulds Ored but MUST", 3, booleanFilter); tstFilterCard("Shoulds Ored but MUST", 3, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "010", "020"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "010", "020"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getRangeFilter("price", "020", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "020", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getWrappedTermQuery("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getWrappedTermQuery("accessRights", "admin"), Occur.MUST);
tstFilterCard("Shoulds Ored but MUST", 3, booleanFilter); tstFilterCard("Shoulds Ored but MUST", 3, booleanFilter);
} }
public void testShouldsAndMusts() throws Throwable { public void testShouldsAndMusts() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "010", "020"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "010", "020"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getRangeFilter("price", "020", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "020", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getTermsFilter("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("accessRights", "admin"), Occur.MUST);
booleanFilter.add(new FilterClause(getRangeFilter("date", "20040101", "20041231"), BooleanClause.Occur.MUST)); booleanFilter.add(getRangeFilter("date", "20040101", "20041231"), Occur.MUST);
tstFilterCard("Shoulds Ored but MUSTs ANDED", 1, booleanFilter); tstFilterCard("Shoulds Ored but MUSTs ANDED", 1, booleanFilter);
} }
public void testShouldsAndMustsAndMustNot() throws Throwable { public void testShouldsAndMustsAndMustNot() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "030", "040"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "030", "040"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getTermsFilter("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("accessRights", "admin"), Occur.MUST);
booleanFilter.add(new FilterClause(getRangeFilter("date", "20050101", "20051231"), BooleanClause.Occur.MUST)); booleanFilter.add(getRangeFilter("date", "20050101", "20051231"), Occur.MUST);
booleanFilter.add(new FilterClause(getTermsFilter("inStock", "N"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getTermsFilter("inStock", "N"), Occur.MUST_NOT);
tstFilterCard("Shoulds Ored but MUSTs ANDED and MustNot", 0, booleanFilter); tstFilterCard("Shoulds Ored but MUSTs ANDED and MustNot", 0, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getRangeFilter("price", "030", "040"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getRangeFilter("price", "030", "040"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getWrappedTermQuery("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getWrappedTermQuery("accessRights", "admin"), Occur.MUST);
booleanFilter.add(new FilterClause(getRangeFilter("date", "20050101", "20051231"), BooleanClause.Occur.MUST)); booleanFilter.add(getRangeFilter("date", "20050101", "20051231"), Occur.MUST);
booleanFilter.add(new FilterClause(getWrappedTermQuery("inStock", "N"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getWrappedTermQuery("inStock", "N"), Occur.MUST_NOT);
tstFilterCard("Shoulds Ored but MUSTs ANDED and MustNot", 0, booleanFilter); tstFilterCard("Shoulds Ored but MUSTs ANDED and MustNot", 0, booleanFilter);
} }
public void testJustMust() throws Throwable { public void testJustMust() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("accessRights", "admin"), Occur.MUST);
tstFilterCard("MUST", 3, booleanFilter); tstFilterCard("MUST", 3, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getWrappedTermQuery("accessRights", "admin"), BooleanClause.Occur.MUST)); booleanFilter.add(getWrappedTermQuery("accessRights", "admin"), Occur.MUST);
tstFilterCard("MUST", 3, booleanFilter); tstFilterCard("MUST", 3, booleanFilter);
} }
public void testJustMustNot() throws Throwable { public void testJustMustNot() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("inStock", "N"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getTermsFilter("inStock", "N"), Occur.MUST_NOT);
tstFilterCard("MUST_NOT", 4, booleanFilter); tstFilterCard("MUST_NOT", 4, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getWrappedTermQuery("inStock", "N"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getWrappedTermQuery("inStock", "N"), Occur.MUST_NOT);
tstFilterCard("MUST_NOT", 4, booleanFilter); tstFilterCard("MUST_NOT", 4, booleanFilter);
} }
public void testMustAndMustNot() throws Throwable { public void testMustAndMustNot() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("inStock", "N"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("inStock", "N"), Occur.MUST);
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getTermsFilter("price", "030"), Occur.MUST_NOT);
tstFilterCard("MUST_NOT wins over MUST for same docs", 0, booleanFilter); tstFilterCard("MUST_NOT wins over MUST for same docs", 0, booleanFilter);
// same with a real DISI (no OpenBitSetIterator) // same with a real DISI (no OpenBitSetIterator)
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getWrappedTermQuery("inStock", "N"), BooleanClause.Occur.MUST)); booleanFilter.add(getWrappedTermQuery("inStock", "N"), Occur.MUST);
booleanFilter.add(new FilterClause(getWrappedTermQuery("price", "030"), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getWrappedTermQuery("price", "030"), Occur.MUST_NOT);
tstFilterCard("MUST_NOT wins over MUST for same docs", 0, booleanFilter); tstFilterCard("MUST_NOT wins over MUST for same docs", 0, booleanFilter);
} }
public void testCombinedNullDocIdSets() throws Throwable { public void testEmpty() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.MUST)); tstFilterCard("empty BooleanFilter returns no results", 0, booleanFilter);
booleanFilter.add(new FilterClause(getNullDISFilter(), BooleanClause.Occur.MUST)); }
public void testCombinedNullDocIdSets() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(getTermsFilter("price", "030"), Occur.MUST);
booleanFilter.add(getNullDISFilter(), Occur.MUST);
tstFilterCard("A MUST filter that returns a null DIS should never return documents", 0, booleanFilter); tstFilterCard("A MUST filter that returns a null DIS should never return documents", 0, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("price", "030"), Occur.MUST);
booleanFilter.add(new FilterClause(getNullDISIFilter(), BooleanClause.Occur.MUST)); booleanFilter.add(getNullDISIFilter(), Occur.MUST);
tstFilterCard("A MUST filter that returns a null DISI should never return documents", 0, booleanFilter); tstFilterCard("A MUST filter that returns a null DISI should never return documents", 0, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getTermsFilter("price", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getNullDISFilter(), BooleanClause.Occur.SHOULD)); booleanFilter.add(getNullDISFilter(), Occur.SHOULD);
tstFilterCard("A SHOULD filter that returns a null DIS should be invisible", 1, booleanFilter); tstFilterCard("A SHOULD filter that returns a null DIS should be invisible", 1, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.SHOULD)); booleanFilter.add(getTermsFilter("price", "030"), Occur.SHOULD);
booleanFilter.add(new FilterClause(getNullDISIFilter(), BooleanClause.Occur.SHOULD)); booleanFilter.add(getNullDISIFilter(), Occur.SHOULD);
tstFilterCard("A SHOULD filter that returns a null DISI should be invisible", 1, booleanFilter); tstFilterCard("A SHOULD filter that returns a null DISI should be invisible", 1, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("price", "030"), Occur.MUST);
booleanFilter.add(new FilterClause(getNullDISFilter(), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getNullDISFilter(), Occur.MUST_NOT);
tstFilterCard("A MUST_NOT filter that returns a null DIS should be invisible", 1, booleanFilter); tstFilterCard("A MUST_NOT filter that returns a null DIS should be invisible", 1, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getTermsFilter("price", "030"), BooleanClause.Occur.MUST)); booleanFilter.add(getTermsFilter("price", "030"), Occur.MUST);
booleanFilter.add(new FilterClause(getNullDISIFilter(), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getNullDISIFilter(), Occur.MUST_NOT);
tstFilterCard("A MUST_NOT filter that returns a null DISI should be invisible", 1, booleanFilter); tstFilterCard("A MUST_NOT filter that returns a null DISI should be invisible", 1, booleanFilter);
} }
public void testJustNullDocIdSets() throws Throwable { public void testJustNullDocIdSets() throws Exception {
BooleanFilter booleanFilter = new BooleanFilter(); BooleanFilter booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getNullDISFilter(), BooleanClause.Occur.MUST)); booleanFilter.add(getNullDISFilter(), Occur.MUST);
tstFilterCard("A MUST filter that returns a null DIS should never return documents", 0, booleanFilter); tstFilterCard("A MUST filter that returns a null DIS should never return documents", 0, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getNullDISIFilter(), BooleanClause.Occur.MUST)); booleanFilter.add(getNullDISIFilter(), Occur.MUST);
tstFilterCard("A MUST filter that returns a null DISI should never return documents", 0, booleanFilter); tstFilterCard("A MUST filter that returns a null DISI should never return documents", 0, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getNullDISFilter(), BooleanClause.Occur.SHOULD)); booleanFilter.add(getNullDISFilter(), Occur.SHOULD);
tstFilterCard("A single SHOULD filter that returns a null DIS should never return documents", 0, booleanFilter); tstFilterCard("A single SHOULD filter that returns a null DIS should never return documents", 0, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getNullDISIFilter(), BooleanClause.Occur.SHOULD)); booleanFilter.add(getNullDISIFilter(), Occur.SHOULD);
tstFilterCard("A single SHOULD filter that returns a null DISI should never return documents", 0, booleanFilter); tstFilterCard("A single SHOULD filter that returns a null DISI should never return documents", 0, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getNullDISFilter(), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getNullDISFilter(), Occur.MUST_NOT);
tstFilterCard("A single MUST_NOT filter that returns a null DIS should be invisible", 5, booleanFilter); tstFilterCard("A single MUST_NOT filter that returns a null DIS should be invisible", 5, booleanFilter);
booleanFilter = new BooleanFilter(); booleanFilter = new BooleanFilter();
booleanFilter.add(new FilterClause(getNullDISIFilter(), BooleanClause.Occur.MUST_NOT)); booleanFilter.add(getNullDISIFilter(), Occur.MUST_NOT);
tstFilterCard("A single MUST_NOT filter that returns a null DIS should be invisible", 5, booleanFilter); tstFilterCard("A single MUST_NOT filter that returns a null DIS should be invisible", 5, booleanFilter);
} }
} }