HBASE-14676 HBaseTestCase clean out: Purge Incommon Interface and Table and Region implementations

This commit is contained in:
stack 2015-10-24 10:20:40 -07:00
parent caae3b2e5f
commit 604ff56ef3
8 changed files with 178 additions and 404 deletions

View File

@ -19,35 +19,29 @@
package org.apache.hadoop.hbase; package org.apache.hadoop.hbase;
import java.io.IOException; import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import java.util.NavigableMap; import java.util.NavigableMap;
import junit.framework.AssertionFailedError;
import junit.framework.TestCase;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Durability; import org.apache.hadoop.hbase.client.Durability;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result; import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.ResultScanner;
import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Table; import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.regionserver.HRegion; import org.apache.hadoop.hbase.regionserver.HRegion;
import org.apache.hadoop.hbase.regionserver.InternalScanner;
import org.apache.hadoop.hbase.regionserver.Region; import org.apache.hadoop.hbase.regionserver.Region;
import org.apache.hadoop.hbase.regionserver.RegionAsTable;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.apache.hadoop.hbase.util.FSTableDescriptors; import org.apache.hadoop.hbase.util.FSTableDescriptors;
import org.apache.hadoop.hbase.util.FSUtils; import org.apache.hadoop.hbase.util.FSUtils;
import org.apache.hadoop.hdfs.MiniDFSCluster; import org.apache.hadoop.hdfs.MiniDFSCluster;
import junit.framework.AssertionFailedError;
import junit.framework.TestCase;
/** /**
* Abstract HBase test class. Initializes a few things that can come in handly * Abstract HBase test class. Initializes a few things that can come in handly
* like an HBaseConfiguration and filesystem. * like an HBaseConfiguration and filesystem.
@ -239,7 +233,7 @@ public abstract class HBaseTestCase extends TestCase {
if (startKeyBytes == null || startKeyBytes.length == 0) { if (startKeyBytes == null || startKeyBytes.length == 0) {
startKeyBytes = START_KEY_BYTES; startKeyBytes = START_KEY_BYTES;
} }
return addContent(new HRegionIncommon(r), Bytes.toString(columnFamily), Bytes.toString(column), return addContent(new RegionAsTable(r), Bytes.toString(columnFamily), Bytes.toString(column),
startKeyBytes, endKey, -1); startKeyBytes, endKey, -1);
} }
@ -251,18 +245,15 @@ public abstract class HBaseTestCase extends TestCase {
* Add content to region <code>r</code> on the passed column * Add content to region <code>r</code> on the passed column
* <code>column</code>. * <code>column</code>.
* Adds data of the from 'aaa', 'aab', etc where key and value are the same. * Adds data of the from 'aaa', 'aab', etc where key and value are the same.
* @param updater An instance of {@link Incommon}.
* @param columnFamily
* @param writeToWAL
* @throws IOException * @throws IOException
* @return count of what we added. * @return count of what we added.
*/ */
public static long addContent(final Incommon updater, public static long addContent(final Table updater,
final String columnFamily) throws IOException { final String columnFamily) throws IOException {
return addContent(updater, columnFamily, START_KEY_BYTES, null); return addContent(updater, columnFamily, START_KEY_BYTES, null);
} }
public static long addContent(final Incommon updater, final String family, public static long addContent(final Table updater, final String family,
final String column) throws IOException { final String column) throws IOException {
return addContent(updater, family, column, START_KEY_BYTES, null); return addContent(updater, family, column, START_KEY_BYTES, null);
} }
@ -271,21 +262,16 @@ public abstract class HBaseTestCase extends TestCase {
* Add content to region <code>r</code> on the passed column * Add content to region <code>r</code> on the passed column
* <code>column</code>. * <code>column</code>.
* Adds data of the from 'aaa', 'aab', etc where key and value are the same. * Adds data of the from 'aaa', 'aab', etc where key and value are the same.
* @param updater An instance of {@link Incommon}.
* @param columnFamily
* @param startKeyBytes Where to start the rows inserted
* @param endKey Where to stop inserting rows.
* @param writeToWAL
* @return count of what we added. * @return count of what we added.
* @throws IOException * @throws IOException
*/ */
public static long addContent(final Incommon updater, final String columnFamily, public static long addContent(final Table updater, final String columnFamily,
final byte [] startKeyBytes, final byte [] endKey) final byte [] startKeyBytes, final byte [] endKey)
throws IOException { throws IOException {
return addContent(updater, columnFamily, null, startKeyBytes, endKey, -1); return addContent(updater, columnFamily, null, startKeyBytes, endKey, -1);
} }
public static long addContent(final Incommon updater, final String family, String column, public static long addContent(final Table updater, final String family, String column,
final byte [] startKeyBytes, final byte [] endKey) throws IOException { final byte [] startKeyBytes, final byte [] endKey) throws IOException {
return addContent(updater, family, column, startKeyBytes, endKey, -1); return addContent(updater, family, column, startKeyBytes, endKey, -1);
} }
@ -294,16 +280,10 @@ public abstract class HBaseTestCase extends TestCase {
* Add content to region <code>r</code> on the passed column * Add content to region <code>r</code> on the passed column
* <code>column</code>. * <code>column</code>.
* Adds data of the from 'aaa', 'aab', etc where key and value are the same. * Adds data of the from 'aaa', 'aab', etc where key and value are the same.
* @param updater An instance of {@link Incommon}.
* @param column
* @param startKeyBytes Where to start the rows inserted
* @param endKey Where to stop inserting rows.
* @param ts Timestamp to write the content with.
* @param writeToWAL
* @return count of what we added. * @return count of what we added.
* @throws IOException * @throws IOException
*/ */
public static long addContent(final Incommon updater, public static long addContent(final Table updater,
final String columnFamily, final String columnFamily,
final String column, final String column,
final byte [] startKeyBytes, final byte [] endKey, final long ts) final byte [] startKeyBytes, final byte [] endKey, final long ts)
@ -378,209 +358,6 @@ public abstract class HBaseTestCase extends TestCase {
return count; return count;
} }
/**
* Implementors can flushcache.
*/
public interface FlushCache {
/**
* @throws IOException
*/
void flushcache() throws IOException;
}
/**
* Interface used by tests so can do common operations against an HTable
* or an HRegion.
*
* TOOD: Come up w/ a better name for this interface.
*/
public interface Incommon {
/**
*
* @param delete
* @param writeToWAL
* @throws IOException
*/
void delete(Delete delete, boolean writeToWAL)
throws IOException;
/**
* @param put
* @throws IOException
*/
void put(Put put) throws IOException;
Result get(Get get) throws IOException;
/**
* @param family
* @param qualifiers
* @param firstRow
* @param ts
* @return scanner for specified columns, first row and timestamp
* @throws IOException
*/
ScannerIncommon getScanner(
byte[] family, byte[][] qualifiers, byte[] firstRow, long ts
)
throws IOException;
}
/**
* A class that makes a {@link Incommon} out of a {@link HRegion}
*/
public static class HRegionIncommon implements Incommon, FlushCache {
final HRegion region;
/**
* @param HRegion
*/
public HRegionIncommon(final HRegion HRegion) {
this.region = HRegion;
}
public HRegionIncommon(final Region region) {
this.region = (HRegion)region;
}
public void put(Put put) throws IOException {
region.put(put);
}
public void delete(Delete delete, boolean writeToWAL)
throws IOException {
this.region.delete(delete);
}
public Result get(Get get) throws IOException {
return region.get(get);
}
public ScannerIncommon getScanner(byte [] family, byte [][] qualifiers,
byte [] firstRow, long ts)
throws IOException {
Scan scan = new Scan(firstRow);
if(qualifiers == null || qualifiers.length == 0) {
scan.addFamily(family);
} else {
for(int i=0; i<qualifiers.length; i++){
scan.addColumn(HConstants.CATALOG_FAMILY, qualifiers[i]);
}
}
scan.setTimeRange(0, ts);
return new
InternalScannerIncommon(region.getScanner(scan));
}
public void flushcache() throws IOException {
this.region.flush(true);
}
}
/**
* A class that makes a {@link Incommon} out of a {@link Table}
*/
public static class HTableIncommon implements Incommon {
final Table table;
/**
* @param table
*/
public HTableIncommon(final Table table) {
super();
this.table = table;
}
public void put(Put put) throws IOException {
table.put(put);
}
public void delete(Delete delete, boolean writeToWAL)
throws IOException {
this.table.delete(delete);
}
public Result get(Get get) throws IOException {
return table.get(get);
}
public ScannerIncommon getScanner(byte [] family, byte [][] qualifiers,
byte [] firstRow, long ts)
throws IOException {
Scan scan = new Scan(firstRow);
if(qualifiers == null || qualifiers.length == 0) {
scan.addFamily(family);
} else {
for(int i=0; i<qualifiers.length; i++){
scan.addColumn(HConstants.CATALOG_FAMILY, qualifiers[i]);
}
}
scan.setTimeRange(0, ts);
return new
ClientScannerIncommon(table.getScanner(scan));
}
}
public interface ScannerIncommon
extends Iterable<Result> {
boolean next(List<Cell> values)
throws IOException;
void close() throws IOException;
}
public static class ClientScannerIncommon implements ScannerIncommon {
ResultScanner scanner;
public ClientScannerIncommon(ResultScanner scanner) {
this.scanner = scanner;
}
@Override
public boolean next(List<Cell> values)
throws IOException {
Result results = scanner.next();
if (results == null) {
return false;
}
values.clear();
values.addAll(results.listCells());
return true;
}
public void close() throws IOException {
scanner.close();
}
public Iterator<Result> iterator() {
return scanner.iterator();
}
}
public static class InternalScannerIncommon implements ScannerIncommon {
InternalScanner scanner;
public InternalScannerIncommon(InternalScanner scanner) {
this.scanner = scanner;
}
@Override
public boolean next(List<Cell> results)
throws IOException {
return scanner.next(results);
}
@Override
public void close() throws IOException {
scanner.close();
}
@Override
public Iterator<Result> iterator() {
throw new UnsupportedOperationException();
}
}
protected void assertResultEquals(final HRegion region, final byte [] row, protected void assertResultEquals(final HRegion region, final byte [] row,
final byte [] family, final byte [] qualifier, final long timestamp, final byte [] family, final byte [] qualifier, final long timestamp,
final byte [] value) final byte [] value)
@ -669,5 +446,4 @@ public abstract class HBaseTestCase extends TestCase {
Bytes.toStringBinary(actual) + ">"); Bytes.toStringBinary(actual) + ">");
} }
} }
} }

