HBASE-9836 Intermittent TestRegionObserverScannerOpenHook#testRegionObserverCompactionTimeStacking failure

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1536583 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Zhihong Yu 2013-10-29 02:50:49 +00:00
parent 322eec45f8
commit 3bebeca24d
1 changed files with 35 additions and 2 deletions

View File

@ -26,8 +26,10 @@ import java.io.IOException;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.NavigableSet; import java.util.NavigableSet;
import java.util.concurrent.CountDownLatch;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.hbase.Cell; import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.Coprocessor; import org.apache.hadoop.hbase.Coprocessor;
@ -53,9 +55,12 @@ import org.apache.hadoop.hbase.regionserver.HStore;
import org.apache.hadoop.hbase.regionserver.InternalScanner; import org.apache.hadoop.hbase.regionserver.InternalScanner;
import org.apache.hadoop.hbase.regionserver.KeyValueScanner; import org.apache.hadoop.hbase.regionserver.KeyValueScanner;
import org.apache.hadoop.hbase.regionserver.RegionCoprocessorHost; import org.apache.hadoop.hbase.regionserver.RegionCoprocessorHost;
import org.apache.hadoop.hbase.regionserver.RegionServerServices;
import org.apache.hadoop.hbase.regionserver.ScanType; import org.apache.hadoop.hbase.regionserver.ScanType;
import org.apache.hadoop.hbase.regionserver.Store; import org.apache.hadoop.hbase.regionserver.Store;
import org.apache.hadoop.hbase.regionserver.StoreScanner; import org.apache.hadoop.hbase.regionserver.StoreScanner;
import org.apache.hadoop.hbase.regionserver.compactions.CompactionContext;
import org.apache.hadoop.hbase.regionserver.wal.HLog;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.junit.Test; import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
@ -203,6 +208,31 @@ public class TestRegionObserverScannerOpenHook {
+ r, r.listCells()); + r, r.listCells());
} }
/*
* Custom HRegion which uses CountDownLatch to signal the completion of compaction
*/
public static class CompactionCompletionNotifyingRegion extends HRegion {
private static volatile CountDownLatch compactionStateChangeLatch = null;
@SuppressWarnings("deprecation")
public CompactionCompletionNotifyingRegion(Path tableDir, HLog log,
FileSystem fs, Configuration confParam, HRegionInfo info,
HTableDescriptor htd, RegionServerServices rsServices) {
super(tableDir, log, fs, confParam, info, htd, rsServices);
}
public CountDownLatch getCompactionStateChangeLatch() {
if (compactionStateChangeLatch == null) compactionStateChangeLatch = new CountDownLatch(1);
return compactionStateChangeLatch;
}
@Override
public boolean compact(CompactionContext compaction, Store store) throws IOException {
boolean ret = super.compact(compaction, store);
if (ret) compactionStateChangeLatch.countDown();
return ret;
}
}
/** /**
* Unfortunately, the easiest way to test this is to spin up a mini-cluster since we want to do * Unfortunately, the easiest way to test this is to spin up a mini-cluster since we want to do
* the usual compaction mechanism on the region, rather than going through the backdoor to the * the usual compaction mechanism on the region, rather than going through the backdoor to the
@ -212,6 +242,7 @@ public class TestRegionObserverScannerOpenHook {
public void testRegionObserverCompactionTimeStacking() throws Exception { public void testRegionObserverCompactionTimeStacking() throws Exception {
// setup a mini cluster so we can do a real compaction on a region // setup a mini cluster so we can do a real compaction on a region
Configuration conf = UTIL.getConfiguration(); Configuration conf = UTIL.getConfiguration();
conf.setClass(HConstants.REGION_IMPL, CompactionCompletionNotifyingRegion.class, HRegion.class);
conf.setInt("hbase.hstore.compaction.min", 2); conf.setInt("hbase.hstore.compaction.min", 2);
UTIL.startMiniCluster(); UTIL.startMiniCluster();
String tableName = "testRegionObserverCompactionTimeStacking"; String tableName = "testRegionObserverCompactionTimeStacking";
@ -239,6 +270,8 @@ public class TestRegionObserverScannerOpenHook {
assertEquals("More than 1 region serving test table with 1 row", 1, regions.size()); assertEquals("More than 1 region serving test table with 1 row", 1, regions.size());
HRegion region = regions.get(0); HRegion region = regions.get(0);
admin.flush(region.getRegionName()); admin.flush(region.getRegionName());
CountDownLatch latch = ((CompactionCompletionNotifyingRegion)region)
.getCompactionStateChangeLatch();
// put another row and flush that too // put another row and flush that too
put = new Put(Bytes.toBytes("anotherrow")); put = new Put(Bytes.toBytes("anotherrow"));
@ -249,7 +282,7 @@ public class TestRegionObserverScannerOpenHook {
// run a compaction, which normally would should get rid of the data // run a compaction, which normally would should get rid of the data
// wait for the compaction checker to complete // wait for the compaction checker to complete
Thread.sleep(1000); latch.await();
// check both rows to ensure that they aren't there // check both rows to ensure that they aren't there
Get get = new Get(ROW); Get get = new Get(ROW);
Result r = table.get(get); Result r = table.get(get);