git-svn-id: https://svn.apache.org/repos/asf/lucene/hadoop/trunk/src/contrib/hbase@585293 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
04cac52745
commit
0b92e8826a
|
@ -12,6 +12,7 @@ Trunk (unreleased changes)
|
|||
BUG FIXES
|
||||
HADOOP-2059 In tests, exceptions in min dfs shutdown should not fail test
|
||||
(e.g. nightly #272)
|
||||
HADOOP-2064 TestSplit assertion and NPE failures (Patch build #952 and #953)
|
||||
|
||||
IMPROVEMENTS
|
||||
HADOOP-2401 Add convenience put method that takes writable
|
||||
|
|
|
@ -51,8 +51,8 @@ public class MiniHBaseCluster implements HConstants {
|
|||
private boolean shutdownDFS;
|
||||
private Path parentdir;
|
||||
private MasterThread masterThread = null;
|
||||
ArrayList<RegionServerThread> regionThreads =
|
||||
new ArrayList<RegionServerThread>();
|
||||
List<RegionServerThread> regionThreads =
|
||||
java.util.Collections.synchronizedList(new ArrayList<RegionServerThread>());
|
||||
private boolean deleteOnExit = true;
|
||||
|
||||
/**
|
||||
|
@ -460,7 +460,7 @@ public class MiniHBaseCluster implements HConstants {
|
|||
}
|
||||
}
|
||||
|
||||
public ArrayList<RegionServerThread> getRegionThreads() {
|
||||
public List<RegionServerThread> getRegionThreads() {
|
||||
return this.regionThreads;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,10 +40,10 @@ public class MultiRegionTable extends HBaseTestCase {
|
|||
static final Log LOG = LogFactory.getLog(MultiRegionTable.class.getName());
|
||||
|
||||
/**
|
||||
* Make a multi-region table. Presumption is that table already exists.
|
||||
* Makes it multi-region by filling with data and provoking splits.
|
||||
* Asserts parent region is cleaned up after its daughter splits release all
|
||||
* references.
|
||||
* Make a multi-region table. Presumption is that table already exists and
|
||||
* that there is only one regionserver. Makes it multi-region by filling with
|
||||
* data and provoking splits. Asserts parent region is cleaned up after its
|
||||
* daughter splits release all references.
|
||||
* @param conf
|
||||
* @param cluster
|
||||
* @param localFs
|
||||
|
@ -75,13 +75,27 @@ public class MultiRegionTable extends HBaseTestCase {
|
|||
int count = count(meta, tableName);
|
||||
HTable t = new HTable(conf, new Text(tableName));
|
||||
addContent(new HTableIncommon(t), columnName);
|
||||
LOG.info("Finished content loading");
|
||||
|
||||
// All is running in the one JVM so I should be able to get the single
|
||||
// region instance and bring on a split.
|
||||
HRegionInfo hri =
|
||||
t.getRegionLocation(HConstants.EMPTY_START_ROW).getRegionInfo();
|
||||
HRegion r = cluster.regionThreads.get(0).getRegionServer().
|
||||
// Presumption is that there is only one regionserver.
|
||||
HRegionInfo hri = null;
|
||||
HRegion r = null;
|
||||
for (int i = 0; i < 30; i++) {
|
||||
hri = t.getRegionLocation(HConstants.EMPTY_START_ROW).getRegionInfo();
|
||||
LOG.info("Region location: " + hri);
|
||||
r = cluster.getRegionThreads().get(0).getRegionServer().
|
||||
onlineRegions.get(hri.getRegionName());
|
||||
if (r != null) {
|
||||
break;
|
||||
}
|
||||
try {
|
||||
Thread.sleep(1000);
|
||||
} catch (InterruptedException e) {
|
||||
LOG.warn("Waiting on region to come online", e);
|
||||
}
|
||||
}
|
||||
|
||||
// Flush will provoke a split next time the split-checker thread runs.
|
||||
r.flushcache(false);
|
||||
|
@ -109,6 +123,7 @@ public class MultiRegionTable extends HBaseTestCase {
|
|||
Map<Text, byte []> data = getSplitParentInfo(meta, hri);
|
||||
HRegionInfo parent =
|
||||
Writables.getHRegionInfoOrNull(data.get(HConstants.COL_REGIONINFO));
|
||||
LOG.info("Found parent region: " + parent);
|
||||
assertTrue(parent.isOffline());
|
||||
assertTrue(parent.isSplit());
|
||||
HRegionInfo splitA =
|
||||
|
@ -227,7 +242,8 @@ public class MultiRegionTable extends HBaseTestCase {
|
|||
}
|
||||
// Make sure I get the parent.
|
||||
if (hri.getRegionName().toString().
|
||||
equals(parent.getRegionName().toString())) {
|
||||
equals(parent.getRegionName().toString()) &&
|
||||
hri.getRegionId() == parent.getRegionId()) {
|
||||
return curVals;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue