HBASE-3550 FilterList reports false positives
git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1072481 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e3fa6497fe
commit
3564a25e85
|
@ -49,7 +49,8 @@ Release 0.91.0 - Unreleased
|
|||
HBASE-3525 mvn assembly is over-filling the hbase lib dir
|
||||
HBASE-3531 When under global memstore pressure, dont try to flush
|
||||
unflushable regions.
|
||||
|
||||
HBASE-3550 FilterList reports false positives (Bill Graham via Andrew
|
||||
Purtell)
|
||||
|
||||
IMPROVEMENTS
|
||||
HBASE-3290 Max Compaction Size (Nicolas Spiegelberg via Stack)
|
||||
|
|
|
@ -168,12 +168,15 @@ public class FilterList implements Filter {
|
|||
if (filter.filterAllRemaining()) {
|
||||
return ReturnCode.NEXT_ROW;
|
||||
}
|
||||
switch (filter.filterKeyValue(v)) {
|
||||
ReturnCode code = filter.filterKeyValue(v);
|
||||
switch (code) {
|
||||
case INCLUDE:
|
||||
continue;
|
||||
case NEXT_ROW:
|
||||
case SKIP:
|
||||
return ReturnCode.SKIP;
|
||||
default:
|
||||
return code;
|
||||
}
|
||||
} else if (operator == Operator.MUST_PASS_ONE) {
|
||||
if (filter.filterAllRemaining()) {
|
||||
|
|
|
@ -74,7 +74,68 @@ public class TestColumnPrefixFilter {
|
|||
scan.setMaxVersions();
|
||||
for (String s: prefixMap.keySet()) {
|
||||
filter = new ColumnPrefixFilter(Bytes.toBytes(s));
|
||||
|
||||
scan.setFilter(filter);
|
||||
|
||||
InternalScanner scanner = region.getScanner(scan);
|
||||
List<KeyValue> results = new ArrayList<KeyValue>();
|
||||
while(scanner.next(results));
|
||||
assertEquals(prefixMap.get(s).size(), results.size());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testColumnPrefixFilterWithFilterList() throws IOException {
|
||||
String family = "Family";
|
||||
HTableDescriptor htd = new HTableDescriptor("TestColumnPrefixFilter");
|
||||
htd.addFamily(new HColumnDescriptor(family));
|
||||
HRegionInfo info = new HRegionInfo(htd, null, null, false);
|
||||
HRegion region = HRegion.createHRegion(info, HBaseTestingUtility.
|
||||
getTestDir(), TEST_UTIL.getConfiguration());
|
||||
|
||||
List<String> rows = generateRandomWords(100, "row");
|
||||
List<String> columns = generateRandomWords(10000, "column");
|
||||
long maxTimestamp = 2;
|
||||
|
||||
List<KeyValue> kvList = new ArrayList<KeyValue>();
|
||||
|
||||
Map<String, List<KeyValue>> prefixMap = new HashMap<String,
|
||||
List<KeyValue>>();
|
||||
|
||||
prefixMap.put("p", new ArrayList<KeyValue>());
|
||||
prefixMap.put("s", new ArrayList<KeyValue>());
|
||||
|
||||
String valueString = "ValueString";
|
||||
|
||||
for (String row: rows) {
|
||||
Put p = new Put(Bytes.toBytes(row));
|
||||
for (String column: columns) {
|
||||
for (long timestamp = 1; timestamp <= maxTimestamp; timestamp++) {
|
||||
KeyValue kv = KeyValueTestUtil.create(row, family, column, timestamp,
|
||||
valueString);
|
||||
p.add(kv);
|
||||
kvList.add(kv);
|
||||
for (String s: prefixMap.keySet()) {
|
||||
if (column.startsWith(s)) {
|
||||
prefixMap.get(s).add(kv);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
region.put(p);
|
||||
}
|
||||
|
||||
ColumnPrefixFilter filter;
|
||||
Scan scan = new Scan();
|
||||
scan.setMaxVersions();
|
||||
for (String s: prefixMap.keySet()) {
|
||||
filter = new ColumnPrefixFilter(Bytes.toBytes(s));
|
||||
|
||||
//this is how this test differs from the one above
|
||||
FilterList filterList = new FilterList(FilterList.Operator.MUST_PASS_ALL);
|
||||
filterList.addFilter(filter);
|
||||
scan.setFilter(filterList);
|
||||
|
||||
InternalScanner scanner = region.getScanner(scan);
|
||||
List<KeyValue> results = new ArrayList<KeyValue>();
|
||||
while(scanner.next(results));
|
||||
|
|
Loading…
Reference in New Issue