HBASE-9686 More temporary test files are being left in /tmp/hbase-<user>

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1528984 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Jonathan Hsieh 2013-10-03 19:47:09 +00:00
parent 04de6764ac
commit 3be068f6da
12 changed files with 976 additions and 938 deletions

View File

@ -254,7 +254,7 @@ public abstract class HBaseTestCase extends TestCase {
* @throws IOException * @throws IOException
* @return count of what we added. * @return count of what we added.
*/ */
protected static long addContent(final Incommon updater, public static long addContent(final Incommon 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);
} }
@ -275,7 +275,7 @@ public abstract class HBaseTestCase extends TestCase {
* @return count of what we added. * @return count of what we added.
* @throws IOException * @throws IOException
*/ */
protected static long addContent(final Incommon updater, final String columnFamily, public static long addContent(final Incommon 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);
@ -299,8 +299,8 @@ public abstract class HBaseTestCase extends TestCase {
* @return count of what we added. * @return count of what we added.
* @throws IOException * @throws IOException
*/ */
protected static long addContent(final Incommon updater, public static long addContent(final Incommon 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)
throws IOException { throws IOException {
@ -573,26 +573,6 @@ public abstract class HBaseTestCase extends TestCase {
} }
} }
// protected void assertCellEquals(final HRegion region, final byte [] row,
// final byte [] column, final long timestamp, final String value)
// throws IOException {
// Map<byte [], Cell> result = region.getFull(row, null, timestamp, 1, null);
// Cell cell_value = result.get(column);
// if (value == null) {
// assertEquals(Bytes.toString(column) + " at timestamp " + timestamp, null,
// cell_value);
// } else {
// if (cell_value == null) {
// fail(Bytes.toString(column) + " at timestamp " + timestamp +
// "\" was expected to be \"" + value + " but was null");
// }
// if (cell_value != null) {
// assertEquals(Bytes.toString(column) + " at timestamp "
// + timestamp, value, new String(cell_value.getValue()));
// }
// }
// }
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)

View File

@ -82,6 +82,7 @@ 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.MultiVersionConsistencyControl; import org.apache.hadoop.hbase.regionserver.MultiVersionConsistencyControl;
import org.apache.hadoop.hbase.regionserver.RegionServerServices; import org.apache.hadoop.hbase.regionserver.RegionServerServices;
import org.apache.hadoop.hbase.regionserver.wal.HLog;
import org.apache.hadoop.hbase.security.User; import org.apache.hadoop.hbase.security.User;
import org.apache.hadoop.hbase.tool.Canary; import org.apache.hadoop.hbase.tool.Canary;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
@ -125,7 +126,7 @@ import org.apache.zookeeper.ZooKeeper.States;
@InterfaceAudience.Public @InterfaceAudience.Public
@InterfaceStability.Evolving @InterfaceStability.Evolving
public class HBaseTestingUtility extends HBaseCommonTestingUtility { public class HBaseTestingUtility extends HBaseCommonTestingUtility {
private Configuration conf; protected Configuration conf;
private MiniZooKeeperCluster zkCluster = null; private MiniZooKeeperCluster zkCluster = null;
/** /**
@ -1503,9 +1504,10 @@ public class HBaseTestingUtility extends HBaseCommonTestingUtility {
public static final byte[][] COLUMNS = {fam1, fam2, fam3}; public static final byte[][] COLUMNS = {fam1, fam2, fam3};
private static final int MAXVERSIONS = 3; private static final int MAXVERSIONS = 3;
private static final char FIRST_CHAR = 'a'; public static final char FIRST_CHAR = 'a';
public static final char LAST_CHAR = 'z';
public static final byte [] START_KEY_BYTES = {FIRST_CHAR, FIRST_CHAR, FIRST_CHAR}; public static final byte [] START_KEY_BYTES = {FIRST_CHAR, FIRST_CHAR, FIRST_CHAR};
public static final String START_KEY = new String(START_KEY_BYTES, HConstants.UTF8_CHARSET);
/** /**
* Create a table of name <code>name</code> with {@link COLUMNS} for * Create a table of name <code>name</code> with {@link COLUMNS} for
@ -1565,7 +1567,47 @@ public class HBaseTestingUtility extends HBaseCommonTestingUtility {
public HRegion createLocalHRegion(HRegionInfo info, HTableDescriptor desc) throws IOException { public HRegion createLocalHRegion(HRegionInfo info, HTableDescriptor desc) throws IOException {
return HRegion.createHRegion(info, getDataTestDir(), getConfiguration(), desc); return HRegion.createHRegion(info, getDataTestDir(), getConfiguration(), desc);
} }
/**
* Create an HRegion that writes to the local tmp dirs with specified hlog
* @param info regioninfo
* @param desc table descriptor
* @param hlog hlog for this region.
* @return created hregion
* @throws IOException
*/
public HRegion createLocalHRegion(HRegionInfo info, HTableDescriptor desc, HLog hlog) throws IOException {
return HRegion.createHRegion(info, getDataTestDir(), getConfiguration(), desc, hlog);
}
/**
* @param tableName
* @param startKey
* @param stopKey
* @param callingMethod
* @param conf
* @param isReadOnly
* @param families
* @throws IOException
* @return A region on which you must call
* {@link HRegion#closeHRegion(HRegion)} when done.
*/
public HRegion createLocalHRegion(byte[] tableName, byte[] startKey, byte[] stopKey,
String callingMethod, Configuration conf, boolean isReadOnly, Durability durability,
HLog hlog, byte[]... families) throws IOException {
HTableDescriptor htd = new HTableDescriptor(TableName.valueOf(tableName));
htd.setReadOnly(isReadOnly);
for (byte[] family : families) {
HColumnDescriptor hcd = new HColumnDescriptor(family);
// Set default to be three versions.
hcd.setMaxVersions(Integer.MAX_VALUE);
htd.addFamily(hcd);
}
htd.setDurability(durability);
HRegionInfo info = new HRegionInfo(htd.getTableName(), startKey, stopKey, false);
return createLocalHRegion(info, htd, hlog);
}
// //
// ========================================================================== // ==========================================================================

View File

@ -53,7 +53,7 @@ import org.junit.runners.Parameterized.Parameters;
@RunWith(Parameterized.class) @RunWith(Parameterized.class)
@Category(SmallTests.class) @Category(SmallTests.class)
public class TestScannerSelectionUsingKeyRange { public class TestScannerSelectionUsingKeyRange {
private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility(); private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility().createLocalHTU();
private static TableName TABLE = TableName.valueOf("myTable"); private static TableName TABLE = TableName.valueOf("myTable");
private static String FAMILY = "myCF"; private static String FAMILY = "myCF";
private static byte[] FAMILY_BYTES = Bytes.toBytes(FAMILY); private static byte[] FAMILY_BYTES = Bytes.toBytes(FAMILY);

View File

@ -61,7 +61,7 @@ public class TestScannerSelectionUsingTTL {
LogFactory.getLog(TestScannerSelectionUsingTTL.class); LogFactory.getLog(TestScannerSelectionUsingTTL.class);
private static final HBaseTestingUtility TEST_UTIL = private static final HBaseTestingUtility TEST_UTIL =
new HBaseTestingUtility(); new HBaseTestingUtility().createLocalHTU();
private static TableName TABLE = TableName.valueOf("myTable"); private static TableName TABLE = TableName.valueOf("myTable");
private static String FAMILY = "myCF"; private static String FAMILY = "myCF";
private static byte[] FAMILY_BYTES = Bytes.toBytes(FAMILY); private static byte[] FAMILY_BYTES = Bytes.toBytes(FAMILY);

View File

@ -20,27 +20,29 @@
package org.apache.hadoop.hbase.master.handler; package org.apache.hadoop.hbase.master.handler;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import java.io.IOException; import java.io.IOException;
import java.util.Set; import java.util.Set;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.hbase.TableName;
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.HTableDescriptor; import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.LargeTests; import org.apache.hadoop.hbase.LargeTests;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.HBaseAdmin; import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.master.MasterFileSystem; import org.apache.hadoop.hbase.master.MasterFileSystem;
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.junit.AfterClass; import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass; import org.junit.BeforeClass;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
import org.junit.rules.TestName;
/** /**
* Verify that the HTableDescriptor is updated after * Verify that the HTableDescriptor is updated after
@ -48,10 +50,10 @@ import org.junit.experimental.categories.Category;
*/ */
@Category(LargeTests.class) @Category(LargeTests.class)
public class TestTableDescriptorModification { public class TestTableDescriptorModification {
@Rule public TestName name = new TestName();
private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility(); private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility();
private static final TableName TABLE_NAME = private static TableName TABLE_NAME = null;
TableName.valueOf("table");
private static final byte[] FAMILY_0 = Bytes.toBytes("cf0"); private static final byte[] FAMILY_0 = Bytes.toBytes("cf0");
private static final byte[] FAMILY_1 = Bytes.toBytes("cf1"); private static final byte[] FAMILY_1 = Bytes.toBytes("cf1");
@ -65,6 +67,12 @@ public class TestTableDescriptorModification {
TEST_UTIL.startMiniCluster(1); TEST_UTIL.startMiniCluster(1);
} }
@Before
public void setup() {
TABLE_NAME = TableName.valueOf(name.getMethodName());
}
@AfterClass @AfterClass
public static void afterAllTests() throws Exception { public static void afterAllTests() throws Exception {
TEST_UTIL.shutdownMiniCluster(); TEST_UTIL.shutdownMiniCluster();

View File

@ -38,7 +38,6 @@ 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.CellUtil; import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.HBaseConfiguration;
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;
@ -51,6 +50,7 @@ import org.apache.hadoop.hbase.MultithreadedTestUtil.TestThread;
import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.Append; import org.apache.hadoop.hbase.client.Append;
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.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Increment; import org.apache.hadoop.hbase.client.Increment;
import org.apache.hadoop.hbase.client.Mutation; import org.apache.hadoop.hbase.client.Mutation;
@ -63,6 +63,7 @@ import org.apache.hadoop.hbase.filter.CompareFilter.CompareOp;
import org.apache.hadoop.hbase.io.HeapSize; import org.apache.hadoop.hbase.io.HeapSize;
import org.apache.hadoop.hbase.regionserver.wal.HLog; 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.Before;
import org.junit.Rule; import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
@ -79,12 +80,10 @@ public class TestAtomicOperation {
@Rule public TestName name = new TestName(); @Rule public TestName name = new TestName();
HRegion region = null; HRegion region = null;
private HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility(); private HBaseTestingUtility TEST_UTIL = HBaseTestingUtility.createLocalHTU();
private final String DIR = TEST_UTIL.getDataTestDir("TestAtomicOperation").toString();
// Test names // Test names
static final byte[] tableName = Bytes.toBytes("testtable");; static byte[] tableName;
static final byte[] qual1 = Bytes.toBytes("qual1"); static final byte[] qual1 = Bytes.toBytes("qual1");
static final byte[] qual2 = Bytes.toBytes("qual2"); static final byte[] qual2 = Bytes.toBytes("qual2");
static final byte[] qual3 = Bytes.toBytes("qual3"); static final byte[] qual3 = Bytes.toBytes("qual3");
@ -93,6 +92,11 @@ public class TestAtomicOperation {
static final byte [] row = Bytes.toBytes("rowA"); static final byte [] row = Bytes.toBytes("rowA");
static final byte [] row2 = Bytes.toBytes("rowB"); static final byte [] row2 = Bytes.toBytes("rowB");
@Before
public void setup() {
tableName = Bytes.toBytes(name.getMethodName());
}
////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////
// New tests that doesn't spin up a mini cluster but rather just test the // New tests that doesn't spin up a mini cluster but rather just test the
// individual code pieces in the HRegion. // individual code pieces in the HRegion.
@ -196,14 +200,7 @@ public class TestAtomicOperation {
htd.addFamily(hcd); htd.addFamily(hcd);
} }
HRegionInfo info = new HRegionInfo(htd.getTableName(), null, null, false); HRegionInfo info = new HRegionInfo(htd.getTableName(), null, null, false);
Path path = new Path(DIR + callingMethod); region = TEST_UTIL.createLocalHRegion(info, htd);
FileSystem fs = TEST_UTIL.getTestFileSystem();
if (fs.exists(path)) {
if (!fs.delete(path, true)) {
throw new IOException("Failed delete of " + path);
}
}
region = HRegion.createHRegion(info, path, HBaseConfiguration.create(), htd);
} }
/** /**
@ -521,10 +518,10 @@ public class TestAtomicOperation {
public void testPutAndCheckAndPutInParallel() throws Exception { public void testPutAndCheckAndPutInParallel() throws Exception {
final String tableName = "testPutAndCheckAndPut"; final String tableName = "testPutAndCheckAndPut";
Configuration conf = HBaseConfiguration.create(); Configuration conf = TEST_UTIL.getConfiguration();
conf.setClass(HConstants.REGION_IMPL, MockHRegion.class, HeapSize.class); conf.setClass(HConstants.REGION_IMPL, MockHRegion.class, HeapSize.class);
final MockHRegion region = (MockHRegion) TestHRegion.initHRegion( final MockHRegion region = (MockHRegion) TEST_UTIL.createLocalHRegion(Bytes.toBytes(tableName),
Bytes.toBytes(tableName), tableName, conf, Bytes.toBytes(family)); null, null, tableName, conf, false, Durability.SYNC_WAL, null, Bytes.toBytes(family));
Put[] puts = new Put[1]; Put[] puts = new Put[1];
Put put = new Put(Bytes.toBytes("r1")); Put put = new Put(Bytes.toBytes("r1"));

View File

@ -54,8 +54,10 @@ import org.apache.hadoop.hbase.regionserver.wal.HLogFactory;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.junit.After; import org.junit.After;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
import org.junit.rules.TestName;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.junit.runners.Parameterized; import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters; import org.junit.runners.Parameterized.Parameters;
@ -69,10 +71,11 @@ import org.junit.runners.Parameterized.Parameters;
public class TestCacheOnWriteInSchema { public class TestCacheOnWriteInSchema {
private static final Log LOG = LogFactory.getLog(TestCacheOnWriteInSchema.class); private static final Log LOG = LogFactory.getLog(TestCacheOnWriteInSchema.class);
@Rule public TestName name = new TestName();
private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility(); private static final HBaseTestingUtility TEST_UTIL = HBaseTestingUtility.createLocalHTU();
private static final String DIR = TEST_UTIL.getDataTestDir("TestCacheOnWriteInSchema").toString(); private static final String DIR = TEST_UTIL.getDataTestDir("TestCacheOnWriteInSchema").toString();
private static final byte [] table = Bytes.toBytes("table"); private static byte [] table;
private static byte [] family = Bytes.toBytes("family"); private static byte [] family = Bytes.toBytes("family");
private static final int NUM_KV = 25000; private static final int NUM_KV = 25000;
private static final Random rand = new Random(12983177L); private static final Random rand = new Random(12983177L);
@ -141,6 +144,9 @@ public class TestCacheOnWriteInSchema {
@Before @Before
public void setUp() throws IOException { public void setUp() throws IOException {
// parameterized tests add [#] suffix get rid of [ and ].
table = Bytes.toBytes(name.getMethodName().replaceAll("[\\[\\]]", "_"));
conf = TEST_UTIL.getConfiguration(); conf = TEST_UTIL.getConfiguration();
conf.setInt(HFile.FORMAT_VERSION_KEY, HFile.MAX_FORMAT_VERSION); conf.setInt(HFile.FORMAT_VERSION_KEY, HFile.MAX_FORMAT_VERSION);
conf.setBoolean(CacheConfig.CACHE_BLOCKS_ON_WRITE_KEY, false); conf.setBoolean(CacheConfig.CACHE_BLOCKS_ON_WRITE_KEY, false);
@ -165,7 +171,7 @@ public class TestCacheOnWriteInSchema {
HRegionInfo info = new HRegionInfo(htd.getTableName(), null, null, false); HRegionInfo info = new HRegionInfo(htd.getTableName(), null, null, false);
hlog = HLogFactory.createHLog(fs, basedir, logName, conf); hlog = HLogFactory.createHLog(fs, basedir, logName, conf);
region = new HRegion(basedir, hlog, fs, conf, info, htd, null); region = TEST_UTIL.createLocalHRegion(info, htd, hlog);
store = new HStore(region, hcd, conf); store = new HStore(region, hcd, conf);
} }

View File

@ -18,9 +18,20 @@
*/ */
package org.apache.hadoop.hbase.regionserver; package org.apache.hadoop.hbase.regionserver;
import static org.mockito.AdditionalMatchers.aryEq; import static org.apache.hadoop.hbase.HBaseTestingUtility.START_KEY;
import static org.mockito.Matchers.*; import static org.apache.hadoop.hbase.HBaseTestingUtility.START_KEY_BYTES;
import static org.mockito.Mockito.*; import static org.apache.hadoop.hbase.HBaseTestingUtility.fam1;
import static org.apache.hadoop.hbase.HBaseTestingUtility.fam2;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import static org.mockito.Matchers.any;
import static org.mockito.Mockito.doAnswer;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
@ -43,17 +54,17 @@ import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil; import org.apache.hadoop.hbase.CellUtil;
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;
import org.apache.hadoop.hbase.KeyValue;
import org.apache.hadoop.hbase.MediumTests; import org.apache.hadoop.hbase.MediumTests;
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.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.Scan; import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Durability;
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;
@ -67,8 +78,13 @@ import org.apache.hadoop.hbase.regionserver.wal.HLog;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.apache.hadoop.hbase.util.Pair; import org.apache.hadoop.hbase.util.Pair;
import org.apache.hadoop.hbase.util.Threads; import org.apache.hadoop.hbase.util.Threads;
import org.junit.After;
import org.junit.Assume; import org.junit.Assume;
import org.junit.Before;
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.mockito.Mockito; import org.mockito.Mockito;
import org.mockito.invocation.InvocationOnMock; import org.mockito.invocation.InvocationOnMock;
import org.mockito.stubbing.Answer; import org.mockito.stubbing.Answer;
@ -78,10 +94,12 @@ import org.mockito.stubbing.Answer;
* Test compactions * Test compactions
*/ */
@Category(MediumTests.class) @Category(MediumTests.class)
public class TestCompaction extends HBaseTestCase { public class TestCompaction {
@Rule public TestName name = new TestName();
static final Log LOG = LogFactory.getLog(TestCompaction.class.getName()); static final Log LOG = LogFactory.getLog(TestCompaction.class.getName());
private static final HBaseTestingUtility UTIL = new HBaseTestingUtility(); private static final HBaseTestingUtility UTIL = new HBaseTestingUtility().createLocalHTU();
protected Configuration conf = UTIL.getConfiguration();
private HRegion r = null; private HRegion r = null;
private HTableDescriptor htd = null; private HTableDescriptor htd = null;
private Path compactionDir = null; private Path compactionDir = null;
@ -113,19 +131,17 @@ public class TestCompaction extends HBaseTestCase {
col2 = Bytes.toBytes("column2"); col2 = Bytes.toBytes("column2");
} }
@Override @Before
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); this.htd = UTIL.createTableDescriptor(name.getMethodName());
this.htd = createTableDescriptor(getName()); this.r = UTIL.createLocalHRegion(htd, null, null);
this.r = createNewHRegion(htd, null, null);
} }
@Override @After
public void tearDown() throws Exception { public void tearDown() throws Exception {
HLog hlog = r.getLog(); HLog hlog = r.getLog();
this.r.close(); this.r.close();
hlog.closeAndDelete(); hlog.closeAndDelete();
super.tearDown();
} }
/** /**
@ -134,6 +150,7 @@ public class TestCompaction extends HBaseTestCase {
* right answer in this case - and that it just basically works. * right answer in this case - and that it just basically works.
* @throws IOException * @throws IOException
*/ */
@Test
public void testMajorCompactingToNoOutput() throws IOException { public void testMajorCompactingToNoOutput() throws IOException {
createStoreFile(r); createStoreFile(r);
for (int i = 0; i < compactionThreshold; i++) { for (int i = 0; i < compactionThreshold; i++) {
@ -168,14 +185,17 @@ public class TestCompaction extends HBaseTestCase {
* Assert deletes get cleaned up. * Assert deletes get cleaned up.
* @throws Exception * @throws Exception
*/ */
@Test
public void testMajorCompaction() throws Exception { public void testMajorCompaction() throws Exception {
majorCompaction(); majorCompaction();
} }
@Test
public void testDataBlockEncodingInCacheOnly() throws Exception { public void testDataBlockEncodingInCacheOnly() throws Exception {
majorCompactionWithDataBlockEncoding(true); majorCompactionWithDataBlockEncoding(true);
} }
@Test
public void testDataBlockEncodingEverywhere() throws Exception { public void testDataBlockEncodingEverywhere() throws Exception {
majorCompactionWithDataBlockEncoding(false); majorCompactionWithDataBlockEncoding(false);
} }
@ -210,7 +230,7 @@ public class TestCompaction extends HBaseTestCase {
createStoreFile(r); createStoreFile(r);
} }
// Add more content. // Add more content.
addContent(new HRegionIncommon(r), Bytes.toString(COLUMN_FAMILY)); HBaseTestCase.addContent(new HRegionIncommon(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.
@ -310,6 +330,7 @@ public class TestCompaction extends HBaseTestCase {
assertEquals("Should not see anything after TTL has expired", 0, count); assertEquals("Should not see anything after TTL has expired", 0, count);
} }
@Test
public void testTimeBasedMajorCompaction() throws Exception { public void testTimeBasedMajorCompaction() throws Exception {
// create 2 storefiles and force a major compaction to reset the time // create 2 storefiles and force a major compaction to reset the time
int delay = 10 * 1000; // 10 sec int delay = 10 * 1000; // 10 sec
@ -359,16 +380,21 @@ public class TestCompaction extends HBaseTestCase {
} }
} }
@Test
public void testMinorCompactionWithDeleteRow() throws Exception { public void testMinorCompactionWithDeleteRow() throws Exception {
Delete deleteRow = new Delete(secondRowBytes); Delete deleteRow = new Delete(secondRowBytes);
testMinorCompactionWithDelete(deleteRow); testMinorCompactionWithDelete(deleteRow);
} }
@Test
public void testMinorCompactionWithDeleteColumn1() throws Exception { public void testMinorCompactionWithDeleteColumn1() throws Exception {
Delete dc = new Delete(secondRowBytes); Delete dc = new Delete(secondRowBytes);
/* delete all timestamps in the column */ /* delete all timestamps in the column */
dc.deleteColumns(fam2, col2); dc.deleteColumns(fam2, col2);
testMinorCompactionWithDelete(dc); testMinorCompactionWithDelete(dc);
} }
@Test
public void testMinorCompactionWithDeleteColumn2() throws Exception { public void testMinorCompactionWithDeleteColumn2() throws Exception {
Delete dc = new Delete(secondRowBytes); Delete dc = new Delete(secondRowBytes);
dc.deleteColumn(fam2, col2); dc.deleteColumn(fam2, col2);
@ -381,11 +407,15 @@ public class TestCompaction extends HBaseTestCase {
//testMinorCompactionWithDelete(dc, 2); //testMinorCompactionWithDelete(dc, 2);
testMinorCompactionWithDelete(dc, 3); testMinorCompactionWithDelete(dc, 3);
} }
@Test
public void testMinorCompactionWithDeleteColumnFamily() throws Exception { public void testMinorCompactionWithDeleteColumnFamily() throws Exception {
Delete deleteCF = new Delete(secondRowBytes); Delete deleteCF = new Delete(secondRowBytes);
deleteCF.deleteFamily(fam2); deleteCF.deleteFamily(fam2);
testMinorCompactionWithDelete(deleteCF); testMinorCompactionWithDelete(deleteCF);
} }
@Test
public void testMinorCompactionWithDeleteVersion1() throws Exception { public void testMinorCompactionWithDeleteVersion1() throws Exception {
Delete deleteVersion = new Delete(secondRowBytes); Delete deleteVersion = new Delete(secondRowBytes);
deleteVersion.deleteColumns(fam2, col2, 2); deleteVersion.deleteColumns(fam2, col2, 2);
@ -394,6 +424,8 @@ public class TestCompaction extends HBaseTestCase {
*/ */
testMinorCompactionWithDelete(deleteVersion, 1); testMinorCompactionWithDelete(deleteVersion, 1);
} }
@Test
public void testMinorCompactionWithDeleteVersion2() throws Exception { public void testMinorCompactionWithDeleteVersion2() throws Exception {
Delete deleteVersion = new Delete(secondRowBytes); Delete deleteVersion = new Delete(secondRowBytes);
deleteVersion.deleteColumn(fam2, col2, 1); deleteVersion.deleteColumn(fam2, col2, 1);
@ -417,10 +449,10 @@ public class TestCompaction extends HBaseTestCase {
private void testMinorCompactionWithDelete(Delete delete, int expectedResultsAfterDelete) throws Exception { private void testMinorCompactionWithDelete(Delete delete, int expectedResultsAfterDelete) throws Exception {
HRegionIncommon loader = new HRegionIncommon(r); HRegionIncommon loader = new HRegionIncommon(r);
for (int i = 0; i < compactionThreshold + 1; i++) { for (int i = 0; i < compactionThreshold + 1; i++) {
addContent(loader, Bytes.toString(fam1), Bytes.toString(col1), firstRowBytes, thirdRowBytes, i); HBaseTestCase.addContent(loader, Bytes.toString(fam1), Bytes.toString(col1), firstRowBytes, thirdRowBytes, i);
addContent(loader, Bytes.toString(fam1), Bytes.toString(col2), firstRowBytes, thirdRowBytes, i); HBaseTestCase.addContent(loader, Bytes.toString(fam1), Bytes.toString(col2), firstRowBytes, thirdRowBytes, i);
addContent(loader, Bytes.toString(fam2), Bytes.toString(col1), firstRowBytes, thirdRowBytes, i); HBaseTestCase.addContent(loader, Bytes.toString(fam2), Bytes.toString(col1), firstRowBytes, thirdRowBytes, i);
addContent(loader, Bytes.toString(fam2), Bytes.toString(col2), firstRowBytes, thirdRowBytes, i); HBaseTestCase.addContent(loader, Bytes.toString(fam2), Bytes.toString(col2), firstRowBytes, thirdRowBytes, i);
r.flushcache(); r.flushcache();
} }
@ -496,6 +528,7 @@ public class TestCompaction extends HBaseTestCase {
* (used during RS shutdown) * (used during RS shutdown)
* @throws Exception * @throws Exception
*/ */
@Test
public void testInterruptCompaction() throws Exception { public void testInterruptCompaction() throws Exception {
assertEquals(0, count()); assertEquals(0, count());
@ -514,7 +547,7 @@ public class TestCompaction extends HBaseTestCase {
for (int j = 0; j < jmax; j++) { for (int j = 0; j < jmax; j++) {
p.add(COLUMN_FAMILY, Bytes.toBytes(j), pad); p.add(COLUMN_FAMILY, Bytes.toBytes(j), pad);
} }
addContent(loader, Bytes.toString(COLUMN_FAMILY)); HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY));
loader.put(p); loader.put(p);
loader.flushcache(); loader.flushcache();
} }
@ -591,17 +624,18 @@ public class TestCompaction extends HBaseTestCase {
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); HRegionIncommon loader = new HRegionIncommon(region);
addContent(loader, family); HBaseTestCase.addContent(loader, family);
loader.flushcache(); loader.flushcache();
} }
private void createSmallerStoreFile(final HRegion region) throws IOException { private void createSmallerStoreFile(final HRegion region) throws IOException {
HRegionIncommon loader = new HRegionIncommon(region); HRegionIncommon loader = new HRegionIncommon(region);
addContent(loader, Bytes.toString(COLUMN_FAMILY), ("" + HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY), ("" +
"bbb").getBytes(), null); "bbb").getBytes(), null);
loader.flushcache(); loader.flushcache();
} }
@Test
public void testCompactionWithCorruptResult() throws Exception { public void testCompactionWithCorruptResult() throws Exception {
int nfiles = 10; int nfiles = 10;
for (int i = 0; i < nfiles; i++) { for (int i = 0; i < nfiles; i++) {
@ -641,6 +675,7 @@ public class TestCompaction extends HBaseTestCase {
/** /**
* Test for HBASE-5920 - Test user requested major compactions always occurring * Test for HBASE-5920 - Test user requested major compactions always occurring
*/ */
@Test
public void testNonUserMajorCompactionRequest() throws Exception { public void testNonUserMajorCompactionRequest() throws Exception {
Store store = r.getStore(COLUMN_FAMILY); Store store = r.getStore(COLUMN_FAMILY);
createStoreFile(r); createStoreFile(r);
@ -660,6 +695,7 @@ public class TestCompaction extends HBaseTestCase {
/** /**
* Test for HBASE-5920 * Test for HBASE-5920
*/ */
@Test
public void testUserMajorCompactionRequest() throws IOException{ public void testUserMajorCompactionRequest() throws IOException{
Store store = r.getStore(COLUMN_FAMILY); Store store = r.getStore(COLUMN_FAMILY);
createStoreFile(r); createStoreFile(r);
@ -679,6 +715,7 @@ public class TestCompaction extends HBaseTestCase {
* Create a custom compaction request and be sure that we can track it through the queue, knowing * Create a custom compaction request and be sure that we can track it through the queue, knowing
* when the compaction is completed. * when the compaction is completed.
*/ */
@Test
public void testTrackingCompactionRequest() throws Exception { public void testTrackingCompactionRequest() throws Exception {
// setup a compact/split thread on a mock server // setup a compact/split thread on a mock server
HRegionServer mockServer = Mockito.mock(HRegionServer.class); HRegionServer mockServer = Mockito.mock(HRegionServer.class);
@ -707,6 +744,7 @@ public class TestCompaction extends HBaseTestCase {
* {@link CompactSplitThread} * {@link CompactSplitThread}
* @throws Exception on failure * @throws Exception on failure
*/ */
@Test
public void testMultipleCustomCompactionRequests() throws Exception { public void testMultipleCustomCompactionRequests() throws Exception {
// setup a compact/split thread on a mock server // setup a compact/split thread on a mock server
HRegionServer mockServer = Mockito.mock(HRegionServer.class); HRegionServer mockServer = Mockito.mock(HRegionServer.class);
@ -883,6 +921,7 @@ public class TestCompaction extends HBaseTestCase {
} }
/** Test compaction priority management and multiple compactions per store (HBASE-8665). */ /** Test compaction priority management and multiple compactions per store (HBASE-8665). */
@Test
public void testCompactionQueuePriorities() throws Exception { public void testCompactionQueuePriorities() throws Exception {
// Setup a compact/split thread on a mock server. // Setup a compact/split thread on a mock server.
final Configuration conf = HBaseConfiguration.create(); final Configuration conf = HBaseConfiguration.create();

View File

@ -18,6 +18,8 @@
*/ */
package org.apache.hadoop.hbase.regionserver; package org.apache.hadoop.hbase.regionserver;
import static org.junit.Assert.fail;
import java.io.IOException; import java.io.IOException;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
@ -25,6 +27,7 @@ import org.apache.hadoop.hbase.MediumTests;
import org.apache.hadoop.hbase.RegionTooBusyException; import org.apache.hadoop.hbase.RegionTooBusyException;
import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
@ -33,11 +36,12 @@ import org.junit.experimental.categories.Category;
* We can't use parameterized test since TestHRegion is old fashion. * We can't use parameterized test since TestHRegion is old fashion.
*/ */
@Category(MediumTests.class) @Category(MediumTests.class)
@SuppressWarnings("deprecation")
public class TestHRegionBusyWait extends TestHRegion { public class TestHRegionBusyWait extends TestHRegion {
// TODO: This subclass runs all the tests in TestHRegion as well as the test below which means // TODO: This subclass runs all the tests in TestHRegion as well as the test below which means
// all TestHRegion tests are run twice. // all TestHRegion tests are run twice.
public TestHRegionBusyWait() { @Before
public void setup() throws IOException {
super.setup();
conf.set("hbase.busy.wait.duration", "1000"); conf.set("hbase.busy.wait.duration", "1000");
} }

View File

@ -17,23 +17,35 @@
*/ */
package org.apache.hadoop.hbase.regionserver; package org.apache.hadoop.hbase.regionserver;
import static org.apache.hadoop.hbase.HBaseTestingUtility.fam1;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.io.IOException; import java.io.IOException;
import java.util.Random; import java.util.Random;
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.hbase.Cell;
import org.apache.hadoop.hbase.*; import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HConstants.OperationStatusCode; import org.apache.hadoop.hbase.HConstants.OperationStatusCode;
import org.apache.hadoop.hbase.HRegionInfo;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.MediumTests;
import org.apache.hadoop.hbase.TableName;
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.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.apache.hadoop.hbase.util.EnvironmentEdgeManagerTestHelper; import org.apache.hadoop.hbase.util.EnvironmentEdgeManagerTestHelper;
import org.junit.After;
import org.junit.Before;
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;
/** /**
@ -41,15 +53,15 @@ import org.junit.experimental.categories.Category;
* *
*/ */
@Category(MediumTests.class) @Category(MediumTests.class)
public class TestParallelPut extends HBaseTestCase { public class TestParallelPut {
static final Log LOG = LogFactory.getLog(TestParallelPut.class); static final Log LOG = LogFactory.getLog(TestParallelPut.class);
@Rule public TestName name = new TestName();
private static HRegion region = null; private static HRegion region = null;
private static HBaseTestingUtility hbtu = new HBaseTestingUtility(); private static HBaseTestingUtility hbtu = new HBaseTestingUtility();
private static final String DIR = hbtu.getDataTestDir() + "/TestParallelPut/";
// Test names // Test names
static final byte[] tableName = Bytes.toBytes("testtable");; static byte[] tableName;
static final byte[] qual1 = Bytes.toBytes("qual1"); static final byte[] qual1 = Bytes.toBytes("qual1");
static final byte[] qual2 = Bytes.toBytes("qual2"); static final byte[] qual2 = Bytes.toBytes("qual2");
static final byte[] qual3 = Bytes.toBytes("qual3"); static final byte[] qual3 = Bytes.toBytes("qual3");
@ -61,16 +73,19 @@ public class TestParallelPut extends HBaseTestCase {
/** /**
* @see org.apache.hadoop.hbase.HBaseTestCase#setUp() * @see org.apache.hadoop.hbase.HBaseTestCase#setUp()
*/ */
@Override @Before
protected void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); tableName = Bytes.toBytes(name.getMethodName());
} }
@Override @After
protected void tearDown() throws Exception { public void tearDown() throws Exception {
super.tearDown();
EnvironmentEdgeManagerTestHelper.reset(); EnvironmentEdgeManagerTestHelper.reset();
} }
public String getName() {
return name.getMethodName();
}
////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////
// New tests that don't spin up a mini cluster but rather just test the // New tests that don't spin up a mini cluster but rather just test the
@ -80,6 +95,7 @@ public class TestParallelPut extends HBaseTestCase {
/** /**
* Test one put command. * Test one put command.
*/ */
@Test
public void testPut() throws IOException { public void testPut() throws IOException {
LOG.info("Starting testPut"); LOG.info("Starting testPut");
initHRegion(tableName, getName(), fam1); initHRegion(tableName, getName(), fam1);
@ -96,6 +112,7 @@ public class TestParallelPut extends HBaseTestCase {
/** /**
* Test multi-threaded Puts. * Test multi-threaded Puts.
*/ */
@Test
public void testParallelPuts() throws IOException { public void testParallelPuts() throws IOException {
LOG.info("Starting testParallelPuts"); LOG.info("Starting testParallelPuts");
@ -148,24 +165,12 @@ public class TestParallelPut extends HBaseTestCase {
private void initHRegion(byte [] tableName, String callingMethod, private void initHRegion(byte [] tableName, String callingMethod,
byte[] ... families) byte[] ... families)
throws IOException { throws IOException {
initHRegion(tableName, callingMethod, HBaseConfiguration.create(), families);
}
private void initHRegion(byte [] tableName, String callingMethod,
Configuration conf, byte [] ... families)
throws IOException{
HTableDescriptor htd = new HTableDescriptor(TableName.valueOf(tableName)); HTableDescriptor htd = new HTableDescriptor(TableName.valueOf(tableName));
for(byte [] family : families) { for(byte [] family : families) {
htd.addFamily(new HColumnDescriptor(family)); htd.addFamily(new HColumnDescriptor(family));
} }
HRegionInfo info = new HRegionInfo(htd.getTableName(), null, null, false); HRegionInfo info = new HRegionInfo(htd.getTableName(), null, null, false);
Path path = new Path(DIR + callingMethod); region = hbtu.createLocalHRegion(info, htd);
if (fs.exists(path)) {
if (!fs.delete(path, true)) {
throw new IOException("Failed delete of " + path);
}
}
region = HRegion.createHRegion(info, path, conf, htd);
} }
/** /**

View File

@ -23,18 +23,18 @@ import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
import java.io.IOException;
import java.security.PrivilegedExceptionAction; import java.security.PrivilegedExceptionAction;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.UUID; import java.util.UUID;
import java.io.IOException;
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.hbase.TableName;
import org.apache.hadoop.hbase.HBaseTestingUtility; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.LargeTests; import org.apache.hadoop.hbase.LargeTests;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.HTable; 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;
@ -46,14 +46,18 @@ import org.apache.hadoop.hbase.security.AccessDeniedException;
import org.apache.hadoop.hbase.security.User; import org.apache.hadoop.hbase.security.User;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.junit.AfterClass; import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass; import org.junit.BeforeClass;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.junit.experimental.categories.Category; import org.junit.experimental.categories.Category;
import org.junit.rules.TestName;
import com.google.protobuf.BlockingRpcChannel; import com.google.protobuf.BlockingRpcChannel;
@Category(LargeTests.class) @Category(LargeTests.class)
public class TestAccessControlFilter { public class TestAccessControlFilter {
@Rule public TestName name = new TestName();
private static Log LOG = LogFactory.getLog(TestAccessControlFilter.class); private static Log LOG = LogFactory.getLog(TestAccessControlFilter.class);
private static HBaseTestingUtility TEST_UTIL; private static HBaseTestingUtility TEST_UTIL;
@ -62,12 +66,17 @@ public class TestAccessControlFilter {
private static User LIMITED; private static User LIMITED;
private static User DENIED; private static User DENIED;
private static TableName TABLE =
TableName.valueOf("testtable"); private static TableName TABLE;
private static byte[] FAMILY = Bytes.toBytes("f1"); private static byte[] FAMILY = Bytes.toBytes("f1");
private static byte[] PRIVATE_COL = Bytes.toBytes("private"); private static byte[] PRIVATE_COL = Bytes.toBytes("private");
private static byte[] PUBLIC_COL = Bytes.toBytes("public"); private static byte[] PUBLIC_COL = Bytes.toBytes("public");
@Before
public void setup () {
TABLE = TableName.valueOf(name.getMethodName());
}
@BeforeClass @BeforeClass
public static void setupBeforeClass() throws Exception { public static void setupBeforeClass() throws Exception {
TEST_UTIL = new HBaseTestingUtility(); TEST_UTIL = new HBaseTestingUtility();
@ -107,7 +116,7 @@ public class TestAccessControlFilter {
public Object run() throws Exception { public Object run() throws Exception {
HTable aclmeta = new HTable(TEST_UTIL.getConfiguration(), HTable aclmeta = new HTable(TEST_UTIL.getConfiguration(),
AccessControlLists.ACL_TABLE_NAME); AccessControlLists.ACL_TABLE_NAME);
byte[] table = Bytes.toBytes("testtable"); byte[] table = Bytes.toBytes(name.getMethodName());
BlockingRpcChannel service = aclmeta.coprocessorService(table); BlockingRpcChannel service = aclmeta.coprocessorService(table);
AccessControlService.BlockingInterface protocol = AccessControlService.BlockingInterface protocol =
AccessControlService.newBlockingStub(service); AccessControlService.newBlockingStub(service);