HBASE-15421 Convert TestStoreScanner to junit4 from junit3 and clean up close of scanners

This commit is contained in:
stack 2016-03-07 20:46:36 -08:00
parent 1c6beb3dc1
commit 4f044cf6be
1 changed files with 212 additions and 186 deletions

View File

@ -28,9 +28,8 @@ import java.util.List;
import java.util.NavigableSet; import java.util.NavigableSet;
import java.util.TreeSet; import java.util.TreeSet;
import junit.framework.TestCase;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.CategoryBasedTimeout;
import org.apache.hadoop.hbase.Cell; import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellComparator; import org.apache.hadoop.hbase.CellComparator;
import org.apache.hadoop.hbase.HBaseConfiguration; import org.apache.hadoop.hbase.HBaseConfiguration;
@ -44,11 +43,19 @@ import org.apache.hadoop.hbase.testclassification.RegionServerTests;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.apache.hadoop.hbase.util.EnvironmentEdge; import org.apache.hadoop.hbase.util.EnvironmentEdge;
import org.apache.hadoop.hbase.util.EnvironmentEdgeManagerTestHelper; import org.apache.hadoop.hbase.util.EnvironmentEdgeManagerTestHelper;
import org.junit.Assert;
import org.junit.Rule;
import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
import org.junit.rules.TestName;
import org.junit.rules.TestRule;
// Can't be small as it plays with EnvironmentEdgeManager // Can't be small as it plays with EnvironmentEdgeManager
@Category({RegionServerTests.class, MediumTests.class}) @Category({RegionServerTests.class, MediumTests.class})
public class TestStoreScanner extends TestCase { public class TestStoreScanner {
@Rule public TestName name = new TestName();
@Rule public final TestRule timeout = CategoryBasedTimeout.builder().withTimeout(this.getClass()).
withLookingForStuckThread(true).build();
private static final String CF_STR = "cf"; private static final String CF_STR = "cf";
final byte [] CF = Bytes.toBytes(CF_STR); final byte [] CF = Bytes.toBytes(CF_STR);
static Configuration CONF = HBaseConfiguration.create(); static Configuration CONF = HBaseConfiguration.create();
@ -56,10 +63,6 @@ public class TestStoreScanner extends TestCase {
Long.MAX_VALUE, KeepDeletedCells.FALSE, 0, CellComparator.COMPARATOR); Long.MAX_VALUE, KeepDeletedCells.FALSE, 0, CellComparator.COMPARATOR);
private ScanType scanType = ScanType.USER_SCAN; private ScanType scanType = ScanType.USER_SCAN;
public void setUp() throws Exception {
super.setUp();
}
/* /*
* Test utility for building a NavigableSet for scanners. * Test utility for building a NavigableSet for scanners.
* @param strCols * @param strCols
@ -74,6 +77,7 @@ public class TestStoreScanner extends TestCase {
return cols; return cols;
} }
@Test
public void testScanTimeRange() throws IOException { public void testScanTimeRange() throws IOException {
String r1 = "R1"; String r1 = "R1";
// returns only 1 of these 2 even though same timestamp // returns only 1 of these 2 even though same timestamp
@ -91,42 +95,48 @@ public class TestStoreScanner extends TestCase {
Scan scanSpec = new Scan(Bytes.toBytes(r1)); Scan scanSpec = new Scan(Bytes.toBytes(r1));
scanSpec.setTimeRange(0, 6); scanSpec.setTimeRange(0, 6);
scanSpec.setMaxVersions(); scanSpec.setMaxVersions();
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, List<Cell> results = null;
getCols("a"), scanners); try (StoreScanner scan =
List<Cell> results = new ArrayList<Cell>(); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
assertEquals(true, scan.next(results)); results = new ArrayList<Cell>();
assertEquals(5, results.size()); Assert.assertEquals(true, scan.next(results));
assertEquals(kvs[kvs.length - 1], results.get(0)); Assert.assertEquals(5, results.size());
Assert.assertEquals(kvs[kvs.length - 1], results.get(0));
}
// Scan limited TimeRange // Scan limited TimeRange
scanSpec = new Scan(Bytes.toBytes(r1)); scanSpec = new Scan(Bytes.toBytes(r1));
scanSpec.setTimeRange(1, 3); scanSpec.setTimeRange(1, 3);
scanSpec.setMaxVersions(); scanSpec.setMaxVersions();
scan = new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), try (StoreScanner scan =
scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
results = new ArrayList<Cell>(); results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(2, results.size()); Assert.assertEquals(2, results.size());
}
// Another range. // Another range.
scanSpec = new Scan(Bytes.toBytes(r1)); scanSpec = new Scan(Bytes.toBytes(r1));
scanSpec.setTimeRange(5, 10); scanSpec.setTimeRange(5, 10);
scanSpec.setMaxVersions(); scanSpec.setMaxVersions();
scan = new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), try (StoreScanner scan =
scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
results = new ArrayList<Cell>(); results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(1, results.size()); Assert.assertEquals(1, results.size());
}
// See how TimeRange and Versions interact. // See how TimeRange and Versions interact.
// Another range. // Another range.
scanSpec = new Scan(Bytes.toBytes(r1)); scanSpec = new Scan(Bytes.toBytes(r1));
scanSpec.setTimeRange(0, 10); scanSpec.setTimeRange(0, 10);
scanSpec.setMaxVersions(3); scanSpec.setMaxVersions(3);
scan = new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), try (StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"),
scanners); scanners)) {
results = new ArrayList<Cell>(); results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(3, results.size()); Assert.assertEquals(3, results.size());
}
} }
@Test
public void testScanSameTimestamp() throws IOException { public void testScanSameTimestamp() throws IOException {
// returns only 1 of these 2 even though same timestamp // returns only 1 of these 2 even though same timestamp
KeyValue [] kvs = new KeyValue[] { KeyValue [] kvs = new KeyValue[] {
@ -140,13 +150,13 @@ public class TestStoreScanner extends TestCase {
Scan scanSpec = new Scan(Bytes.toBytes("R1")); Scan scanSpec = new Scan(Bytes.toBytes("R1"));
// this only uses maxVersions (default=1) and TimeRange (default=all) // this only uses maxVersions (default=1) and TimeRange (default=all)
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, try (StoreScanner scan =
getCols("a"), scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
List<Cell> results = new ArrayList<Cell>();
List<Cell> results = new ArrayList<Cell>(); Assert.assertEquals(true, scan.next(results));
assertEquals(true, scan.next(results)); Assert.assertEquals(1, results.size());
assertEquals(1, results.size()); Assert.assertEquals(kvs[0], results.get(0));
assertEquals(kvs[0], results.get(0)); }
} }
/* /*
@ -156,6 +166,7 @@ public class TestStoreScanner extends TestCase {
* TODO this comment makes no sense above. Appears to do the right thing. * TODO this comment makes no sense above. Appears to do the right thing.
* @throws IOException * @throws IOException
*/ */
@Test
public void testWontNextToNext() throws IOException { public void testWontNextToNext() throws IOException {
// build the scan file: // build the scan file:
KeyValue [] kvs = new KeyValue[] { KeyValue [] kvs = new KeyValue[] {
@ -167,27 +178,27 @@ public class TestStoreScanner extends TestCase {
Scan scanSpec = new Scan(Bytes.toBytes("R1")); Scan scanSpec = new Scan(Bytes.toBytes("R1"));
// this only uses maxVersions (default=1) and TimeRange (default=all) // this only uses maxVersions (default=1) and TimeRange (default=all)
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, try (StoreScanner scan =
getCols("a"), scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
List<Cell> results = new ArrayList<Cell>();
List<Cell> results = new ArrayList<Cell>(); scan.next(results);
scan.next(results); Assert.assertEquals(1, results.size());
assertEquals(1, results.size()); Assert.assertEquals(kvs[0], results.get(0));
assertEquals(kvs[0], results.get(0)); // should be ok...
// should be ok... // now scan _next_ again.
// now scan _next_ again. results.clear();
results.clear(); scan.next(results);
scan.next(results); Assert.assertEquals(1, results.size());
assertEquals(1, results.size()); Assert.assertEquals(kvs[2], results.get(0));
assertEquals(kvs[2], results.get(0));
results.clear();
scan.next(results);
assertEquals(0, results.size());
results.clear();
scan.next(results);
Assert.assertEquals(0, results.size());
}
} }
@Test
public void testDeleteVersionSameTimestamp() throws IOException { public void testDeleteVersionSameTimestamp() throws IOException {
KeyValue [] kvs = new KeyValue [] { KeyValue [] kvs = new KeyValue [] {
KeyValueTestUtil.create("R1", "cf", "a", 1, KeyValue.Type.Put, "dont-care"), KeyValueTestUtil.create("R1", "cf", "a", 1, KeyValue.Type.Put, "dont-care"),
@ -195,18 +206,19 @@ public class TestStoreScanner extends TestCase {
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
Scan scanSpec = new Scan(Bytes.toBytes("R1")); Scan scanSpec = new Scan(Bytes.toBytes("R1"));
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, try (StoreScanner scan =
getCols("a"), scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
List<Cell> results = new ArrayList<Cell>();
List<Cell> results = new ArrayList<Cell>(); Assert.assertFalse(scan.next(results));
assertFalse(scan.next(results)); Assert.assertEquals(0, results.size());
assertEquals(0, results.size()); }
} }
/* /*
* Test the case where there is a delete row 'in front of' the next row, the scanner * Test the case where there is a delete row 'in front of' the next row, the scanner
* will move to the next row. * will move to the next row.
*/ */
@Test
public void testDeletedRowThenGoodRow() throws IOException { public void testDeletedRowThenGoodRow() throws IOException {
KeyValue [] kvs = new KeyValue [] { KeyValue [] kvs = new KeyValue [] {
KeyValueTestUtil.create("R1", "cf", "a", 1, KeyValue.Type.Put, "dont-care"), KeyValueTestUtil.create("R1", "cf", "a", 1, KeyValue.Type.Put, "dont-care"),
@ -215,18 +227,18 @@ public class TestStoreScanner extends TestCase {
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
Scan scanSpec = new Scan(Bytes.toBytes("R1")); Scan scanSpec = new Scan(Bytes.toBytes("R1"));
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, try (StoreScanner scan =
getCols("a"), scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
List<Cell> results = new ArrayList<Cell>();
Assert.assertEquals(true, scan.next(results));
Assert.assertEquals(0, results.size());
List<Cell> results = new ArrayList<Cell>(); Assert.assertEquals(true, scan.next(results));
assertEquals(true, scan.next(results)); Assert.assertEquals(1, results.size());
assertEquals(0, results.size()); Assert.assertEquals(kvs[2], results.get(0));
assertEquals(true, scan.next(results)); Assert.assertEquals(false, scan.next(results));
assertEquals(1, results.size()); }
assertEquals(kvs[2], results.get(0));
assertEquals(false, scan.next(results));
} }
public void testDeleteVersionMaskingMultiplePuts() throws IOException { public void testDeleteVersionMaskingMultiplePuts() throws IOException {
@ -242,15 +254,16 @@ public class TestStoreScanner extends TestCase {
}; };
List<KeyValueScanner> scanners = scanFixture(kvs1, kvs2); List<KeyValueScanner> scanners = scanFixture(kvs1, kvs2);
StoreScanner scan = new StoreScanner(new Scan(Bytes.toBytes("R1")), try (StoreScanner scan = new StoreScanner(new Scan(Bytes.toBytes("R1")), scanInfo, scanType,
scanInfo, scanType, getCols("a"), scanners); getCols("a"), scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
// the two put at ts=now will be masked by the 1 delete, and // the two put at ts=now will be masked by the 1 delete, and
// since the scan default returns 1 version we'll return the newest // since the scan default returns 1 version we'll return the newest
// key, which is kvs[2], now-100. // key, which is kvs[2], now-100.
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(1, results.size()); Assert.assertEquals(1, results.size());
assertEquals(kvs2[1], results.get(0)); Assert.assertEquals(kvs2[1], results.get(0));
}
} }
public void testDeleteVersionsMixedAndMultipleVersionReturn() throws IOException { public void testDeleteVersionsMixedAndMultipleVersionReturn() throws IOException {
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
@ -267,15 +280,17 @@ public class TestStoreScanner extends TestCase {
List<KeyValueScanner> scanners = scanFixture(kvs1, kvs2); List<KeyValueScanner> scanners = scanFixture(kvs1, kvs2);
Scan scanSpec = new Scan(Bytes.toBytes("R1")).setMaxVersions(2); Scan scanSpec = new Scan(Bytes.toBytes("R1")).setMaxVersions(2);
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, try (StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType,
getCols("a"), scanners); getCols("a"), scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(2, results.size()); Assert.assertEquals(2, results.size());
assertEquals(kvs2[1], results.get(0)); Assert.assertEquals(kvs2[1], results.get(0));
assertEquals(kvs2[0], results.get(1)); Assert.assertEquals(kvs2[0], results.get(1));
}
} }
@Test
public void testWildCardOneVersionScan() throws IOException { public void testWildCardOneVersionScan() throws IOException {
KeyValue [] kvs = new KeyValue [] { KeyValue [] kvs = new KeyValue [] {
KeyValueTestUtil.create("R1", "cf", "a", 2, KeyValue.Type.Put, "dont-care"), KeyValueTestUtil.create("R1", "cf", "a", 2, KeyValue.Type.Put, "dont-care"),
@ -283,15 +298,17 @@ public class TestStoreScanner extends TestCase {
KeyValueTestUtil.create("R1", "cf", "a", 1, KeyValue.Type.DeleteColumn, "dont-care"), KeyValueTestUtil.create("R1", "cf", "a", 1, KeyValue.Type.DeleteColumn, "dont-care"),
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
StoreScanner scan = new StoreScanner(new Scan(Bytes.toBytes("R1")), try (StoreScanner scan =
scanInfo, scanType, null, scanners); new StoreScanner(new Scan(Bytes.toBytes("R1")), scanInfo, scanType, null, scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(2, results.size()); Assert.assertEquals(2, results.size());
assertEquals(kvs[0], results.get(0)); Assert.assertEquals(kvs[0], results.get(0));
assertEquals(kvs[1], results.get(1)); Assert.assertEquals(kvs[1], results.get(1));
}
} }
@Test
public void testWildCardScannerUnderDeletes() throws IOException { public void testWildCardScannerUnderDeletes() throws IOException {
KeyValue [] kvs = new KeyValue [] { KeyValue [] kvs = new KeyValue [] {
KeyValueTestUtil.create("R1", "cf", "a", 2, KeyValue.Type.Put, "dont-care"), // inc KeyValueTestUtil.create("R1", "cf", "a", 2, KeyValue.Type.Put, "dont-care"), // inc
@ -312,18 +329,20 @@ public class TestStoreScanner extends TestCase {
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
StoreScanner scan = new StoreScanner(new Scan().setMaxVersions(2), try (StoreScanner scan = new StoreScanner(new Scan().setMaxVersions(2),
scanInfo, scanType, null, scanners); scanInfo, scanType, null, scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(5, results.size()); Assert.assertEquals(5, results.size());
assertEquals(kvs[0], results.get(0)); Assert.assertEquals(kvs[0], results.get(0));
assertEquals(kvs[2], results.get(1)); Assert.assertEquals(kvs[2], results.get(1));
assertEquals(kvs[3], results.get(2)); Assert.assertEquals(kvs[3], results.get(2));
assertEquals(kvs[6], results.get(3)); Assert.assertEquals(kvs[6], results.get(3));
assertEquals(kvs[7], results.get(4)); Assert.assertEquals(kvs[7], results.get(4));
}
} }
@Test
public void testDeleteFamily() throws IOException { public void testDeleteFamily() throws IOException {
KeyValue [] kvs = new KeyValue[] { KeyValue [] kvs = new KeyValue[] {
KeyValueTestUtil.create("R1", "cf", "a", 100, KeyValue.Type.DeleteFamily, "dont-care"), KeyValueTestUtil.create("R1", "cf", "a", 100, KeyValue.Type.DeleteFamily, "dont-care"),
@ -340,19 +359,21 @@ public class TestStoreScanner extends TestCase {
KeyValueTestUtil.create("R2", "cf", "a", 11, KeyValue.Type.Put, "dont-care"), KeyValueTestUtil.create("R2", "cf", "a", 11, KeyValue.Type.Put, "dont-care"),
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
StoreScanner scan = new StoreScanner( try (StoreScanner scan =
new Scan().setMaxVersions(Integer.MAX_VALUE), scanInfo, scanType, null, new StoreScanner(new Scan().setMaxVersions(Integer.MAX_VALUE), scanInfo, scanType, null,
scanners); scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(0, results.size()); Assert.assertEquals(0, results.size());
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(1, results.size()); Assert.assertEquals(1, results.size());
assertEquals(kvs[kvs.length-1], results.get(0)); Assert.assertEquals(kvs[kvs.length-1], results.get(0));
assertEquals(false, scan.next(results)); Assert.assertEquals(false, scan.next(results));
}
} }
@Test
public void testDeleteColumn() throws IOException { public void testDeleteColumn() throws IOException {
KeyValue [] kvs = new KeyValue[] { KeyValue [] kvs = new KeyValue[] {
KeyValueTestUtil.create("R1", "cf", "a", 10, KeyValue.Type.DeleteColumn, "dont-care"), KeyValueTestUtil.create("R1", "cf", "a", 10, KeyValue.Type.DeleteColumn, "dont-care"),
@ -361,12 +382,13 @@ public class TestStoreScanner extends TestCase {
KeyValueTestUtil.create("R1", "cf", "b", 5, KeyValue.Type.Put, "dont-care") KeyValueTestUtil.create("R1", "cf", "b", 5, KeyValue.Type.Put, "dont-care")
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
StoreScanner scan = new StoreScanner(new Scan(), scanInfo, scanType, null, try (StoreScanner scan = new StoreScanner(new Scan(), scanInfo, scanType, null,
scanners); scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
assertEquals(true, scan.next(results)); Assert.assertEquals(true, scan.next(results));
assertEquals(1, results.size()); Assert.assertEquals(1, results.size());
assertEquals(kvs[3], results.get(0)); Assert.assertEquals(kvs[3], results.get(0));
}
} }
private static final KeyValue [] kvs = new KeyValue[] { private static final KeyValue [] kvs = new KeyValue[] {
@ -382,30 +404,32 @@ public class TestStoreScanner extends TestCase {
KeyValueTestUtil.create("R2", "cf", "a", 11, KeyValue.Type.Put, "dont-care"), KeyValueTestUtil.create("R2", "cf", "a", 11, KeyValue.Type.Put, "dont-care"),
}; };
@Test
public void testSkipColumn() throws IOException { public void testSkipColumn() throws IOException {
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
StoreScanner scan = new StoreScanner(new Scan(), scanInfo, scanType, try (StoreScanner scan =
getCols("a", "d"), scanners); new StoreScanner(new Scan(), scanInfo, scanType, getCols("a", "d"), scanners)) {
List<Cell> results = new ArrayList<Cell>();
Assert.assertEquals(true, scan.next(results));
Assert.assertEquals(2, results.size());
Assert.assertEquals(kvs[0], results.get(0));
Assert.assertEquals(kvs[3], results.get(1));
results.clear();
List<Cell> results = new ArrayList<Cell>(); Assert.assertEquals(true, scan.next(results));
assertEquals(true, scan.next(results)); Assert.assertEquals(1, results.size());
assertEquals(2, results.size()); Assert.assertEquals(kvs[kvs.length-1], results.get(0));
assertEquals(kvs[0], results.get(0));
assertEquals(kvs[3], results.get(1));
results.clear();
assertEquals(true, scan.next(results)); results.clear();
assertEquals(1, results.size()); Assert.assertEquals(false, scan.next(results));
assertEquals(kvs[kvs.length-1], results.get(0)); }
results.clear();
assertEquals(false, scan.next(results));
} }
/* /*
* Test expiration of KeyValues in combination with a configured TTL for * Test expiration of KeyValues in combination with a configured TTL for
* a column family (as should be triggered in a major compaction). * a column family (as should be triggered in a major compaction).
*/ */
@Test
public void testWildCardTtlScan() throws IOException { public void testWildCardTtlScan() throws IOException {
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
KeyValue [] kvs = new KeyValue[] { KeyValue [] kvs = new KeyValue[] {
@ -424,41 +448,41 @@ public class TestStoreScanner extends TestCase {
ScanInfo scanInfo = new ScanInfo(CONF, CF, 0, 1, 500, KeepDeletedCells.FALSE, 0, ScanInfo scanInfo = new ScanInfo(CONF, CF, 0, 1, 500, KeepDeletedCells.FALSE, 0,
CellComparator.COMPARATOR); CellComparator.COMPARATOR);
ScanType scanType = ScanType.USER_SCAN; ScanType scanType = ScanType.USER_SCAN;
StoreScanner scanner = try (StoreScanner scanner = new StoreScanner(scan, scanInfo, scanType, null, scanners)) {
new StoreScanner(scan, scanInfo, scanType, List<Cell> results = new ArrayList<Cell>();
null, scanners); Assert.assertEquals(true, scanner.next(results));
Assert.assertEquals(2, results.size());
Assert.assertEquals(kvs[1], results.get(0));
Assert.assertEquals(kvs[2], results.get(1));
results.clear();
List<Cell> results = new ArrayList<Cell>(); Assert.assertEquals(true, scanner.next(results));
assertEquals(true, scanner.next(results)); Assert.assertEquals(3, results.size());
assertEquals(2, results.size()); Assert.assertEquals(kvs[4], results.get(0));
assertEquals(kvs[1], results.get(0)); Assert.assertEquals(kvs[5], results.get(1));
assertEquals(kvs[2], results.get(1)); Assert.assertEquals(kvs[6], results.get(2));
results.clear(); results.clear();
assertEquals(true, scanner.next(results)); Assert.assertEquals(false, scanner.next(results));
assertEquals(3, results.size()); }
assertEquals(kvs[4], results.get(0));
assertEquals(kvs[5], results.get(1));
assertEquals(kvs[6], results.get(2));
results.clear();
assertEquals(false, scanner.next(results));
} }
@Test
public void testScannerReseekDoesntNPE() throws Exception { public void testScannerReseekDoesntNPE() throws Exception {
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
StoreScanner scan = new StoreScanner(new Scan(), scanInfo, scanType, try (StoreScanner scan =
getCols("a", "d"), scanners); new StoreScanner(new Scan(), scanInfo, scanType, getCols("a", "d"), scanners)) {
// Previously a updateReaders twice in a row would cause an NPE. In test this would also // Previously a updateReaders twice in a row would cause an NPE. In test this would also
// normally cause an NPE because scan.store is null. So as long as we get through these // normally cause an NPE because scan.store is null. So as long as we get through these
// two calls we are good and the bug was quashed. // two calls we are good and the bug was quashed.
scan.updateReaders(new ArrayList<StoreFile>()); scan.updateReaders(new ArrayList<StoreFile>());
scan.updateReaders(new ArrayList<StoreFile>()); scan.updateReaders(new ArrayList<StoreFile>());
scan.peek(); scan.peek();
}
} }
@ -472,14 +496,16 @@ public class TestStoreScanner extends TestCase {
}; };
List<KeyValueScanner> scanners = scanFixture(kvs); List<KeyValueScanner> scanners = scanFixture(kvs);
Scan scanSpec = new Scan(Bytes.toBytes("R1")); Scan scanSpec = new Scan(Bytes.toBytes("R1"));
StoreScanner scan = new StoreScanner(scanSpec, scanInfo, scanType, try (StoreScanner scan =
getCols("a"), scanners); new StoreScanner(scanSpec, scanInfo, scanType, getCols("a"), scanners)) {
assertNull(scan.peek()); Assert.assertNull(scan.peek());
}
} }
/** /**
* Ensure that expired delete family markers don't override valid puts * Ensure that expired delete family markers don't override valid puts
*/ */
@Test
public void testExpiredDeleteFamily() throws Exception { public void testExpiredDeleteFamily() throws Exception {
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
KeyValue [] kvs = new KeyValue[] { KeyValue [] kvs = new KeyValue[] {
@ -495,18 +521,20 @@ public class TestStoreScanner extends TestCase {
ScanInfo scanInfo = new ScanInfo(CONF, CF, 0, 1, 500, KeepDeletedCells.FALSE, 0, ScanInfo scanInfo = new ScanInfo(CONF, CF, 0, 1, 500, KeepDeletedCells.FALSE, 0,
CellComparator.COMPARATOR); CellComparator.COMPARATOR);
ScanType scanType = ScanType.USER_SCAN; ScanType scanType = ScanType.USER_SCAN;
StoreScanner scanner = try (StoreScanner scanner =
new StoreScanner(scan, scanInfo, scanType, null, scanners); new StoreScanner(scan, scanInfo, scanType, null, scanners)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
assertEquals(true, scanner.next(results)); Assert.assertEquals(true, scanner.next(results));
assertEquals(1, results.size()); Assert.assertEquals(1, results.size());
assertEquals(kvs[1], results.get(0)); Assert.assertEquals(kvs[1], results.get(0));
results.clear(); results.clear();
assertEquals(false, scanner.next(results)); Assert.assertEquals(false, scanner.next(results));
}
} }
@Test
public void testDeleteMarkerLongevity() throws Exception { public void testDeleteMarkerLongevity() throws Exception {
try { try {
final long now = System.currentTimeMillis(); final long now = System.currentTimeMillis();
@ -558,26 +586,24 @@ public class TestStoreScanner extends TestCase {
KeepDeletedCells.FALSE /* keepDeletedCells */, KeepDeletedCells.FALSE /* keepDeletedCells */,
200, /* timeToPurgeDeletes */ 200, /* timeToPurgeDeletes */
CellComparator.COMPARATOR); CellComparator.COMPARATOR);
StoreScanner scanner = try (StoreScanner scanner =
new StoreScanner(scan, scanInfo, new StoreScanner(scan, scanInfo,
ScanType.COMPACT_DROP_DELETES, null, scanners, ScanType.COMPACT_DROP_DELETES, null, scanners,
HConstants.OLDEST_TIMESTAMP); HConstants.OLDEST_TIMESTAMP)) {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
results = new ArrayList<Cell>(); results = new ArrayList<Cell>();
assertEquals(true, scanner.next(results)); Assert.assertEquals(true, scanner.next(results));
assertEquals(kvs[0], results.get(0)); Assert.assertEquals(kvs[0], results.get(0));
assertEquals(kvs[2], results.get(1)); Assert.assertEquals(kvs[2], results.get(1));
assertEquals(kvs[3], results.get(2)); Assert.assertEquals(kvs[3], results.get(2));
assertEquals(kvs[5], results.get(3)); Assert.assertEquals(kvs[5], results.get(3));
assertEquals(kvs[9], results.get(4)); Assert.assertEquals(kvs[9], results.get(4));
assertEquals(kvs[14], results.get(5)); Assert.assertEquals(kvs[14], results.get(5));
assertEquals(kvs[15], results.get(6)); Assert.assertEquals(kvs[15], results.get(6));
assertEquals(7, results.size()); Assert.assertEquals(7, results.size());
scanner.close(); }
}finally{ } finally {
EnvironmentEdgeManagerTestHelper.reset(); EnvironmentEdgeManagerTestHelper.reset();
} }
} }
}
}