View File

@ -30,9 +30,7 @@ import java.util.NavigableMap;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.hbase.HBaseTestCase.FlushCache; import org.apache.hadoop.hbase.TimestampTestBase.FlushCache;
import org.apache.hadoop.hbase.HBaseTestCase.HTableIncommon;
import org.apache.hadoop.hbase.HBaseTestCase.Incommon;
import org.apache.hadoop.hbase.client.Admin; import org.apache.hadoop.hbase.client.Admin;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.Put;
@ -97,8 +95,7 @@ public class TestMultiVersions {
Table table = UTIL.getConnection().getTable(desc.getTableName()); Table table = UTIL.getConnection().getTable(desc.getTableName());
// TODO: Remove these deprecated classes or pull them in here if this is // TODO: Remove these deprecated classes or pull them in here if this is
// only test using them. // only test using them.
Incommon incommon = new HTableIncommon(table); TimestampTestBase.doTestDelete(table, new FlushCache() {
TimestampTestBase.doTestDelete(incommon, new FlushCache() {
public void flushcache() throws IOException { public void flushcache() throws IOException {
UTIL.getHBaseCluster().flushcache(); UTIL.getHBaseCluster().flushcache();
} }
@ -106,7 +103,7 @@ public class TestMultiVersions {
// Perhaps drop and readd the table between tests so the former does // Perhaps drop and readd the table between tests so the former does
// not pollute this latter? Or put into separate tests. // not pollute this latter? Or put into separate tests.
TimestampTestBase.doTestTimestampScanning(incommon, new FlushCache() { TimestampTestBase.doTestTimestampScanning(table, new FlushCache() {
public void flushcache() throws IOException { public void flushcache() throws IOException {
UTIL.getMiniHBaseCluster().flushcache(); UTIL.getMiniHBaseCluster().flushcache();
} }
@ -136,7 +133,7 @@ public class TestMultiVersions {
desc.addFamily(hcd); desc.addFamily(hcd);
this.admin.createTable(desc); this.admin.createTable(desc);
Put put = new Put(row, timestamp1); Put put = new Put(row, timestamp1);
put.add(contents, contents, value1); put.addColumn(contents, contents, value1);
Table table = UTIL.getConnection().getTable(desc.getTableName()); Table table = UTIL.getConnection().getTable(desc.getTableName());
table.put(put); table.put(put);
// Shut down and restart the HBase cluster // Shut down and restart the HBase cluster
@ -148,7 +145,7 @@ public class TestMultiVersions {
table = UTIL.getConnection().getTable(desc.getTableName()); table = UTIL.getConnection().getTable(desc.getTableName());
// Overwrite previous value // Overwrite previous value
put = new Put(row, timestamp2); put = new Put(row, timestamp2);
put.add(contents, contents, value2); put.addColumn(contents, contents, value2);
table.put(put); table.put(put);
// Now verify that getRow(row, column, latest) works // Now verify that getRow(row, column, latest) works
Get get = new Get(row); Get get = new Get(row);
@ -221,7 +218,7 @@ public class TestMultiVersions {
for (int i = 0; i < startKeys.length; i++) { for (int i = 0; i < startKeys.length; i++) {
for (int j = 0; j < timestamp.length; j++) { for (int j = 0; j < timestamp.length; j++) {
Put put = new Put(rows[i], timestamp[j]); Put put = new Put(rows[i], timestamp[j]);
put.add(HConstants.CATALOG_FAMILY, null, timestamp[j], put.addColumn(HConstants.CATALOG_FAMILY, null, timestamp[j],
Bytes.toBytes(timestamp[j])); Bytes.toBytes(timestamp[j]));
puts.add(put); puts.add(put);
} }

View File

@ -24,15 +24,19 @@ import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result; import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.ResultScanner;
import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.client.Durability; import org.apache.hadoop.hbase.client.Durability;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.junit.Assert;
/** /**
* Tests user specifiable time stamps putting, getting and scanning. Also * Tests user specifiable time stamps putting, getting and scanning. Also
* tests same in presence of deletes. Test cores are written so can be * tests same in presence of deletes. Test cores are written so can be
* run against an HRegion and against an HTable: i.e. both local and remote. * run against an HRegion and against an HTable: i.e. both local and remote.
*/ */
public class TimestampTestBase extends HBaseTestCase { public class TimestampTestBase {
private static final long T0 = 10L; private static final long T0 = 10L;
private static final long T1 = 100L; private static final long T1 = 100L;
private static final long T2 = 200L; private static final long T2 = 200L;
@ -42,73 +46,73 @@ public class TimestampTestBase extends HBaseTestCase {
private static final byte [] ROW = Bytes.toBytes("row"); private static final byte [] ROW = Bytes.toBytes("row");
/* interface FlushCache {
void flushcache() throws IOException;
}
/*
* Run test that delete works according to description in <a * Run test that delete works according to description in <a
* href="https://issues.apache.org/jira/browse/HADOOP-1784">hadoop-1784</a>. * href="https://issues.apache.org/jira/browse/HADOOP-1784">hadoop-1784</a>.
* @param incommon * @param incommon
* @param flusher * @param flusher
* @throws IOException * @throws IOException
*/ */
public static void doTestDelete(final Incommon incommon, FlushCache flusher) public static void doTestDelete(final Table table, FlushCache flusher)
throws IOException { throws IOException {
// Add values at various timestamps (Values are timestampes as bytes). // Add values at various timestamps (Values are timestampes as bytes).
put(incommon, T0); put(table, T0);
put(incommon, T1); put(table, T1);
put(incommon, T2); put(table, T2);
put(incommon); put(table);
// Verify that returned versions match passed timestamps. // Verify that returned versions match passed timestamps.
assertVersions(incommon, new long [] {HConstants.LATEST_TIMESTAMP, T2, T1}); assertVersions(table, new long [] {HConstants.LATEST_TIMESTAMP, T2, T1});
// If I delete w/o specifying a timestamp, this means I'm deleting the // If I delete w/o specifying a timestamp, this means I'm deleting the latest.
// latest. delete(table);
delete(incommon); // Verify that I get back T2 through T1 -- that the latest version has been deleted.
// Verify that I get back T2 through T1 -- that the latest version has assertVersions(table, new long [] {T2, T1, T0});
// been deleted.
assertVersions(incommon, new long [] {T2, T1, T0});
// Flush everything out to disk and then retry // Flush everything out to disk and then retry
flusher.flushcache(); flusher.flushcache();
assertVersions(incommon, new long [] {T2, T1, T0}); assertVersions(table, new long [] {T2, T1, T0});
// Now add, back a latest so I can test remove other than the latest. // Now add, back a latest so I can test remove other than the latest.
put(incommon); put(table);
assertVersions(incommon, new long [] {HConstants.LATEST_TIMESTAMP, T2, T1}); assertVersions(table, new long [] {HConstants.LATEST_TIMESTAMP, T2, T1});
delete(incommon, T2); delete(table, T2);
assertVersions(incommon, new long [] {HConstants.LATEST_TIMESTAMP, T1, T0}); assertVersions(table, new long [] {HConstants.LATEST_TIMESTAMP, T1, T0});
// Flush everything out to disk and then retry // Flush everything out to disk and then retry
flusher.flushcache(); flusher.flushcache();
assertVersions(incommon, new long [] {HConstants.LATEST_TIMESTAMP, T1, T0}); assertVersions(table, new long [] {HConstants.LATEST_TIMESTAMP, T1, T0});
// Now try deleting all from T2 back inclusive (We first need to add T2 // Now try deleting all from T2 back inclusive (We first need to add T2
// back into the mix and to make things a little interesting, delete and // back into the mix and to make things a little interesting, delete and then readd T1.
// then readd T1. put(table, T2);
put(incommon, T2); delete(table, T1);
delete(incommon, T1); put(table, T1);
put(incommon, T1);
Delete delete = new Delete(ROW); Delete delete = new Delete(ROW);
delete.deleteColumns(FAMILY_NAME, QUALIFIER_NAME, T2); delete.addColumns(FAMILY_NAME, QUALIFIER_NAME, T2);
incommon.delete(delete, true); table.delete(delete);
// Should only be current value in set. Assert this is so // Should only be current value in set. Assert this is so
assertOnlyLatest(incommon, HConstants.LATEST_TIMESTAMP); assertOnlyLatest(table, HConstants.LATEST_TIMESTAMP);
// Flush everything out to disk and then redo above tests // Flush everything out to disk and then redo above tests
flusher.flushcache(); flusher.flushcache();
assertOnlyLatest(incommon, HConstants.LATEST_TIMESTAMP); assertOnlyLatest(table, HConstants.LATEST_TIMESTAMP);
} }
private static void assertOnlyLatest(final Incommon incommon, private static void assertOnlyLatest(final Table incommon, final long currentTime)
final long currentTime)
throws IOException { throws IOException {
Get get = null; Get get = null;
get = new Get(ROW); get = new Get(ROW);
get.addColumn(FAMILY_NAME, QUALIFIER_NAME); get.addColumn(FAMILY_NAME, QUALIFIER_NAME);
get.setMaxVersions(3); get.setMaxVersions(3);
Result result = incommon.get(get); Result result = incommon.get(get);
assertEquals(1, result.size()); Assert.assertEquals(1, result.size());
long time = Bytes.toLong(CellUtil.cloneValue(result.rawCells()[0])); long time = Bytes.toLong(CellUtil.cloneValue(result.rawCells()[0]));
assertEquals(time, currentTime); Assert.assertEquals(time, currentTime);
} }
/* /*
@ -119,7 +123,7 @@ public class TimestampTestBase extends HBaseTestCase {
* @param tss * @param tss
* @throws IOException * @throws IOException
*/ */
public static void assertVersions(final Incommon incommon, final long [] tss) public static void assertVersions(final Table incommon, final long [] tss)
throws IOException { throws IOException {
// Assert that 'latest' is what we expect. // Assert that 'latest' is what we expect.
Get get = null; Get get = null;
@ -128,7 +132,7 @@ public class TimestampTestBase extends HBaseTestCase {
Result r = incommon.get(get); Result r = incommon.get(get);
byte [] bytes = r.getValue(FAMILY_NAME, QUALIFIER_NAME); byte [] bytes = r.getValue(FAMILY_NAME, QUALIFIER_NAME);
long t = Bytes.toLong(bytes); long t = Bytes.toLong(bytes);
assertEquals(tss[0], t); Assert.assertEquals(tss[0], t);
// Now assert that if we ask for multiple versions, that they come out in // Now assert that if we ask for multiple versions, that they come out in
// order. // order.
@ -137,10 +141,10 @@ public class TimestampTestBase extends HBaseTestCase {
get.setMaxVersions(tss.length); get.setMaxVersions(tss.length);
Result result = incommon.get(get); Result result = incommon.get(get);
Cell [] kvs = result.rawCells(); Cell [] kvs = result.rawCells();
assertEquals(kvs.length, tss.length); Assert.assertEquals(kvs.length, tss.length);
for(int i=0;i<kvs.length;i++) { for(int i=0;i<kvs.length;i++) {
t = Bytes.toLong(CellUtil.cloneValue(kvs[i])); t = Bytes.toLong(CellUtil.cloneValue(kvs[i]));
assertEquals(tss[i], t); Assert.assertEquals(tss[i], t);
} }
// Determine highest stamp to set as next max stamp // Determine highest stamp to set as next max stamp
@ -153,10 +157,10 @@ public class TimestampTestBase extends HBaseTestCase {
get.setMaxVersions(kvs.length - 1); get.setMaxVersions(kvs.length - 1);
result = incommon.get(get); result = incommon.get(get);
kvs = result.rawCells(); kvs = result.rawCells();
assertEquals(kvs.length, tss.length - 1); Assert.assertEquals(kvs.length, tss.length - 1);
for(int i=1;i<kvs.length;i++) { for(int i=1;i<kvs.length;i++) {
t = Bytes.toLong(CellUtil.cloneValue(kvs[i-1])); t = Bytes.toLong(CellUtil.cloneValue(kvs[i-1]));
assertEquals(tss[i], t); Assert.assertEquals(tss[i], t);
} }
// Test scanner returns expected version // Test scanner returns expected version
@ -169,7 +173,7 @@ public class TimestampTestBase extends HBaseTestCase {
* @param flusher * @param flusher
* @throws IOException * @throws IOException
*/ */
public static void doTestTimestampScanning(final Incommon incommon, public static void doTestTimestampScanning(final Table incommon,
final FlushCache flusher) final FlushCache flusher)
throws IOException { throws IOException {
// Add a couple of values for three different timestamps. // Add a couple of values for three different timestamps.
@ -180,12 +184,12 @@ public class TimestampTestBase extends HBaseTestCase {
int count = assertScanContentTimestamp(incommon, int count = assertScanContentTimestamp(incommon,
HConstants.LATEST_TIMESTAMP); HConstants.LATEST_TIMESTAMP);
// Assert I get same count when I scan at each timestamp. // Assert I get same count when I scan at each timestamp.
assertEquals(count, assertScanContentTimestamp(incommon, T0)); Assert.assertEquals(count, assertScanContentTimestamp(incommon, T0));
assertEquals(count, assertScanContentTimestamp(incommon, T1)); Assert.assertEquals(count, assertScanContentTimestamp(incommon, T1));
// Flush everything out to disk and then retry // Flush everything out to disk and then retry
flusher.flushcache(); flusher.flushcache();
assertEquals(count, assertScanContentTimestamp(incommon, T0)); Assert.assertEquals(count, assertScanContentTimestamp(incommon, T0));
assertEquals(count, assertScanContentTimestamp(incommon, T1)); Assert.assertEquals(count, assertScanContentTimestamp(incommon, T1));
} }
/* /*
@ -195,10 +199,12 @@ public class TimestampTestBase extends HBaseTestCase {
* @return Count of items scanned. * @return Count of items scanned.
* @throws IOException * @throws IOException
*/ */
public static int assertScanContentTimestamp(final Incommon in, final long ts) public static int assertScanContentTimestamp(final Table in, final long ts)
throws IOException { throws IOException {
ScannerIncommon scanner = Scan scan = new Scan(HConstants.EMPTY_START_ROW);
in.getScanner(COLUMNS[0], null, HConstants.EMPTY_START_ROW, ts); scan.addFamily(FAMILY_NAME);
scan.setTimeRange(0, ts);
ResultScanner scanner = in.getScanner(scan);
int count = 0; int count = 0;
try { try {
// TODO FIX // TODO FIX
@ -221,12 +227,12 @@ public class TimestampTestBase extends HBaseTestCase {
return count; return count;
} }
public static void put(final Incommon loader, final long ts) public static void put(final Table loader, final long ts)
throws IOException { throws IOException {
put(loader, Bytes.toBytes(ts), ts); put(loader, Bytes.toBytes(ts), ts);
} }
public static void put(final Incommon loader) public static void put(final Table loader)
throws IOException { throws IOException {
long ts = HConstants.LATEST_TIMESTAMP; long ts = HConstants.LATEST_TIMESTAMP;
put(loader, Bytes.toBytes(ts), ts); put(loader, Bytes.toBytes(ts), ts);
@ -239,39 +245,39 @@ public class TimestampTestBase extends HBaseTestCase {
* @param ts * @param ts
* @throws IOException * @throws IOException
*/ */
public static void put(final Incommon loader, final byte [] bytes, public static void put(final Table loader, final byte [] bytes,
final long ts) final long ts)
throws IOException { throws IOException {
Put put = new Put(ROW, ts); Put put = new Put(ROW, ts);
put.setDurability(Durability.SKIP_WAL); put.setDurability(Durability.SKIP_WAL);
put.add(FAMILY_NAME, QUALIFIER_NAME, bytes); put.addColumn(FAMILY_NAME, QUALIFIER_NAME, bytes);
loader.put(put); loader.put(put);
} }
public static void delete(final Incommon loader) throws IOException { public static void delete(final Table loader) throws IOException {
delete(loader, null); delete(loader, null);
} }
public static void delete(final Incommon loader, final byte [] column) public static void delete(final Table loader, final byte [] column)
throws IOException { throws IOException {
delete(loader, column, HConstants.LATEST_TIMESTAMP); delete(loader, column, HConstants.LATEST_TIMESTAMP);
} }
public static void delete(final Incommon loader, final long ts) public static void delete(final Table loader, final long ts)
throws IOException { throws IOException {
delete(loader, null, ts); delete(loader, null, ts);
} }
public static void delete(final Incommon loader, final byte [] column, public static void delete(final Table loader, final byte [] column,
final long ts) final long ts)
throws IOException { throws IOException {
Delete delete = ts == HConstants.LATEST_TIMESTAMP? Delete delete = ts == HConstants.LATEST_TIMESTAMP?
new Delete(ROW): new Delete(ROW, ts); new Delete(ROW): new Delete(ROW, ts);
delete.deleteColumn(FAMILY_NAME, QUALIFIER_NAME, ts); delete.addColumn(FAMILY_NAME, QUALIFIER_NAME, ts);
loader.delete(delete, true); loader.delete(delete);
} }
public static Result get(final Incommon loader) throws IOException { public static Result get(final Table loader) throws IOException {
return loader.get(new Get(ROW)); return loader.get(new Get(ROW));
} }
} }

View File

@ -37,8 +37,6 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.concurrent.CountDownLatch; import java.util.concurrent.CountDownLatch;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FSDataOutputStream; import org.apache.hadoop.fs.FSDataOutputStream;
import org.apache.hadoop.fs.FileStatus; import org.apache.hadoop.fs.FileStatus;
@ -47,7 +45,6 @@ import org.apache.hadoop.fs.Path;
import org.apache.hadoop.hbase.ChoreService; import org.apache.hadoop.hbase.ChoreService;
import org.apache.hadoop.hbase.HBaseConfiguration; import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HBaseTestCase; import org.apache.hadoop.hbase.HBaseTestCase;
import org.apache.hadoop.hbase.HBaseTestCase.HRegionIncommon;
import org.apache.hadoop.hbase.HBaseTestingUtility; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.HConstants;
import org.apache.hadoop.hbase.HTableDescriptor; import org.apache.hadoop.hbase.HTableDescriptor;
@ -57,6 +54,7 @@ import org.apache.hadoop.hbase.testclassification.RegionServerTests;
import org.apache.hadoop.hbase.client.Delete; import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Durability; import org.apache.hadoop.hbase.client.Durability;
import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.io.hfile.HFileScanner; import org.apache.hadoop.hbase.io.hfile.HFileScanner;
import org.apache.hadoop.hbase.regionserver.compactions.CompactionContext; import org.apache.hadoop.hbase.regionserver.compactions.CompactionContext;
import org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest; import org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest;
@ -86,7 +84,6 @@ import org.mockito.stubbing.Answer;
@Category({RegionServerTests.class, MediumTests.class}) @Category({RegionServerTests.class, MediumTests.class})
public class TestCompaction { public class TestCompaction {
@Rule public TestName name = new TestName(); @Rule public TestName name = new TestName();
private static final Log LOG = LogFactory.getLog(TestCompaction.class.getName());
private static final HBaseTestingUtility UTIL = HBaseTestingUtility.createLocalHTU(); private static final HBaseTestingUtility UTIL = HBaseTestingUtility.createLocalHTU();
protected Configuration conf = UTIL.getConfiguration(); protected Configuration conf = UTIL.getConfiguration();
@ -148,15 +145,15 @@ public class TestCompaction {
int jmax = (int) Math.ceil(15.0/compactionThreshold); int jmax = (int) Math.ceil(15.0/compactionThreshold);
byte [] pad = new byte[1000]; // 1 KB chunk byte [] pad = new byte[1000]; // 1 KB chunk
for (int i = 0; i < compactionThreshold; i++) { for (int i = 0; i < compactionThreshold; i++) {
HRegionIncommon loader = new HRegionIncommon(r); Table loader = new RegionAsTable(r);
Put p = new Put(Bytes.add(STARTROW, Bytes.toBytes(i))); Put p = new Put(Bytes.add(STARTROW, Bytes.toBytes(i)));
p.setDurability(Durability.SKIP_WAL); p.setDurability(Durability.SKIP_WAL);
for (int j = 0; j < jmax; j++) { for (int j = 0; j < jmax; j++) {
p.add(COLUMN_FAMILY, Bytes.toBytes(j), pad); p.addColumn(COLUMN_FAMILY, Bytes.toBytes(j), pad);
} }
HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY)); HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY));
loader.put(p); loader.put(p);
loader.flushcache(); r.flush(true);
} }
HRegion spyR = spy(r); HRegion spyR = spy(r);
@ -230,9 +227,9 @@ public class TestCompaction {
} }
private void createStoreFile(final HRegion region, String family) throws IOException { private void createStoreFile(final HRegion region, String family) throws IOException {
HRegionIncommon loader = new HRegionIncommon(region); Table loader = new RegionAsTable(region);
HBaseTestCase.addContent(loader, family); HBaseTestCase.addContent(loader, family);
loader.flushcache(); region.flush(true);
} }
@Test @Test

View File

@ -40,7 +40,6 @@ import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell; import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil; import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.HBaseTestCase; import org.apache.hadoop.hbase.HBaseTestCase;
import org.apache.hadoop.hbase.HBaseTestCase.HRegionIncommon;
import org.apache.hadoop.hbase.HBaseTestingUtility; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.HConstants;
import org.apache.hadoop.hbase.HTableDescriptor; import org.apache.hadoop.hbase.HTableDescriptor;
@ -48,6 +47,7 @@ import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Result; import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.Scan; import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.io.encoding.DataBlockEncoding; import org.apache.hadoop.hbase.io.encoding.DataBlockEncoding;
import org.apache.hadoop.hbase.io.hfile.HFileDataBlockEncoder; import org.apache.hadoop.hbase.io.hfile.HFileDataBlockEncoder;
import org.apache.hadoop.hbase.io.hfile.HFileDataBlockEncoderImpl; import org.apache.hadoop.hbase.io.hfile.HFileDataBlockEncoderImpl;
@ -198,7 +198,7 @@ public class TestMajorCompaction {
createStoreFile(r); createStoreFile(r);
} }
// Add more content. // Add more content.
HBaseTestCase.addContent(new HRegionIncommon(r), Bytes.toString(COLUMN_FAMILY)); HBaseTestCase.addContent(new RegionAsTable(r), Bytes.toString(COLUMN_FAMILY));
// Now there are about 5 versions of each column. // Now there are about 5 versions of each column.
// Default is that there only 3 (MAXVERSIONS) versions allowed per column. // Default is that there only 3 (MAXVERSIONS) versions allowed per column.
@ -387,16 +387,16 @@ public class TestMajorCompaction {
} }
private void createStoreFile(final Region region, String family) throws IOException { private void createStoreFile(final Region region, String family) throws IOException {
HRegionIncommon loader = new HRegionIncommon(region); Table loader = new RegionAsTable(region);
HBaseTestCase.addContent(loader, family); HBaseTestCase.addContent(loader, family);
loader.flushcache(); region.flush(true);
} }
private void createSmallerStoreFile(final Region region) throws IOException { private void createSmallerStoreFile(final Region region) throws IOException {
HRegionIncommon loader = new HRegionIncommon(region); Table loader = new RegionAsTable(region);
HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY), ("" + HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY), ("" +
"bbb").getBytes(), null); "bbb").getBytes(), null);
loader.flushcache(); region.flush(true);
} }
/** /**

View File

@ -28,7 +28,6 @@ import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseTestCase; import org.apache.hadoop.hbase.HBaseTestCase;
import org.apache.hadoop.hbase.HBaseTestCase.HRegionIncommon;
import org.apache.hadoop.hbase.HBaseTestingUtility; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.HConstants;
import org.apache.hadoop.hbase.HTableDescriptor; import org.apache.hadoop.hbase.HTableDescriptor;
@ -37,6 +36,7 @@ import org.apache.hadoop.hbase.testclassification.RegionServerTests;
import org.apache.hadoop.hbase.client.Delete; import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Result; import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.wal.WAL; import org.apache.hadoop.hbase.wal.WAL;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.junit.After; import org.junit.After;
@ -162,7 +162,7 @@ public class TestMinorCompaction {
} }
private void testMinorCompactionWithDelete(Delete delete, int expectedResultsAfterDelete) throws Exception { private void testMinorCompactionWithDelete(Delete delete, int expectedResultsAfterDelete) throws Exception {
HRegionIncommon loader = new HRegionIncommon(r); Table loader = new RegionAsTable(r);
for (int i = 0; i < compactionThreshold + 1; i++) { for (int i = 0; i < compactionThreshold + 1; i++) {
HBaseTestCase.addContent(loader, Bytes.toString(fam1), Bytes.toString(col1), firstRowBytes, HBaseTestCase.addContent(loader, Bytes.toString(fam1), Bytes.toString(col1), firstRowBytes,
thirdRowBytes, i); thirdRowBytes, i);

View File

@ -38,11 +38,11 @@ import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.hbase.*; import org.apache.hadoop.hbase.*;
import org.apache.hadoop.hbase.HBaseTestCase.HRegionIncommon;
import org.apache.hadoop.hbase.client.Delete; import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Durability; import org.apache.hadoop.hbase.client.Durability;
import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Scan; import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.io.hfile.CacheConfig; import org.apache.hadoop.hbase.io.hfile.CacheConfig;
import org.apache.hadoop.hbase.io.hfile.HFile; import org.apache.hadoop.hbase.io.hfile.HFile;
import org.apache.hadoop.hbase.io.hfile.HFileContext; import org.apache.hadoop.hbase.io.hfile.HFileContext;
@ -125,12 +125,12 @@ public class TestMobStoreCompaction {
public void testSmallerValue() throws Exception { public void testSmallerValue() throws Exception {
init(UTIL.getConfiguration(), 500); init(UTIL.getConfiguration(), 500);
byte[] dummyData = makeDummyData(300); // smaller than mob threshold byte[] dummyData = makeDummyData(300); // smaller than mob threshold
HRegionIncommon loader = new HRegionIncommon(region); Table loader = new RegionAsTable(region);
// one hfile per row // one hfile per row
for (int i = 0; i < compactionThreshold; i++) { for (int i = 0; i < compactionThreshold; i++) {
Put p = createPut(i, dummyData); Put p = createPut(i, dummyData);
loader.put(p); loader.put(p);
loader.flushcache(); region.flush(true);
} }
assertEquals("Before compaction: store files", compactionThreshold, countStoreFiles()); assertEquals("Before compaction: store files", compactionThreshold, countStoreFiles());
assertEquals("Before compaction: mob file count", 0, countMobFiles()); assertEquals("Before compaction: mob file count", 0, countMobFiles());
@ -153,11 +153,11 @@ public class TestMobStoreCompaction {
public void testLargerValue() throws Exception { public void testLargerValue() throws Exception {
init(UTIL.getConfiguration(), 200); init(UTIL.getConfiguration(), 200);
byte[] dummyData = makeDummyData(300); // larger than mob threshold byte[] dummyData = makeDummyData(300); // larger than mob threshold
HRegionIncommon loader = new HRegionIncommon(region); Table loader = new RegionAsTable(region);
for (int i = 0; i < compactionThreshold; i++) { for (int i = 0; i < compactionThreshold; i++) {
Put p = createPut(i, dummyData); Put p = createPut(i, dummyData);
loader.put(p); loader.put(p);
loader.flushcache(); region.flush(true);
} }
assertEquals("Before compaction: store files", compactionThreshold, countStoreFiles()); assertEquals("Before compaction: store files", compactionThreshold, countStoreFiles());
assertEquals("Before compaction: mob file count", compactionThreshold, countMobFiles()); assertEquals("Before compaction: mob file count", compactionThreshold, countMobFiles());
@ -221,14 +221,14 @@ public class TestMobStoreCompaction {
public void testMajorCompactionAfterDelete() throws Exception { public void testMajorCompactionAfterDelete() throws Exception {
init(UTIL.getConfiguration(), 100); init(UTIL.getConfiguration(), 100);
byte[] dummyData = makeDummyData(200); // larger than mob threshold byte[] dummyData = makeDummyData(200); // larger than mob threshold
HRegionIncommon loader = new HRegionIncommon(region); Table loader = new RegionAsTable(region);
// create hfiles and mob hfiles but don't trigger compaction // create hfiles and mob hfiles but don't trigger compaction
int numHfiles = compactionThreshold - 1; int numHfiles = compactionThreshold - 1;
byte[] deleteRow = Bytes.add(STARTROW, Bytes.toBytes(0)); byte[] deleteRow = Bytes.add(STARTROW, Bytes.toBytes(0));
for (int i = 0; i < numHfiles; i++) { for (int i = 0; i < numHfiles; i++) {
Put p = createPut(i, dummyData); Put p = createPut(i, dummyData);
loader.put(p); loader.put(p);
loader.flushcache(); region.flush(true);
} }
assertEquals("Before compaction: store files", numHfiles, countStoreFiles()); assertEquals("Before compaction: store files", numHfiles, countStoreFiles());
assertEquals("Before compaction: mob file count", numHfiles, countMobFiles()); assertEquals("Before compaction: mob file count", numHfiles, countMobFiles());
@ -239,7 +239,7 @@ public class TestMobStoreCompaction {
Delete delete = new Delete(deleteRow); Delete delete = new Delete(deleteRow);
delete.addFamily(COLUMN_FAMILY); delete.addFamily(COLUMN_FAMILY);
region.delete(delete); region.delete(delete);
loader.flushcache(); region.flush(true);
assertEquals("Before compaction: store files", numHfiles + 1, countStoreFiles()); assertEquals("Before compaction: store files", numHfiles + 1, countStoreFiles());
assertEquals("Before compaction: mob files", numHfiles, countMobFiles()); assertEquals("Before compaction: mob files", numHfiles, countMobFiles());

View File

@ -36,8 +36,6 @@ import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.hbase.Cell; import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil; import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.HBaseTestCase; import org.apache.hadoop.hbase.HBaseTestCase;
import org.apache.hadoop.hbase.HBaseTestCase.HRegionIncommon;
import org.apache.hadoop.hbase.HBaseTestCase.ScannerIncommon;
import org.apache.hadoop.hbase.HBaseTestingUtility; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HColumnDescriptor; import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.HConstants;
@ -49,7 +47,9 @@ import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result; import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.ResultScanner;
import org.apache.hadoop.hbase.client.Scan; import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.filter.Filter; import org.apache.hadoop.hbase.filter.Filter;
import org.apache.hadoop.hbase.filter.InclusiveStopFilter; import org.apache.hadoop.hbase.filter.InclusiveStopFilter;
import org.apache.hadoop.hbase.filter.PrefixFilter; import org.apache.hadoop.hbase.filter.PrefixFilter;
@ -99,11 +99,10 @@ public class TestScanner {
private static final long START_CODE = Long.MAX_VALUE; private static final long START_CODE = Long.MAX_VALUE;
private Region r; private HRegion region;
private HRegionIncommon region;
private byte[] firstRowBytes, secondRowBytes, thirdRowBytes; private byte[] firstRowBytes, secondRowBytes, thirdRowBytes;
final private byte[] col1, col2; final private byte[] col1;
public TestScanner() { public TestScanner() {
super(); super();
@ -115,7 +114,6 @@ public class TestScanner {
thirdRowBytes = START_KEY_BYTES.clone(); thirdRowBytes = START_KEY_BYTES.clone();
thirdRowBytes[START_KEY_BYTES.length - 1] += 2; thirdRowBytes[START_KEY_BYTES.length - 1] += 2;
col1 = Bytes.toBytes("column1"); col1 = Bytes.toBytes("column1");
col2 = Bytes.toBytes("column2");
} }
/** /**
@ -127,14 +125,14 @@ public class TestScanner {
byte [] startrow = Bytes.toBytes("bbb"); byte [] startrow = Bytes.toBytes("bbb");
byte [] stoprow = Bytes.toBytes("ccc"); byte [] stoprow = Bytes.toBytes("ccc");
try { try {
this.r = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null); this.region = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null);
HBaseTestCase.addContent(this.r, HConstants.CATALOG_FAMILY); HBaseTestCase.addContent(this.region, HConstants.CATALOG_FAMILY);
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
// Do simple test of getting one row only first. // Do simple test of getting one row only first.
Scan scan = new Scan(Bytes.toBytes("abc"), Bytes.toBytes("abd")); Scan scan = new Scan(Bytes.toBytes("abc"), Bytes.toBytes("abd"));
scan.addFamily(HConstants.CATALOG_FAMILY); scan.addFamily(HConstants.CATALOG_FAMILY);
InternalScanner s = r.getScanner(scan); InternalScanner s = region.getScanner(scan);
int count = 0; int count = 0;
while (s.next(results)) { while (s.next(results)) {
count++; count++;
@ -145,7 +143,7 @@ public class TestScanner {
scan = new Scan(startrow, stoprow); scan = new Scan(startrow, stoprow);
scan.addFamily(HConstants.CATALOG_FAMILY); scan.addFamily(HConstants.CATALOG_FAMILY);
s = r.getScanner(scan); s = region.getScanner(scan);
count = 0; count = 0;
Cell kv = null; Cell kv = null;
results = new ArrayList<Cell>(); results = new ArrayList<Cell>();
@ -162,14 +160,14 @@ public class TestScanner {
assertTrue(count > 10); assertTrue(count > 10);
s.close(); s.close();
} finally { } finally {
HBaseTestingUtility.closeRegionAndWAL(this.r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
void rowPrefixFilter(Scan scan) throws IOException { void rowPrefixFilter(Scan scan) throws IOException {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
scan.addFamily(HConstants.CATALOG_FAMILY); scan.addFamily(HConstants.CATALOG_FAMILY);
InternalScanner s = r.getScanner(scan); InternalScanner s = region.getScanner(scan);
boolean hasMore = true; boolean hasMore = true;
while (hasMore) { while (hasMore) {
hasMore = s.next(results); hasMore = s.next(results);
@ -185,7 +183,7 @@ public class TestScanner {
void rowInclusiveStopFilter(Scan scan, byte[] stopRow) throws IOException { void rowInclusiveStopFilter(Scan scan, byte[] stopRow) throws IOException {
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
scan.addFamily(HConstants.CATALOG_FAMILY); scan.addFamily(HConstants.CATALOG_FAMILY);
InternalScanner s = r.getScanner(scan); InternalScanner s = region.getScanner(scan);
boolean hasMore = true; boolean hasMore = true;
while (hasMore) { while (hasMore) {
hasMore = s.next(results); hasMore = s.next(results);
@ -200,8 +198,8 @@ public class TestScanner {
@Test @Test
public void testFilters() throws IOException { public void testFilters() throws IOException {
try { try {
this.r = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null); this.region = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null);
HBaseTestCase.addContent(this.r, HConstants.CATALOG_FAMILY); HBaseTestCase.addContent(this.region, HConstants.CATALOG_FAMILY);
byte [] prefix = Bytes.toBytes("ab"); byte [] prefix = Bytes.toBytes("ab");
Filter newFilter = new PrefixFilter(prefix); Filter newFilter = new PrefixFilter(prefix);
Scan scan = new Scan(); Scan scan = new Scan();
@ -215,7 +213,7 @@ public class TestScanner {
rowInclusiveStopFilter(scan, stopRow); rowInclusiveStopFilter(scan, stopRow);
} finally { } finally {
HBaseTestingUtility.closeRegionAndWAL(this.r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
@ -227,10 +225,10 @@ public class TestScanner {
@Test @Test
public void testRaceBetweenClientAndTimeout() throws Exception { public void testRaceBetweenClientAndTimeout() throws Exception {
try { try {
this.r = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null); this.region = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null);
HBaseTestCase.addContent(this.r, HConstants.CATALOG_FAMILY); HBaseTestCase.addContent(this.region, HConstants.CATALOG_FAMILY);
Scan scan = new Scan(); Scan scan = new Scan();
InternalScanner s = r.getScanner(scan); InternalScanner s = region.getScanner(scan);
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
try { try {
s.next(results); s.next(results);
@ -242,7 +240,7 @@ public class TestScanner {
return; return;
} }
} finally { } finally {
HBaseTestingUtility.closeRegionAndWAL(this.r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
@ -252,71 +250,70 @@ public class TestScanner {
@Test @Test
public void testScanner() throws IOException { public void testScanner() throws IOException {
try { try {
r = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null); region = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null);
region = new HRegionIncommon(r); Table table = new RegionAsTable(region);
// Write information to the meta table // Write information to the meta table
Put put = new Put(ROW_KEY, System.currentTimeMillis()); Put put = new Put(ROW_KEY, System.currentTimeMillis());
put.add(HConstants.CATALOG_FAMILY, HConstants.REGIONINFO_QUALIFIER, put.addColumn(HConstants.CATALOG_FAMILY, HConstants.REGIONINFO_QUALIFIER,
REGION_INFO.toByteArray()); REGION_INFO.toByteArray());
region.put(put); table.put(put);
// What we just committed is in the memstore. Verify that we can get // What we just committed is in the memstore. Verify that we can get
// it back both with scanning and get // it back both with scanning and get
scan(false, null); scan(false, null);
getRegionInfo(); getRegionInfo(table);
// Close and re-open // Close and re-open
((HRegion)r).close(); ((HRegion)region).close();
r = HRegion.openHRegion(r, null); region = HRegion.openHRegion(region, null);
region = new HRegionIncommon(r); table = new RegionAsTable(region);
// Verify we can get the data back now that it is on disk. // Verify we can get the data back now that it is on disk.
scan(false, null); scan(false, null);
getRegionInfo(); getRegionInfo(table);
// Store some new information // Store some new information
String address = HConstants.LOCALHOST_IP + ":" + HBaseTestingUtility.randomFreePort(); String address = HConstants.LOCALHOST_IP + ":" + HBaseTestingUtility.randomFreePort();
put = new Put(ROW_KEY, System.currentTimeMillis()); put = new Put(ROW_KEY, System.currentTimeMillis());
put.add(HConstants.CATALOG_FAMILY, HConstants.SERVER_QUALIFIER, put.addColumn(HConstants.CATALOG_FAMILY, HConstants.SERVER_QUALIFIER,
Bytes.toBytes(address)); Bytes.toBytes(address));
// put.add(HConstants.COL_STARTCODE, Bytes.toBytes(START_CODE)); // put.add(HConstants.COL_STARTCODE, Bytes.toBytes(START_CODE));
region.put(put); table.put(put);
// Validate that we can still get the HRegionInfo, even though it is in // Validate that we can still get the HRegionInfo, even though it is in
// an older row on disk and there is a newer row in the memstore // an older row on disk and there is a newer row in the memstore
scan(true, address.toString()); scan(true, address.toString());
getRegionInfo(); getRegionInfo(table);
// flush cache // flush cache
this.region.flush(true);
region.flushcache();
// Validate again // Validate again
scan(true, address.toString()); scan(true, address.toString());
getRegionInfo(); getRegionInfo(table);
// Close and reopen // Close and reopen
((HRegion)r).close(); ((HRegion)region).close();
r = HRegion.openHRegion(r,null); region = HRegion.openHRegion(region,null);
region = new HRegionIncommon(r); table = new RegionAsTable(region);
// Validate again // Validate again
scan(true, address.toString()); scan(true, address.toString());
getRegionInfo(); getRegionInfo(table);
// Now update the information again // Now update the information again
@ -324,38 +321,37 @@ public class TestScanner {
put = new Put(ROW_KEY, System.currentTimeMillis()); put = new Put(ROW_KEY, System.currentTimeMillis());
put.add(HConstants.CATALOG_FAMILY, HConstants.SERVER_QUALIFIER, put.addColumn(HConstants.CATALOG_FAMILY, HConstants.SERVER_QUALIFIER, Bytes.toBytes(address));
Bytes.toBytes(address)); table.put(put);
region.put(put);
// Validate again // Validate again
scan(true, address.toString()); scan(true, address.toString());
getRegionInfo(); getRegionInfo(table);
// flush cache // flush cache
region.flushcache(); region.flush(true);
// Validate again // Validate again
scan(true, address.toString()); scan(true, address.toString());
getRegionInfo(); getRegionInfo(table);
// Close and reopen // Close and reopen
((HRegion)r).close(); ((HRegion)this.region).close();
r = HRegion.openHRegion(r,null); this.region = HRegion.openHRegion(region, null);
region = new HRegionIncommon(r); table = new RegionAsTable(this.region);
// Validate again // Validate again
scan(true, address.toString()); scan(true, address.toString());
getRegionInfo(); getRegionInfo(table);
} finally { } finally {
// clean up // clean up
HBaseTestingUtility.closeRegionAndWAL(r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
@ -387,7 +383,7 @@ public class TestScanner {
for (int ii = 0; ii < EXPLICIT_COLS.length; ii++) { for (int ii = 0; ii < EXPLICIT_COLS.length; ii++) {
scan.addColumn(COLS[0], EXPLICIT_COLS[ii]); scan.addColumn(COLS[0], EXPLICIT_COLS[ii]);
} }
scanner = r.getScanner(scan); scanner = region.getScanner(scan);
while (scanner.next(results)) { while (scanner.next(results)) {
assertTrue(hasColumn(results, HConstants.CATALOG_FAMILY, assertTrue(hasColumn(results, HConstants.CATALOG_FAMILY,
HConstants.REGIONINFO_QUALIFIER)); HConstants.REGIONINFO_QUALIFIER));
@ -448,10 +444,10 @@ public class TestScanner {
/** Use get to retrieve the HRegionInfo and validate it */ /** Use get to retrieve the HRegionInfo and validate it */
private void getRegionInfo() throws IOException { private void getRegionInfo(Table table) throws IOException {
Get get = new Get(ROW_KEY); Get get = new Get(ROW_KEY);
get.addColumn(HConstants.CATALOG_FAMILY, HConstants.REGIONINFO_QUALIFIER); get.addColumn(HConstants.CATALOG_FAMILY, HConstants.REGIONINFO_QUALIFIER);
Result result = region.get(get); Result result = table.get(get);
byte [] bytes = result.value(); byte [] bytes = result.value();
validateRegionInfo(bytes); validateRegionInfo(bytes);
} }
@ -464,10 +460,11 @@ public class TestScanner {
*/ */
@Test @Test
public void testScanAndSyncFlush() throws Exception { public void testScanAndSyncFlush() throws Exception {
this.r = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null); this.region = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null);
HRegionIncommon hri = new HRegionIncommon(r); Table hri = new RegionAsTable(region);
try { try {
LOG.info("Added: " + HBaseTestCase.addContent(hri, Bytes.toString(HConstants.CATALOG_FAMILY), LOG.info("Added: " +
HBaseTestCase.addContent(hri, Bytes.toString(HConstants.CATALOG_FAMILY),
Bytes.toString(HConstants.REGIONINFO_QUALIFIER))); Bytes.toString(HConstants.REGIONINFO_QUALIFIER)));
int count = count(hri, -1, false); int count = count(hri, -1, false);
assertEquals(count, count(hri, 100, false)); // do a sync flush. assertEquals(count, count(hri, 100, false)); // do a sync flush.
@ -475,7 +472,7 @@ public class TestScanner {
LOG.error("Failed", e); LOG.error("Failed", e);
throw e; throw e;
} finally { } finally {
HBaseTestingUtility.closeRegionAndWAL(this.r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
@ -487,10 +484,11 @@ public class TestScanner {
*/ */
@Test @Test
public void testScanAndRealConcurrentFlush() throws Exception { public void testScanAndRealConcurrentFlush() throws Exception {
this.r = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null); this.region = TEST_UTIL.createLocalHRegion(TESTTABLEDESC, null, null);
HRegionIncommon hri = new HRegionIncommon(r); Table hri = new RegionAsTable(region);
try { try {
LOG.info("Added: " + HBaseTestCase.addContent(hri, Bytes.toString(HConstants.CATALOG_FAMILY), LOG.info("Added: " +
HBaseTestCase.addContent(hri, Bytes.toString(HConstants.CATALOG_FAMILY),
Bytes.toString(HConstants.REGIONINFO_QUALIFIER))); Bytes.toString(HConstants.REGIONINFO_QUALIFIER)));
int count = count(hri, -1, false); int count = count(hri, -1, false);
assertEquals(count, count(hri, 100, true)); // do a true concurrent background thread flush assertEquals(count, count(hri, 100, true)); // do a true concurrent background thread flush
@ -498,7 +496,7 @@ public class TestScanner {
LOG.error("Failed", e); LOG.error("Failed", e);
throw e; throw e;
} finally { } finally {
HBaseTestingUtility.closeRegionAndWAL(this.r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
@ -512,8 +510,8 @@ public class TestScanner {
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public void testScanAndConcurrentMajorCompact() throws Exception { public void testScanAndConcurrentMajorCompact() throws Exception {
HTableDescriptor htd = TEST_UTIL.createTableDescriptor(name.getMethodName()); HTableDescriptor htd = TEST_UTIL.createTableDescriptor(name.getMethodName());
this.r = TEST_UTIL.createLocalHRegion(htd, null, null); this.region = TEST_UTIL.createLocalHRegion(htd, null, null);
HRegionIncommon hri = new HRegionIncommon(r); Table hri = new RegionAsTable(region);
try { try {
HBaseTestCase.addContent(hri, Bytes.toString(fam1), Bytes.toString(col1), HBaseTestCase.addContent(hri, Bytes.toString(fam1), Bytes.toString(col1),
@ -524,18 +522,18 @@ public class TestScanner {
Delete dc = new Delete(firstRowBytes); Delete dc = new Delete(firstRowBytes);
/* delete column1 of firstRow */ /* delete column1 of firstRow */
dc.deleteColumns(fam1, col1); dc.deleteColumns(fam1, col1);
r.delete(dc); region.delete(dc);
r.flush(true); region.flush(true);
HBaseTestCase.addContent(hri, Bytes.toString(fam1), Bytes.toString(col1), HBaseTestCase.addContent(hri, Bytes.toString(fam1), Bytes.toString(col1),
secondRowBytes, thirdRowBytes); secondRowBytes, thirdRowBytes);
HBaseTestCase.addContent(hri, Bytes.toString(fam2), Bytes.toString(col1), HBaseTestCase.addContent(hri, Bytes.toString(fam2), Bytes.toString(col1),
secondRowBytes, thirdRowBytes); secondRowBytes, thirdRowBytes);
r.flush(true); region.flush(true);
InternalScanner s = r.getScanner(new Scan()); InternalScanner s = region.getScanner(new Scan());
// run a major compact, column1 of firstRow will be cleaned. // run a major compact, column1 of firstRow will be cleaned.
r.compact(true); region.compact(true);
List<Cell> results = new ArrayList<Cell>(); List<Cell> results = new ArrayList<Cell>();
s.next(results); s.next(results);
@ -555,7 +553,7 @@ public class TestScanner {
assertTrue(CellUtil.matchingFamily(results.get(0), fam1)); assertTrue(CellUtil.matchingFamily(results.get(0), fam1));
assertTrue(CellUtil.matchingFamily(results.get(1), fam2)); assertTrue(CellUtil.matchingFamily(results.get(1), fam2));
} finally { } finally {
HBaseTestingUtility.closeRegionAndWAL(this.r); HBaseTestingUtility.closeRegionAndWAL(this.region);
} }
} }
@ -567,19 +565,20 @@ public class TestScanner {
* @return Count of rows found. * @return Count of rows found.
* @throws IOException * @throws IOException
*/ */
private int count(final HRegionIncommon hri, final int flushIndex, private int count(final Table countTable, final int flushIndex, boolean concurrent)
boolean concurrent)
throws IOException { throws IOException {
LOG.info("Taking out counting scan"); LOG.info("Taking out counting scan");
ScannerIncommon s = hri.getScanner(HConstants.CATALOG_FAMILY, EXPLICIT_COLS, Scan scan = new Scan();
HConstants.EMPTY_START_ROW, HConstants.LATEST_TIMESTAMP); for (byte [] qualifier: EXPLICIT_COLS) {
List<Cell> values = new ArrayList<Cell>(); scan.addColumn(HConstants.CATALOG_FAMILY, qualifier);
}
ResultScanner s = countTable.getScanner(scan);
int count = 0; int count = 0;
boolean justFlushed = false; boolean justFlushed = false;
while (s.next(values)) { while (s.next() != null) {
if (justFlushed) { if (justFlushed) {
LOG.info("after next() just after next flush"); LOG.info("after next() just after next flush");
justFlushed=false; justFlushed = false;
} }
count++; count++;
if (flushIndex == count) { if (flushIndex == count) {
@ -587,7 +586,7 @@ public class TestScanner {
Thread t = new Thread() { Thread t = new Thread() {
public void run() { public void run() {
try { try {
hri.flushcache(); region.flush(true);
LOG.info("Finishing flush"); LOG.info("Finishing flush");
} catch (IOException e) { } catch (IOException e) {
LOG.info("Failed flush cache"); LOG.info("Failed flush cache");
@ -607,5 +606,4 @@ public class TestScanner {
LOG.info("Found " + count + " items"); LOG.info("Found " + count + " items");
return count; return count;
} }
} }