HBASE-9253 clean up IT test code.

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1515207 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
eclark 2013-08-18 20:29:54 +00:00
parent 1668952866
commit e91ef96624
15 changed files with 57 additions and 64 deletions

View File

@ -167,7 +167,7 @@ public class IntegrationTestLazyCfLoading {
scf.setFilterIfMissing(true); scf.setFilterIfMissing(true);
return scf; return scf;
} }
}; }
@Before @Before
public void setUp() throws Exception { public void setUp() throws Exception {

View File

@ -85,7 +85,7 @@ public class IntegrationTestManyRegions {
LOG.info(String.format("Deleting existing table %s.", TABLE_NAME)); LOG.info(String.format("Deleting existing table %s.", TABLE_NAME));
if (admin.isTableEnabled(TABLE_NAME)) admin.disableTable(TABLE_NAME); if (admin.isTableEnabled(TABLE_NAME)) admin.disableTable(TABLE_NAME);
admin.deleteTable(TABLE_NAME); admin.deleteTable(TABLE_NAME);
LOG.info(String.format("Existing table %s deleted.")); LOG.info(String.format("Existing table %s deleted.", TABLE_NAME));
} }
LOG.info("Cluster ready"); LOG.info("Cluster ready");
} }

View File

@ -102,8 +102,8 @@ public class IntegrationTestsDriver extends AbstractHBaseTool {
IntegrationTestingUtility.setUseDistributedCluster(conf); IntegrationTestingUtility.setUseDistributedCluster(conf);
Class<?>[] classes = findIntegrationTestClasses(); Class<?>[] classes = findIntegrationTestClasses();
LOG.info("Found " + classes.length + " integration tests to run:"); LOG.info("Found " + classes.length + " integration tests to run:");
for (int i = 0; i < classes.length; i++) { for (Class<?> aClass : classes) {
LOG.info(" " + classes[i]); LOG.info(" " + aClass);
} }
JUnitCore junit = new JUnitCore(); JUnitCore junit = new JUnitCore();
junit.addListener(new TextListener(System.out)); junit.addListener(new TextListener(System.out));

View File

@ -56,7 +56,7 @@ public class Action {
initialServers = regionServers.toArray(new ServerName[regionServers.size()]); initialServers = regionServers.toArray(new ServerName[regionServers.size()]);
} }
public void perform() throws Exception { }; public void perform() throws Exception { }
/** Returns current region servers */ /** Returns current region servers */
protected ServerName[] getCurrentServers() throws IOException { protected ServerName[] getCurrentServers() throws IOException {

View File

@ -31,13 +31,11 @@ import org.apache.hadoop.hbase.util.Bytes;
* Action the adds a column family to a table. * Action the adds a column family to a table.
*/ */
public class AddColumnAction extends Action { public class AddColumnAction extends Action {
private final Random random;
private final byte[] tableName; private final byte[] tableName;
private HBaseAdmin admin; private HBaseAdmin admin;
public AddColumnAction(String tableName) { public AddColumnAction(String tableName) {
this.tableName = Bytes.toBytes(tableName); this.tableName = Bytes.toBytes(tableName);
this.random = new Random();
} }
@Override @Override

View File

@ -24,8 +24,8 @@ import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
/** /**
* Created by eclark on 8/12/13. * Action that queues a table compaction.
*/ */
public class CompactTableAction extends Action { public class CompactTableAction extends Action {
private final byte[] tableNameBytes; private final byte[] tableNameBytes;
private final int majorRatio; private final int majorRatio;

View File

@ -58,7 +58,8 @@ public class RemoveColumnAction extends Action {
} }
int index = random.nextInt(columnDescriptors.length); int index = random.nextInt(columnDescriptors.length);
while(protectedColumns.contains(columnDescriptors[index].getNameAsString())) { while(protectedColumns != null &&
protectedColumns.contains(columnDescriptors[index].getNameAsString())) {
index = random.nextInt(columnDescriptors.length); index = random.nextInt(columnDescriptors.length);
} }

View File

@ -22,8 +22,8 @@ import org.apache.hadoop.hbase.ServerName;
import org.apache.hadoop.hbase.chaos.monkies.PolicyBasedChaosMonkey; import org.apache.hadoop.hbase.chaos.monkies.PolicyBasedChaosMonkey;
/** /**
* Created by eclark on 8/12/13. * Action that restarts a random HRegionServer
*/ */
public class RestartRandomRsAction extends RestartActionBaseAction { public class RestartRandomRsAction extends RestartActionBaseAction {
public RestartRandomRsAction(long sleepTime) { public RestartRandomRsAction(long sleepTime) {
super(sleepTime); super(sleepTime);

View File

@ -20,6 +20,27 @@ package org.apache.hadoop.hbase.chaos.monkies;
import org.apache.hadoop.hbase.Stoppable; import org.apache.hadoop.hbase.Stoppable;
/**
* A utility to injects faults in a running cluster.
* <p>
* ChaosMonkey defines Action's and Policy's. Actions are sequences of events, like
* - Select a random server to kill
* - Sleep for 5 sec
* - Start the server on the same host
* Actions can also be complex events, like rolling restart of all of the servers.
* <p>
* Policies on the other hand are responsible for executing the actions based on a strategy.
* The default policy is to execute a random action every minute based on predefined action
* weights. ChaosMonkey executes predefined named policies until it is stopped. More than one
* policy can be active at any time.
* <p>
* Chaos monkey can be run from the command line, or can be invoked from integration tests.
* See {@link org.apache.hadoop.hbase.IntegrationTestIngest} or other integration tests that use
* chaos monkey for code examples.
* <p>
* ChaosMonkey class is indeed inspired by the Netflix's same-named tool:
* http://techblog.netflix.com/2012/07/chaos-monkey-released-into-wild.html
*/
public abstract class ChaosMonkey implements Stoppable { public abstract class ChaosMonkey implements Stoppable {
public abstract void start() throws Exception; public abstract void start() throws Exception;

View File

@ -30,25 +30,7 @@ import org.apache.hadoop.hbase.chaos.policies.Policy;
import org.apache.hadoop.hbase.util.Pair; import org.apache.hadoop.hbase.util.Pair;
/** /**
* A utility to injects faults in a running cluster. * Chaos monkey that given multiple policies will run actions against the cluster.
* <p>
* ChaosMonkey defines Action's and Policy's. Actions are sequences of events, like
* - Select a random server to kill
* - Sleep for 5 sec
* - Start the server on the same host
* Actions can also be complex events, like rolling restart of all of the servers.
* <p>
* Policies on the other hand are responsible for executing the actions based on a strategy.
* The default policy is to execute a random action every minute based on predefined action
* weights. ChaosMonkey executes predefined named policies until it is stopped. More than one
* policy can be active at any time.
* <p>
* Chaos monkey can be run from the command line, or can be invoked from integration tests.
* See {@link org.apache.hadoop.hbase.IntegrationTestIngest} or other integration tests that use
* chaos monkey for code examples.
* <p>
* ChaosMonkey class is indeed inspired by the Netflix's same-named tool:
* http://techblog.netflix.com/2012/07/chaos-monkey-released-into-wild.html
*/ */
public class PolicyBasedChaosMonkey extends ChaosMonkey { public class PolicyBasedChaosMonkey extends ChaosMonkey {

View File

@ -329,10 +329,6 @@ public class IntegrationTestBulkLoad extends IntegrationTestBase {
private Long order; private Long order;
public LinkKey() {
}
public LinkKey(long chainId, long order) { public LinkKey(long chainId, long order) {
this.chainId = chainId; this.chainId = chainId;
this.order = order; this.order = order;
@ -373,9 +369,6 @@ public class IntegrationTestBulkLoad extends IntegrationTestBase {
return rk; return rk;
} }
public LinkChain() {
}
public LinkChain(Long rk, Long next) { public LinkChain(Long rk, Long next) {
this.rk = rk; this.rk = rk;
this.next = next; this.next = next;
@ -416,8 +409,7 @@ public class IntegrationTestBulkLoad extends IntegrationTestBase {
LinkChain linkChain, LinkChain linkChain,
int numPartitions) { int numPartitions) {
int hash = linkKey.getChainId().hashCode(); int hash = linkKey.getChainId().hashCode();
int partition = hash % numPartitions; return hash % numPartitions;
return partition;
} }
} }

View File

@ -339,7 +339,9 @@ public class IntegrationTestImportTsv implements Configurable, Tool {
fout.write(Bytes.toBytes("testRunFromOutputCommitter\n")); fout.write(Bytes.toBytes("testRunFromOutputCommitter\n"));
LOG.debug(format("Wrote test data to file: %s", inputPath)); LOG.debug(format("Wrote test data to file: %s", inputPath));
} finally { } finally {
fout.close(); if (fout != null) {
fout.close();
}
} }
// create a parent job that ships the HBase dependencies. This is // create a parent job that ships the HBase dependencies. This is

View File

@ -445,7 +445,7 @@ public class IntegrationTestMTTR {
rs = table.getScanner(s); rs = table.getScanner(s);
Result result = rs.next(); Result result = rs.next();
return rs != null && result != null && result.size() > 0; return result != null && result.size() > 0;
} finally { } finally {
if (rs != null) { if (rs != null) {
rs.close(); rs.close();
@ -510,7 +510,6 @@ public class IntegrationTestMTTR {
@Override @Override
public Boolean call() throws Exception { public Boolean call() throws Exception {
int colsPerKey = 10; int colsPerKey = 10;
int recordSize = 500;
int numServers = util.getHBaseClusterInterface().getInitialClusterStatus().getServersSize(); int numServers = util.getHBaseClusterInterface().getInitialClusterStatus().getServersSize();
int numKeys = numServers * 5000; int numKeys = numServers * 5000;
int writeThreads = 10; int writeThreads = 10;
@ -521,7 +520,7 @@ public class IntegrationTestMTTR {
do { do {
int ret = loadTool.run(new String[]{ int ret = loadTool.run(new String[]{
"-tn", loadTableName.getNameAsString(), "-tn", loadTableName.getNameAsString(),
"-write", String.format("%d:%d:%d", colsPerKey, recordSize, writeThreads), "-write", String.format("%d:%d:%d", colsPerKey, 500, writeThreads),
"-num_keys", String.valueOf(numKeys), "-num_keys", String.valueOf(numKeys),
"-skip_init" "-skip_init"
}); });

View File

@ -28,6 +28,7 @@ import java.util.Random;
import java.util.Set; import java.util.Set;
import java.util.UUID; import java.util.UUID;
import com.google.common.collect.Sets;
import org.apache.commons.cli.CommandLine; import org.apache.commons.cli.CommandLine;
import org.apache.commons.cli.GnuParser; import org.apache.commons.cli.GnuParser;
import org.apache.commons.cli.HelpFormatter; import org.apache.commons.cli.HelpFormatter;
@ -204,10 +205,6 @@ public class IntegrationTestBigLinkedList extends IntegrationTestBase {
private static final Log LOG = LogFactory.getLog(Generator.class); private static final Log LOG = LogFactory.getLog(Generator.class);
public static enum Counts {
UNREFERENCED, UNDEFINED, REFERENCED, CORRUPT
}
static class GeneratorInputFormat extends InputFormat<BytesWritable,NullWritable> { static class GeneratorInputFormat extends InputFormat<BytesWritable,NullWritable> {
static class GeneratorInputSplit extends InputSplit implements Writable { static class GeneratorInputSplit extends InputSplit implements Writable {
@Override @Override
@ -322,7 +319,6 @@ public class IntegrationTestBigLinkedList extends IntegrationTestBase {
*/ */
static class GeneratorMapper static class GeneratorMapper
extends Mapper<BytesWritable, NullWritable, NullWritable, NullWritable> { extends Mapper<BytesWritable, NullWritable, NullWritable, NullWritable> {
Random rand = new Random();
byte[][] first = null; byte[][] first = null;
byte[][] prev = null; byte[][] prev = null;
@ -350,11 +346,11 @@ public class IntegrationTestBigLinkedList extends IntegrationTestBase {
if (this.numNodes < this.wrap) { if (this.numNodes < this.wrap) {
this.wrap = this.numNodes; this.wrap = this.numNodes;
} }
}; }
protected void cleanup(Context context) throws IOException ,InterruptedException { protected void cleanup(Context context) throws IOException ,InterruptedException {
table.close(); table.close();
}; }
@Override @Override
protected void map(BytesWritable key, NullWritable value, Context output) throws IOException { protected void map(BytesWritable key, NullWritable value, Context output) throws IOException {
@ -593,7 +589,9 @@ public class IntegrationTestBigLinkedList extends IntegrationTestBase {
context.getCounter(Counts.UNREFERENCED).increment(1); context.getCounter(Counts.UNREFERENCED).increment(1);
} else { } else {
if (refs.size() > 1) { if (refs.size() > 1) {
context.write(new Text(keyString), new Text(refsSb.toString())); if (refsSb != null) {
context.write(new Text(keyString), new Text(refsSb.toString()));
}
context.getCounter(Counts.EXTRAREFERENCES).increment(refs.size() - 1); context.getCounter(Counts.EXTRAREFERENCES).increment(refs.size() - 1);
} }
// node is defined and referenced // node is defined and referenced
@ -1067,18 +1065,18 @@ public class IntegrationTestBigLinkedList extends IntegrationTestBase {
@Override @Override
protected Set<String> getColumnFamilies() { protected Set<String> getColumnFamilies() {
return null; return Sets.newHashSet(Bytes.toString(FAMILY_NAME));
} }
private static void setJobConf(Job job, int numMappers, long numNodes, private static void setJobConf(Job job, int numMappers, long numNodes,
Integer width, Integer wrapMuplitplier) { Integer width, Integer wrapMultiplier) {
job.getConfiguration().setInt(GENERATOR_NUM_MAPPERS_KEY, numMappers); job.getConfiguration().setInt(GENERATOR_NUM_MAPPERS_KEY, numMappers);
job.getConfiguration().setLong(GENERATOR_NUM_ROWS_PER_MAP_KEY, numNodes); job.getConfiguration().setLong(GENERATOR_NUM_ROWS_PER_MAP_KEY, numNodes);
if (width != null) { if (width != null) {
job.getConfiguration().setInt(GENERATOR_WIDTH_KEY, width.intValue()); job.getConfiguration().setInt(GENERATOR_WIDTH_KEY, width);
} }
if (wrapMuplitplier != null) { if (wrapMultiplier != null) {
job.getConfiguration().setInt(GENERATOR_WRAP_KEY, wrapMuplitplier.intValue()); job.getConfiguration().setInt(GENERATOR_WRAP_KEY, wrapMultiplier);
} }
} }

View File

@ -24,7 +24,6 @@ import java.util.UUID;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import com.google.common.collect.Lists;
import com.google.common.collect.Sets; import com.google.common.collect.Sets;
import org.apache.commons.cli.CommandLine; import org.apache.commons.cli.CommandLine;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
@ -114,7 +113,7 @@ public class IntegrationTestLoadAndVerify extends IntegrationTestBase {
private enum Counters { private enum Counters {
ROWS_WRITTEN, ROWS_WRITTEN,
REFERENCES_WRITTEN, REFERENCES_WRITTEN,
REFERENCES_CHECKED; REFERENCES_CHECKED
} }
@Before @Before
@ -122,9 +121,11 @@ public class IntegrationTestLoadAndVerify extends IntegrationTestBase {
util = getTestingUtil(getConf()); util = getTestingUtil(getConf());
util.initializeCluster(3); util.initializeCluster(3);
this.setConf(util.getConfiguration()); this.setConf(util.getConfiguration());
getConf().setLong(NUM_TO_WRITE_KEY, NUM_TO_WRITE_DEFAULT / 100); if (!util.isDistributedCluster()) {
getConf().setInt(NUM_MAP_TASKS_KEY, NUM_MAP_TASKS_DEFAULT / 100); getConf().setLong(NUM_TO_WRITE_KEY, NUM_TO_WRITE_DEFAULT / 100);
getConf().setInt(NUM_REDUCE_TASKS_KEY, NUM_REDUCE_TASKS_DEFAULT / 10); getConf().setInt(NUM_MAP_TASKS_KEY, NUM_MAP_TASKS_DEFAULT / 100);
getConf().setInt(NUM_REDUCE_TASKS_KEY, NUM_REDUCE_TASKS_DEFAULT / 10);
}
} }
/** /**
@ -360,8 +361,7 @@ public class IntegrationTestLoadAndVerify extends IntegrationTestBase {
htd.addFamily(new HColumnDescriptor(TEST_FAMILY)); htd.addFamily(new HColumnDescriptor(TEST_FAMILY));
HBaseAdmin admin = getTestingUtil(getConf()).getHBaseAdmin(); HBaseAdmin admin = getTestingUtil(getConf()).getHBaseAdmin();
int numPreCreate = 40; admin.createTable(htd, Bytes.toBytes(0L), Bytes.toBytes(-1L), 40);
admin.createTable(htd, Bytes.toBytes(0L), Bytes.toBytes(-1L), numPreCreate);
doLoad(getConf(), htd); doLoad(getConf(), htd);
doVerify(getConf(), htd); doVerify(getConf(), htd);