HBASE-12519 Remove tabs used as whitespace (Varun Saxena)
This commit is contained in:
parent
eb4c194a87
commit
58b6b24c29
|
@ -39,7 +39,7 @@ public class ExcludePrivateAnnotationsStandardDoclet {
|
||||||
|
|
||||||
public static boolean start(RootDoc root) {
|
public static boolean start(RootDoc root) {
|
||||||
System.out.println(
|
System.out.println(
|
||||||
ExcludePrivateAnnotationsStandardDoclet.class.getSimpleName());
|
ExcludePrivateAnnotationsStandardDoclet.class.getSimpleName());
|
||||||
return Standard.start(RootDocProcessor.process(root));
|
return Standard.start(RootDocProcessor.process(root));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -65,10 +65,10 @@ class RootDocProcessor {
|
||||||
return getProxy(obj);
|
return getProxy(obj);
|
||||||
} else if (obj instanceof Object[]) {
|
} else if (obj instanceof Object[]) {
|
||||||
Class<?> componentType = type.isArray() ? type.getComponentType()
|
Class<?> componentType = type.isArray() ? type.getComponentType()
|
||||||
: cls.getComponentType();
|
: cls.getComponentType();
|
||||||
Object[] array = (Object[]) obj;
|
Object[] array = (Object[]) obj;
|
||||||
Object[] newArray = (Object[]) Array.newInstance(componentType,
|
Object[] newArray = (Object[]) Array.newInstance(componentType,
|
||||||
array.length);
|
array.length);
|
||||||
for (int i = 0; i < array.length; ++i) {
|
for (int i = 0; i < array.length; ++i) {
|
||||||
newArray[i] = process(array[i], componentType);
|
newArray[i] = process(array[i], componentType);
|
||||||
}
|
}
|
||||||
|
@ -98,116 +98,99 @@ class RootDocProcessor {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object invoke(Object proxy, Method method, Object[] args)
|
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
|
||||||
throws Throwable {
|
|
||||||
String methodName = method.getName();
|
String methodName = method.getName();
|
||||||
if (target instanceof Doc) {
|
if (target instanceof Doc) {
|
||||||
if (methodName.equals("isIncluded")) {
|
if (methodName.equals("isIncluded")) {
|
||||||
Doc doc = (Doc) target;
|
Doc doc = (Doc) target;
|
||||||
return !exclude(doc) && doc.isIncluded();
|
return !exclude(doc) && doc.isIncluded();
|
||||||
}
|
}
|
||||||
if (target instanceof RootDoc) {
|
if (target instanceof RootDoc) {
|
||||||
if (methodName.equals("classes")) {
|
if (methodName.equals("classes")) {
|
||||||
return filter(((RootDoc) target).classes(), ClassDoc.class);
|
return filter(((RootDoc) target).classes(), ClassDoc.class);
|
||||||
} else if (methodName.equals("specifiedClasses")) {
|
} else if (methodName.equals("specifiedClasses")) {
|
||||||
return filter(((RootDoc) target).specifiedClasses(), ClassDoc.class);
|
return filter(((RootDoc) target).specifiedClasses(), ClassDoc.class);
|
||||||
} else if (methodName.equals("specifiedPackages")) {
|
} else if (methodName.equals("specifiedPackages")) {
|
||||||
return filter(((RootDoc) target).specifiedPackages(), PackageDoc.class);
|
return filter(((RootDoc) target).specifiedPackages(), PackageDoc.class);
|
||||||
}
|
}
|
||||||
} else if (target instanceof ClassDoc) {
|
} else if (target instanceof ClassDoc) {
|
||||||
if (isFiltered(args)) {
|
if (isFiltered(args)) {
|
||||||
if (methodName.equals("methods")) {
|
if (methodName.equals("methods")) {
|
||||||
return filter(((ClassDoc) target).methods(true), MethodDoc.class);
|
return filter(((ClassDoc) target).methods(true), MethodDoc.class);
|
||||||
} else if (methodName.equals("fields")) {
|
} else if (methodName.equals("fields")) {
|
||||||
return filter(((ClassDoc) target).fields(true), FieldDoc.class);
|
return filter(((ClassDoc) target).fields(true), FieldDoc.class);
|
||||||
} else if (methodName.equals("innerClasses")) {
|
} else if (methodName.equals("innerClasses")) {
|
||||||
return filter(((ClassDoc) target).innerClasses(true),
|
return filter(((ClassDoc) target).innerClasses(true), ClassDoc.class);
|
||||||
ClassDoc.class);
|
} else if (methodName.equals("constructors")) {
|
||||||
} else if (methodName.equals("constructors")) {
|
return filter(((ClassDoc) target).constructors(true), ConstructorDoc.class);
|
||||||
return filter(((ClassDoc) target).constructors(true),
|
}
|
||||||
ConstructorDoc.class);
|
}
|
||||||
}
|
} else if (target instanceof PackageDoc) {
|
||||||
}
|
if (methodName.equals("allClasses")) {
|
||||||
} else if (target instanceof PackageDoc) {
|
if (isFiltered(args)) {
|
||||||
if (methodName.equals("allClasses")) {
|
return filter(((PackageDoc) target).allClasses(true), ClassDoc.class);
|
||||||
if (isFiltered(args)) {
|
} else {
|
||||||
return filter(((PackageDoc) target).allClasses(true),
|
return filter(((PackageDoc) target).allClasses(), ClassDoc.class);
|
||||||
ClassDoc.class);
|
}
|
||||||
} else {
|
} else if (methodName.equals("annotationTypes")) {
|
||||||
return filter(((PackageDoc) target).allClasses(), ClassDoc.class);
|
return filter(((PackageDoc) target).annotationTypes(), AnnotationTypeDoc.class);
|
||||||
}
|
} else if (methodName.equals("enums")) {
|
||||||
} else if (methodName.equals("annotationTypes")) {
|
return filter(((PackageDoc) target).enums(), ClassDoc.class);
|
||||||
return filter(((PackageDoc) target).annotationTypes(),
|
} else if (methodName.equals("errors")) {
|
||||||
AnnotationTypeDoc.class);
|
return filter(((PackageDoc) target).errors(), ClassDoc.class);
|
||||||
} else if (methodName.equals("enums")) {
|
} else if (methodName.equals("exceptions")) {
|
||||||
return filter(((PackageDoc) target).enums(),
|
return filter(((PackageDoc) target).exceptions(), ClassDoc.class);
|
||||||
ClassDoc.class);
|
} else if (methodName.equals("interfaces")) {
|
||||||
} else if (methodName.equals("errors")) {
|
return filter(((PackageDoc) target).interfaces(), ClassDoc.class);
|
||||||
return filter(((PackageDoc) target).errors(),
|
} else if (methodName.equals("ordinaryClasses")) {
|
||||||
ClassDoc.class);
|
return filter(((PackageDoc) target).ordinaryClasses(), ClassDoc.class);
|
||||||
} else if (methodName.equals("exceptions")) {
|
}
|
||||||
return filter(((PackageDoc) target).exceptions(),
|
}
|
||||||
ClassDoc.class);
|
|
||||||
} else if (methodName.equals("interfaces")) {
|
|
||||||
return filter(((PackageDoc) target).interfaces(),
|
|
||||||
ClassDoc.class);
|
|
||||||
} else if (methodName.equals("ordinaryClasses")) {
|
|
||||||
return filter(((PackageDoc) target).ordinaryClasses(),
|
|
||||||
ClassDoc.class);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args != null) {
|
if (args != null) {
|
||||||
if (methodName.equals("compareTo") || methodName.equals("equals")
|
if (methodName.equals("compareTo") || methodName.equals("equals")
|
||||||
|| methodName.equals("overrides")
|
|| methodName.equals("overrides") || methodName.equals("subclassOf")) {
|
||||||
|| methodName.equals("subclassOf")) {
|
args[0] = unwrap(args[0]);
|
||||||
args[0] = unwrap(args[0]);
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
return process(method.invoke(target, args), method.getReturnType());
|
return process(method.invoke(target, args), method.getReturnType());
|
||||||
} catch (InvocationTargetException e) {
|
} catch (InvocationTargetException e) {
|
||||||
throw e.getTargetException();
|
throw e.getTargetException();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean exclude(Doc doc) {
|
private static boolean exclude(Doc doc) {
|
||||||
AnnotationDesc[] annotations = null;
|
AnnotationDesc[] annotations = null;
|
||||||
if (doc instanceof ProgramElementDoc) {
|
if (doc instanceof ProgramElementDoc) {
|
||||||
annotations = ((ProgramElementDoc) doc).annotations();
|
annotations = ((ProgramElementDoc) doc).annotations();
|
||||||
} else if (doc instanceof PackageDoc) {
|
} else if (doc instanceof PackageDoc) {
|
||||||
annotations = ((PackageDoc) doc).annotations();
|
annotations = ((PackageDoc) doc).annotations();
|
||||||
}
|
}
|
||||||
if (annotations != null) {
|
if (annotations != null) {
|
||||||
for (AnnotationDesc annotation : annotations) {
|
|
||||||
String qualifiedTypeName = annotation.annotationType().qualifiedTypeName();
|
|
||||||
if (qualifiedTypeName.equals(
|
|
||||||
InterfaceAudience.Private.class.getCanonicalName())
|
|
||||||
|| qualifiedTypeName.equals(
|
|
||||||
InterfaceAudience.LimitedPrivate.class.getCanonicalName())) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (stability.equals(StabilityOptions.EVOLVING_OPTION)) {
|
|
||||||
if (qualifiedTypeName.equals(
|
|
||||||
InterfaceStability.Unstable.class.getCanonicalName())) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (stability.equals(StabilityOptions.STABLE_OPTION)) {
|
|
||||||
if (qualifiedTypeName.equals(
|
|
||||||
InterfaceStability.Unstable.class.getCanonicalName())
|
|
||||||
|| qualifiedTypeName.equals(
|
|
||||||
InterfaceStability.Evolving.class.getCanonicalName())) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (AnnotationDesc annotation : annotations) {
|
for (AnnotationDesc annotation : annotations) {
|
||||||
String qualifiedTypeName =
|
String qualifiedTypeName = annotation.annotationType().qualifiedTypeName();
|
||||||
annotation.annotationType().qualifiedTypeName();
|
if (qualifiedTypeName.equals(InterfaceAudience.Private.class.getCanonicalName())
|
||||||
if (qualifiedTypeName.equals(
|
|| qualifiedTypeName
|
||||||
InterfaceAudience.Public.class.getCanonicalName())) {
|
.equals(InterfaceAudience.LimitedPrivate.class.getCanonicalName())) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (stability.equals(StabilityOptions.EVOLVING_OPTION)) {
|
||||||
|
if (qualifiedTypeName.equals(InterfaceStability.Unstable.class.getCanonicalName())) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (stability.equals(StabilityOptions.STABLE_OPTION)) {
|
||||||
|
if (qualifiedTypeName.equals(InterfaceStability.Unstable.class.getCanonicalName())
|
||||||
|
|| qualifiedTypeName.equals(InterfaceStability.Evolving.class.getCanonicalName())) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (AnnotationDesc annotation : annotations) {
|
||||||
|
String qualifiedTypeName = annotation.annotationType().qualifiedTypeName();
|
||||||
|
if (qualifiedTypeName.equals(InterfaceAudience.Public.class.getCanonicalName())) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -220,28 +203,24 @@ class RootDocProcessor {
|
||||||
|
|
||||||
private static Object[] filter(Doc[] array, Class<?> componentType) {
|
private static Object[] filter(Doc[] array, Class<?> componentType) {
|
||||||
if (array == null || array.length == 0) {
|
if (array == null || array.length == 0) {
|
||||||
return array;
|
return array;
|
||||||
}
|
}
|
||||||
List<Object> list = new ArrayList<Object>(array.length);
|
List<Object> list = new ArrayList<Object>(array.length);
|
||||||
for (Doc entry : array) {
|
for (Doc entry : array) {
|
||||||
if (!exclude(entry)) {
|
if (!exclude(entry)) {
|
||||||
list.add(process(entry, componentType));
|
list.add(process(entry, componentType));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return list.toArray((Object[]) Array.newInstance(componentType, list
|
return list.toArray((Object[]) Array.newInstance(componentType, list.size()));
|
||||||
.size()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private Object unwrap(Object proxy) {
|
private Object unwrap(Object proxy) {
|
||||||
if (proxy instanceof Proxy)
|
if (proxy instanceof Proxy) return ((ExcludeHandler) Proxy.getInvocationHandler(proxy)).target;
|
||||||
return ((ExcludeHandler) Proxy.getInvocationHandler(proxy)).target;
|
|
||||||
return proxy;
|
return proxy;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isFiltered(Object[] args) {
|
private boolean isFiltered(Object[] args) {
|
||||||
return args != null && Boolean.TRUE.equals(args[0]);
|
return args != null && Boolean.TRUE.equals(args[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,16 +35,15 @@ class StabilityOptions {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void validOptions(String[][] options,
|
public static void validOptions(String[][] options, DocErrorReporter reporter) {
|
||||||
DocErrorReporter reporter) {
|
|
||||||
for (int i = 0; i < options.length; i++) {
|
for (int i = 0; i < options.length; i++) {
|
||||||
String opt = options[i][0].toLowerCase();
|
String opt = options[i][0].toLowerCase();
|
||||||
if (opt.equals(UNSTABLE_OPTION)) {
|
if (opt.equals(UNSTABLE_OPTION)) {
|
||||||
RootDocProcessor.stability = UNSTABLE_OPTION;
|
RootDocProcessor.stability = UNSTABLE_OPTION;
|
||||||
} else if (opt.equals(EVOLVING_OPTION)) {
|
} else if (opt.equals(EVOLVING_OPTION)) {
|
||||||
RootDocProcessor.stability = EVOLVING_OPTION;
|
RootDocProcessor.stability = EVOLVING_OPTION;
|
||||||
} else if (opt.equals(STABLE_OPTION)) {
|
} else if (opt.equals(STABLE_OPTION)) {
|
||||||
RootDocProcessor.stability = STABLE_OPTION;
|
RootDocProcessor.stability = STABLE_OPTION;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,9 +52,9 @@ class StabilityOptions {
|
||||||
List<String[]> optionsList = new ArrayList<String[]>();
|
List<String[]> optionsList = new ArrayList<String[]>();
|
||||||
for (int i = 0; i < options.length; i++) {
|
for (int i = 0; i < options.length; i++) {
|
||||||
if (!options[i][0].equalsIgnoreCase(UNSTABLE_OPTION)
|
if (!options[i][0].equalsIgnoreCase(UNSTABLE_OPTION)
|
||||||
&& !options[i][0].equalsIgnoreCase(EVOLVING_OPTION)
|
&& !options[i][0].equalsIgnoreCase(EVOLVING_OPTION)
|
||||||
&& !options[i][0].equalsIgnoreCase(STABLE_OPTION)) {
|
&& !options[i][0].equalsIgnoreCase(STABLE_OPTION)) {
|
||||||
optionsList.add(options[i]);
|
optionsList.add(options[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
String[][] filteredOptions = new String[optionsList.size()][];
|
String[][] filteredOptions = new String[optionsList.size()][];
|
||||||
|
@ -65,5 +64,4 @@ class StabilityOptions {
|
||||||
}
|
}
|
||||||
return filteredOptions;
|
return filteredOptions;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -973,7 +973,7 @@ public class HTableDescriptor implements Comparable<HTableDescriptor> {
|
||||||
* This compares the content of the two descriptors and not the reference.
|
* This compares the content of the two descriptors and not the reference.
|
||||||
*
|
*
|
||||||
* @return 0 if the contents of the descriptors are exactly matching,
|
* @return 0 if the contents of the descriptors are exactly matching,
|
||||||
* 1 if there is a mismatch in the contents
|
* 1 if there is a mismatch in the contents
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public int compareTo(@Nonnull final HTableDescriptor other) {
|
public int compareTo(@Nonnull final HTableDescriptor other) {
|
||||||
|
|
|
@ -428,7 +428,7 @@ public class HTable implements HTableInterface, RegionLocator {
|
||||||
* @param tableName Name of table to check.
|
* @param tableName Name of table to check.
|
||||||
* @return {@code true} if table is online.
|
* @return {@code true} if table is online.
|
||||||
* @throws IOException if a remote or network exception occurs
|
* @throws IOException if a remote or network exception occurs
|
||||||
* @deprecated use {@link HBaseAdmin#isTableEnabled(byte[])}
|
* @deprecated use {@link HBaseAdmin#isTableEnabled(byte[])}
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public static boolean isTableEnabled(Configuration conf, String tableName)
|
public static boolean isTableEnabled(Configuration conf, String tableName)
|
||||||
|
@ -442,7 +442,7 @@ public class HTable implements HTableInterface, RegionLocator {
|
||||||
* @param tableName Name of table to check.
|
* @param tableName Name of table to check.
|
||||||
* @return {@code true} if table is online.
|
* @return {@code true} if table is online.
|
||||||
* @throws IOException if a remote or network exception occurs
|
* @throws IOException if a remote or network exception occurs
|
||||||
* @deprecated use {@link HBaseAdmin#isTableEnabled(byte[])}
|
* @deprecated use {@link HBaseAdmin#isTableEnabled(byte[])}
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public static boolean isTableEnabled(Configuration conf, byte[] tableName)
|
public static boolean isTableEnabled(Configuration conf, byte[] tableName)
|
||||||
|
|
|
@ -32,7 +32,7 @@ import org.apache.hadoop.hbase.classification.InterfaceStability;
|
||||||
public class UnmodifyableHTableDescriptor extends HTableDescriptor {
|
public class UnmodifyableHTableDescriptor extends HTableDescriptor {
|
||||||
/** Default constructor */
|
/** Default constructor */
|
||||||
public UnmodifyableHTableDescriptor() {
|
public UnmodifyableHTableDescriptor() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -180,12 +180,11 @@ public class AggregationClient implements Closeable {
|
||||||
*/
|
*/
|
||||||
private void validateParameters(Scan scan, boolean canFamilyBeAbsent) throws IOException {
|
private void validateParameters(Scan scan, boolean canFamilyBeAbsent) throws IOException {
|
||||||
if (scan == null
|
if (scan == null
|
||||||
|| (Bytes.equals(scan.getStartRow(), scan.getStopRow()) && !Bytes
|
|| (Bytes.equals(scan.getStartRow(), scan.getStopRow()) && !Bytes.equals(
|
||||||
.equals(scan.getStartRow(), HConstants.EMPTY_START_ROW))
|
scan.getStartRow(), HConstants.EMPTY_START_ROW))
|
||||||
|| ((Bytes.compareTo(scan.getStartRow(), scan.getStopRow()) > 0) &&
|
|| ((Bytes.compareTo(scan.getStartRow(), scan.getStopRow()) > 0) && !Bytes.equals(
|
||||||
!Bytes.equals(scan.getStopRow(), HConstants.EMPTY_END_ROW))) {
|
scan.getStopRow(), HConstants.EMPTY_END_ROW))) {
|
||||||
throw new IOException(
|
throw new IOException("Agg client Exception: Startrow should be smaller than Stoprow");
|
||||||
"Agg client Exception: Startrow should be smaller than Stoprow");
|
|
||||||
} else if (!canFamilyBeAbsent) {
|
} else if (!canFamilyBeAbsent) {
|
||||||
if (scan.getFamilyMap().size() != 1) {
|
if (scan.getFamilyMap().size() != 1) {
|
||||||
throw new IOException("There must be only one family.");
|
throw new IOException("There must be only one family.");
|
||||||
|
|
|
@ -68,8 +68,8 @@ public class DependentColumnFilter extends CompareFilter {
|
||||||
* @param valueComparator comparator
|
* @param valueComparator comparator
|
||||||
*/
|
*/
|
||||||
public DependentColumnFilter(final byte [] family, final byte[] qualifier,
|
public DependentColumnFilter(final byte [] family, final byte[] qualifier,
|
||||||
final boolean dropDependentColumn, final CompareOp valueCompareOp,
|
final boolean dropDependentColumn, final CompareOp valueCompareOp,
|
||||||
final ByteArrayComparable valueComparator) {
|
final ByteArrayComparable valueComparator) {
|
||||||
// set up the comparator
|
// set up the comparator
|
||||||
super(valueCompareOp, valueComparator);
|
super(valueCompareOp, valueComparator);
|
||||||
this.columnFamily = family;
|
this.columnFamily = family;
|
||||||
|
@ -136,10 +136,10 @@ public class DependentColumnFilter extends CompareFilter {
|
||||||
@Override
|
@Override
|
||||||
public ReturnCode filterKeyValue(Cell c) {
|
public ReturnCode filterKeyValue(Cell c) {
|
||||||
// Check if the column and qualifier match
|
// Check if the column and qualifier match
|
||||||
if (!CellUtil.matchingColumn(c, this.columnFamily, this.columnQualifier)) {
|
if (!CellUtil.matchingColumn(c, this.columnFamily, this.columnQualifier)) {
|
||||||
// include non-matches for the time being, they'll be discarded afterwards
|
// include non-matches for the time being, they'll be discarded afterwards
|
||||||
return ReturnCode.INCLUDE;
|
return ReturnCode.INCLUDE;
|
||||||
}
|
}
|
||||||
// If it doesn't pass the op, skip it
|
// If it doesn't pass the op, skip it
|
||||||
if (comparator != null
|
if (comparator != null
|
||||||
&& doCompare(compareOp, comparator, c.getValueArray(), c.getValueOffset(),
|
&& doCompare(compareOp, comparator, c.getValueArray(), c.getValueOffset(),
|
||||||
|
@ -148,7 +148,7 @@ public class DependentColumnFilter extends CompareFilter {
|
||||||
|
|
||||||
stampSet.add(c.getTimestamp());
|
stampSet.add(c.getTimestamp());
|
||||||
if(dropDependentColumn) {
|
if(dropDependentColumn) {
|
||||||
return ReturnCode.SKIP;
|
return ReturnCode.SKIP;
|
||||||
}
|
}
|
||||||
return ReturnCode.INCLUDE;
|
return ReturnCode.INCLUDE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1049,7 +1049,7 @@ public final class RequestConverter {
|
||||||
public static MoveRegionRequest buildMoveRegionRequest(
|
public static MoveRegionRequest buildMoveRegionRequest(
|
||||||
final byte [] encodedRegionName, final byte [] destServerName) throws
|
final byte [] encodedRegionName, final byte [] destServerName) throws
|
||||||
DeserializationException {
|
DeserializationException {
|
||||||
MoveRegionRequest.Builder builder = MoveRegionRequest.newBuilder();
|
MoveRegionRequest.Builder builder = MoveRegionRequest.newBuilder();
|
||||||
builder.setRegion(
|
builder.setRegion(
|
||||||
buildRegionSpecifier(RegionSpecifierType.ENCODED_REGION_NAME,encodedRegionName));
|
buildRegionSpecifier(RegionSpecifierType.ENCODED_REGION_NAME,encodedRegionName));
|
||||||
if (destServerName != null) {
|
if (destServerName != null) {
|
||||||
|
|
|
@ -61,7 +61,7 @@ public class TimeRange {
|
||||||
* @param minStamp the minimum timestamp value, inclusive
|
* @param minStamp the minimum timestamp value, inclusive
|
||||||
*/
|
*/
|
||||||
public TimeRange(byte [] minStamp) {
|
public TimeRange(byte [] minStamp) {
|
||||||
this.minStamp = Bytes.toLong(minStamp);
|
this.minStamp = Bytes.toLong(minStamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -126,8 +126,8 @@ public class TimeRange {
|
||||||
* @return true if within TimeRange, false if not
|
* @return true if within TimeRange, false if not
|
||||||
*/
|
*/
|
||||||
public boolean withinTimeRange(byte [] bytes, int offset) {
|
public boolean withinTimeRange(byte [] bytes, int offset) {
|
||||||
if(allTime) return true;
|
if(allTime) return true;
|
||||||
return withinTimeRange(Bytes.toLong(bytes, offset));
|
return withinTimeRange(Bytes.toLong(bytes, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -139,9 +139,9 @@ public class TimeRange {
|
||||||
* @return true if within TimeRange, false if not
|
* @return true if within TimeRange, false if not
|
||||||
*/
|
*/
|
||||||
public boolean withinTimeRange(long timestamp) {
|
public boolean withinTimeRange(long timestamp) {
|
||||||
if(allTime) return true;
|
if(allTime) return true;
|
||||||
// check if >= minStamp
|
// check if >= minStamp
|
||||||
return (minStamp <= timestamp && timestamp < maxStamp);
|
return (minStamp <= timestamp && timestamp < maxStamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -43,7 +43,7 @@ public class CollectionUtils {
|
||||||
return in;
|
return in;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************ size ************************************/
|
/************************ size ************************************/
|
||||||
|
|
||||||
public static <T> int nullSafeSize(Collection<T> collection) {
|
public static <T> int nullSafeSize(Collection<T> collection) {
|
||||||
if (collection == null) {
|
if (collection == null) {
|
||||||
|
@ -56,7 +56,7 @@ public class CollectionUtils {
|
||||||
return nullSafeSize(a) == nullSafeSize(b);
|
return nullSafeSize(a) == nullSafeSize(b);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*************************** empty ****************************************/
|
/*************************** empty ****************************************/
|
||||||
|
|
||||||
public static <T> boolean isEmpty(Collection<T> collection) {
|
public static <T> boolean isEmpty(Collection<T> collection) {
|
||||||
return collection == null || collection.isEmpty();
|
return collection == null || collection.isEmpty();
|
||||||
|
@ -66,7 +66,7 @@ public class CollectionUtils {
|
||||||
return !isEmpty(collection);
|
return !isEmpty(collection);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************ first/last **************************/
|
/************************ first/last **************************/
|
||||||
|
|
||||||
public static <T> T getFirst(Collection<T> collection) {
|
public static <T> T getFirst(Collection<T> collection) {
|
||||||
if (CollectionUtils.isEmpty(collection)) {
|
if (CollectionUtils.isEmpty(collection)) {
|
||||||
|
|
|
@ -164,7 +164,7 @@ public class JenkinsHash extends Hash {
|
||||||
//-------------------------------- last block: affect all 32 bits of (c)
|
//-------------------------------- last block: affect all 32 bits of (c)
|
||||||
switch (length) { // all the case statements fall through
|
switch (length) { // all the case statements fall through
|
||||||
case 12:
|
case 12:
|
||||||
c += ((key[offset + 11] & BYTE_MASK) << 24);
|
c += ((key[offset + 11] & BYTE_MASK) << 24);
|
||||||
case 11:
|
case 11:
|
||||||
c += ((key[offset + 10] & BYTE_MASK) << 16);
|
c += ((key[offset + 10] & BYTE_MASK) << 16);
|
||||||
case 10:
|
case 10:
|
||||||
|
|
|
@ -201,7 +201,7 @@ public class TestHBaseConfiguration {
|
||||||
|
|
||||||
hadoopClassesAvailable = true;
|
hadoopClassesAvailable = true;
|
||||||
LOG.info("Credential provider classes have been" +
|
LOG.info("Credential provider classes have been" +
|
||||||
" loaded and initialized successfully through reflection.");
|
" loaded and initialized successfully through reflection.");
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -280,7 +280,7 @@ public class TestHBaseConfiguration {
|
||||||
List<Object> providers = getCredentialProviders(conf);
|
List<Object> providers = getCredentialProviders(conf);
|
||||||
if (null == providers) {
|
if (null == providers) {
|
||||||
throw new IOException("Could not fetch any CredentialProviders, " +
|
throw new IOException("Could not fetch any CredentialProviders, " +
|
||||||
"is the implementation available?");
|
"is the implementation available?");
|
||||||
}
|
}
|
||||||
|
|
||||||
Object provider = providers.get(0);
|
Object provider = providers.get(0);
|
||||||
|
|
|
@ -583,8 +583,8 @@ public class IntegrationTestBigLinkedListWithVisibility extends IntegrationTestB
|
||||||
if (args.length < 5) {
|
if (args.length < 5) {
|
||||||
System.err
|
System.err
|
||||||
.println("Usage: Loop <num iterations> " +
|
.println("Usage: Loop <num iterations> " +
|
||||||
"<num mappers> <num nodes per mapper> <output dir> " +
|
"<num mappers> <num nodes per mapper> <output dir> " +
|
||||||
"<num reducers> [<width> <wrap multiplier>]");
|
"<num reducers> [<width> <wrap multiplier>]");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
LOG.info("Running Loop with args:" + Arrays.deepToString(args));
|
LOG.info("Running Loop with args:" + Arrays.deepToString(args));
|
||||||
|
|
|
@ -45,7 +45,7 @@ public class PrefixTreeBlockMeta {
|
||||||
public static final int MAX_FAMILY_LENGTH = Byte.MAX_VALUE;// hard-coded in KeyValue
|
public static final int MAX_FAMILY_LENGTH = Byte.MAX_VALUE;// hard-coded in KeyValue
|
||||||
|
|
||||||
public static final int
|
public static final int
|
||||||
NUM_LONGS = 2,
|
NUM_LONGS = 2,
|
||||||
NUM_INTS = 28,
|
NUM_INTS = 28,
|
||||||
NUM_SHORTS = 0,//keyValueTypeWidth not persisted
|
NUM_SHORTS = 0,//keyValueTypeWidth not persisted
|
||||||
NUM_SINGLE_BYTES = 2,
|
NUM_SINGLE_BYTES = 2,
|
||||||
|
@ -135,7 +135,7 @@ public class PrefixTreeBlockMeta {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**************** operate on each field **********************/
|
/**************** operate on each field **********************/
|
||||||
|
|
||||||
public int calculateNumMetaBytes(){
|
public int calculateNumMetaBytes(){
|
||||||
int numBytes = 0;
|
int numBytes = 0;
|
||||||
|
@ -339,7 +339,7 @@ public class PrefixTreeBlockMeta {
|
||||||
position += UVIntTool.numBytes(numUniqueTags);
|
position += UVIntTool.numBytes(numUniqueTags);
|
||||||
}
|
}
|
||||||
|
|
||||||
//TODO method that can read directly from ByteBuffer instead of InputStream
|
//TODO method that can read directly from ByteBuffer instead of InputStream
|
||||||
|
|
||||||
|
|
||||||
/*************** methods *************************/
|
/*************** methods *************************/
|
||||||
|
|
|
@ -306,7 +306,7 @@ public class PrefixTreeArraySearcher extends PrefixTreeArrayReversibleScanner im
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/****************** complete seek when token mismatch ******************/
|
/****************** complete seek when token mismatch ******************/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param searcherIsAfterInputKey <0: input key is before the searcher's position<br/>
|
* @param searcherIsAfterInputKey <0: input key is before the searcher's position<br/>
|
||||||
|
|
|
@ -71,7 +71,7 @@ public class ColumnSectionWriter {
|
||||||
private List<Integer> outputArrayOffsets;
|
private List<Integer> outputArrayOffsets;
|
||||||
|
|
||||||
|
|
||||||
/*********************** construct *********************/
|
/*********************** construct *********************/
|
||||||
|
|
||||||
public ColumnSectionWriter() {
|
public ColumnSectionWriter() {
|
||||||
this.nonLeaves = Lists.newArrayList();
|
this.nonLeaves = Lists.newArrayList();
|
||||||
|
@ -100,7 +100,7 @@ public class ColumnSectionWriter {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/****************** methods *******************************/
|
/****************** methods *******************************/
|
||||||
|
|
||||||
public ColumnSectionWriter compile() {
|
public ColumnSectionWriter compile() {
|
||||||
if (this.nodeType == ColumnNodeType.FAMILY) {
|
if (this.nodeType == ColumnNodeType.FAMILY) {
|
||||||
|
|
|
@ -75,7 +75,7 @@ public class LongEncoder {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/************* methods ***************************/
|
/************* methods ***************************/
|
||||||
|
|
||||||
public void add(long timestamp) {
|
public void add(long timestamp) {
|
||||||
uniqueValues.add(timestamp);
|
uniqueValues.add(timestamp);
|
||||||
|
@ -158,7 +158,7 @@ public class LongEncoder {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/******************** get/set **************************/
|
/******************** get/set **************************/
|
||||||
|
|
||||||
public long getMin() {
|
public long getMin() {
|
||||||
return min;
|
return min;
|
||||||
|
|
|
@ -179,7 +179,7 @@ public class Tokenizer{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/********************** write ***************************/
|
/********************** write ***************************/
|
||||||
|
|
||||||
public Tokenizer setNodeFirstInsertionIndexes() {
|
public Tokenizer setNodeFirstInsertionIndexes() {
|
||||||
root.setInsertionIndexes(0);
|
root.setInsertionIndexes(0);
|
||||||
|
|
|
@ -289,7 +289,7 @@ public class TokenizerNode{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/************************ byte[] utils *************************/
|
/************************ byte[] utils *************************/
|
||||||
|
|
||||||
protected boolean partiallyMatchesToken(ByteRange bytes) {
|
protected boolean partiallyMatchesToken(ByteRange bytes) {
|
||||||
return numIdenticalBytes(bytes) > 0;
|
return numIdenticalBytes(bytes) > 0;
|
||||||
|
@ -304,7 +304,7 @@ public class TokenizerNode{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/***************** moving nodes around ************************/
|
/***************** moving nodes around ************************/
|
||||||
|
|
||||||
public void appendNodesToExternalList(List<TokenizerNode> appendTo, boolean includeNonLeaves,
|
public void appendNodesToExternalList(List<TokenizerNode> appendTo, boolean includeNonLeaves,
|
||||||
boolean includeLeaves) {
|
boolean includeLeaves) {
|
||||||
|
@ -462,7 +462,7 @@ public class TokenizerNode{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/********************** count different node types ********************/
|
/********************** count different node types ********************/
|
||||||
|
|
||||||
public int getNumBranchNodesIncludingThisNode() {
|
public int getNumBranchNodesIncludingThisNode() {
|
||||||
if (isLeaf()) {
|
if (isLeaf()) {
|
||||||
|
|
|
@ -30,9 +30,9 @@ import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public enum TokenizerRowSearchPosition {
|
public enum TokenizerRowSearchPosition {
|
||||||
|
|
||||||
AFTER,//the key is after this tree node, so keep searching
|
AFTER,//the key is after this tree node, so keep searching
|
||||||
BEFORE,//in a binary search, this tells us to back up
|
BEFORE,//in a binary search, this tells us to back up
|
||||||
MATCH,//the current node is a full match
|
MATCH,//the current node is a full match
|
||||||
NO_MATCH,//might as well return a value more informative than null
|
NO_MATCH,//might as well return a value more informative than null
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,13 +78,13 @@ public class UFIntTool {
|
||||||
|
|
||||||
private static final long[] MASKS = new long[] {
|
private static final long[] MASKS = new long[] {
|
||||||
(long) 255,
|
(long) 255,
|
||||||
(long) 255 << 8,
|
(long) 255 << 8,
|
||||||
(long) 255 << 16,
|
(long) 255 << 16,
|
||||||
(long) 255 << 24,
|
(long) 255 << 24,
|
||||||
(long) 255 << 32,
|
(long) 255 << 32,
|
||||||
(long) 255 << 40,
|
(long) 255 << 40,
|
||||||
(long) 255 << 48,
|
(long) 255 << 48,
|
||||||
(long) 255 << 56
|
(long) 255 << 56
|
||||||
};
|
};
|
||||||
|
|
||||||
public static void writeBytes(int outputWidth, final long value, OutputStream os) throws IOException {
|
public static void writeBytes(int outputWidth, final long value, OutputStream os) throws IOException {
|
||||||
|
|
|
@ -48,7 +48,7 @@ import org.junit.runners.Parameterized.Parameters;
|
||||||
@RunWith(Parameterized.class)
|
@RunWith(Parameterized.class)
|
||||||
public class TestPrefixTreeSearcher {
|
public class TestPrefixTreeSearcher {
|
||||||
|
|
||||||
protected static int BLOCK_START = 7;
|
protected static int BLOCK_START = 7;
|
||||||
|
|
||||||
@Parameters
|
@Parameters
|
||||||
public static Collection<Object[]> parameters() {
|
public static Collection<Object[]> parameters() {
|
||||||
|
|
|
@ -77,7 +77,7 @@ public class TestRowEncoder {
|
||||||
this.rows = testRows;
|
this.rows = testRows;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void compile() throws IOException {
|
public void compile() throws IOException {
|
||||||
// Always run with tags. But should also ensure that KVs without tags work fine
|
// Always run with tags. But should also ensure that KVs without tags work fine
|
||||||
os = new ByteArrayOutputStream(1 << 20);
|
os = new ByteArrayOutputStream(1 << 20);
|
||||||
|
@ -175,7 +175,7 @@ public class TestRowEncoder {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**************** helper **************************/
|
/**************** helper **************************/
|
||||||
|
|
||||||
protected void assertKeyAndValueEqual(Cell expected, Cell actual) {
|
protected void assertKeyAndValueEqual(Cell expected, Cell actual) {
|
||||||
// assert keys are equal (doesn't compare values)
|
// assert keys are equal (doesn't compare values)
|
||||||
|
|
|
@ -29,7 +29,7 @@ import com.google.common.collect.Lists;
|
||||||
|
|
||||||
public class TestRowDataComplexQualifiers extends BaseTestRowData{
|
public class TestRowDataComplexQualifiers extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
Arow = Bytes.toBytes("Arow"),
|
Arow = Bytes.toBytes("Arow"),
|
||||||
cf = PrefixTreeTestConstants.TEST_CF,
|
cf = PrefixTreeTestConstants.TEST_CF,
|
||||||
v0 = Bytes.toBytes("v0");
|
v0 = Bytes.toBytes("v0");
|
||||||
|
|
|
@ -36,36 +36,36 @@ import com.google.common.collect.Lists;
|
||||||
*/
|
*/
|
||||||
public class TestRowDataDeeper extends BaseTestRowData{
|
public class TestRowDataDeeper extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
cdc = Bytes.toBytes("cdc"),
|
cdc = Bytes.toBytes("cdc"),
|
||||||
cf6 = Bytes.toBytes("cf6"),
|
cf6 = Bytes.toBytes("cf6"),
|
||||||
cfc = Bytes.toBytes("cfc"),
|
cfc = Bytes.toBytes("cfc"),
|
||||||
f = Bytes.toBytes("f"),
|
f = Bytes.toBytes("f"),
|
||||||
q = Bytes.toBytes("q"),
|
q = Bytes.toBytes("q"),
|
||||||
v = Bytes.toBytes("v");
|
v = Bytes.toBytes("v");
|
||||||
|
|
||||||
static long
|
static long
|
||||||
ts = 55L;
|
ts = 55L;
|
||||||
|
|
||||||
static List<KeyValue> d = Lists.newArrayList();
|
static List<KeyValue> d = Lists.newArrayList();
|
||||||
static{
|
static{
|
||||||
d.add(new KeyValue(cdc, f, q, ts, v));
|
d.add(new KeyValue(cdc, f, q, ts, v));
|
||||||
d.add(new KeyValue(cf6, f, q, ts, v));
|
d.add(new KeyValue(cf6, f, q, ts, v));
|
||||||
d.add(new KeyValue(cfc, f, q, ts, v));
|
d.add(new KeyValue(cfc, f, q, ts, v));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<KeyValue> getInputs() {
|
public List<KeyValue> getInputs() {
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void individualBlockMetaAssertions(PrefixTreeBlockMeta blockMeta) {
|
public void individualBlockMetaAssertions(PrefixTreeBlockMeta blockMeta) {
|
||||||
//0: token:c; fan:d,f
|
//0: token:c; fan:d,f
|
||||||
//1: token:f; fan:6,c
|
//1: token:f; fan:6,c
|
||||||
//2: leaves
|
//2: leaves
|
||||||
Assert.assertEquals(3, blockMeta.getRowTreeDepth());
|
Assert.assertEquals(3, blockMeta.getRowTreeDepth());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void individualSearcherAssertions(CellSearcher searcher) {
|
public void individualSearcherAssertions(CellSearcher searcher) {
|
||||||
|
|
|
@ -33,62 +33,62 @@ import com.google.common.collect.Lists;
|
||||||
*/
|
*/
|
||||||
public class TestRowDataDifferentTimestamps extends BaseTestRowData{
|
public class TestRowDataDifferentTimestamps extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
Arow = Bytes.toBytes("Arow"),
|
Arow = Bytes.toBytes("Arow"),
|
||||||
Brow = Bytes.toBytes("Brow"),
|
Brow = Bytes.toBytes("Brow"),
|
||||||
cf = Bytes.toBytes("fammy"),
|
cf = Bytes.toBytes("fammy"),
|
||||||
cq0 = Bytes.toBytes("cq0"),
|
cq0 = Bytes.toBytes("cq0"),
|
||||||
cq1 = Bytes.toBytes("cq1"),
|
cq1 = Bytes.toBytes("cq1"),
|
||||||
v0 = Bytes.toBytes("v0");
|
v0 = Bytes.toBytes("v0");
|
||||||
|
|
||||||
static List<KeyValue> d = Lists.newArrayList();
|
static List<KeyValue> d = Lists.newArrayList();
|
||||||
static{
|
static{
|
||||||
KeyValue kv0 = new KeyValue(Arow, cf, cq0, 0L, v0);
|
KeyValue kv0 = new KeyValue(Arow, cf, cq0, 0L, v0);
|
||||||
kv0.setSequenceId(123456789L);
|
kv0.setSequenceId(123456789L);
|
||||||
d.add(kv0);
|
d.add(kv0);
|
||||||
|
|
||||||
KeyValue kv1 = new KeyValue(Arow, cf, cq1, 1L, v0);
|
KeyValue kv1 = new KeyValue(Arow, cf, cq1, 1L, v0);
|
||||||
kv1.setSequenceId(3L);
|
kv1.setSequenceId(3L);
|
||||||
d.add(kv1);
|
d.add(kv1);
|
||||||
|
|
||||||
KeyValue kv2 = new KeyValue(Brow, cf, cq0, 12345678L, v0);
|
KeyValue kv2 = new KeyValue(Brow, cf, cq0, 12345678L, v0);
|
||||||
kv2.setSequenceId(65537L);
|
kv2.setSequenceId(65537L);
|
||||||
d.add(kv2);
|
d.add(kv2);
|
||||||
|
|
||||||
//watch out... Long.MAX_VALUE comes back as 1332221664203, even with other encoders
|
//watch out... Long.MAX_VALUE comes back as 1332221664203, even with other encoders
|
||||||
// d.add(new KeyValue(Brow, cf, cq1, Long.MAX_VALUE, v0));
|
//d.add(new KeyValue(Brow, cf, cq1, Long.MAX_VALUE, v0));
|
||||||
KeyValue kv3 = new KeyValue(Brow, cf, cq1, Long.MAX_VALUE-1, v0);
|
KeyValue kv3 = new KeyValue(Brow, cf, cq1, Long.MAX_VALUE-1, v0);
|
||||||
kv3.setSequenceId(1L);
|
kv3.setSequenceId(1L);
|
||||||
d.add(kv3);
|
d.add(kv3);
|
||||||
|
|
||||||
KeyValue kv4 = new KeyValue(Brow, cf, cq1, 999999999, v0);
|
KeyValue kv4 = new KeyValue(Brow, cf, cq1, 999999999, v0);
|
||||||
//don't set memstoreTS
|
//don't set memstoreTS
|
||||||
d.add(kv4);
|
d.add(kv4);
|
||||||
|
|
||||||
KeyValue kv5 = new KeyValue(Brow, cf, cq1, 12345, v0);
|
KeyValue kv5 = new KeyValue(Brow, cf, cq1, 12345, v0);
|
||||||
kv5.setSequenceId(0L);
|
kv5.setSequenceId(0L);
|
||||||
d.add(kv5);
|
d.add(kv5);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<KeyValue> getInputs() {
|
public List<KeyValue> getInputs() {
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void individualBlockMetaAssertions(PrefixTreeBlockMeta blockMeta) {
|
public void individualBlockMetaAssertions(PrefixTreeBlockMeta blockMeta) {
|
||||||
Assert.assertTrue(blockMeta.getNumMvccVersionBytes() > 0);
|
Assert.assertTrue(blockMeta.getNumMvccVersionBytes() > 0);
|
||||||
Assert.assertEquals(12, blockMeta.getNumValueBytes());
|
Assert.assertEquals(12, blockMeta.getNumValueBytes());
|
||||||
|
|
||||||
Assert.assertFalse(blockMeta.isAllSameTimestamp());
|
Assert.assertFalse(blockMeta.isAllSameTimestamp());
|
||||||
Assert.assertNotNull(blockMeta.getMinTimestamp());
|
Assert.assertNotNull(blockMeta.getMinTimestamp());
|
||||||
Assert.assertTrue(blockMeta.getTimestampIndexWidth() > 0);
|
Assert.assertTrue(blockMeta.getTimestampIndexWidth() > 0);
|
||||||
Assert.assertTrue(blockMeta.getTimestampDeltaWidth() > 0);
|
Assert.assertTrue(blockMeta.getTimestampDeltaWidth() > 0);
|
||||||
|
|
||||||
Assert.assertFalse(blockMeta.isAllSameMvccVersion());
|
Assert.assertFalse(blockMeta.isAllSameMvccVersion());
|
||||||
Assert.assertNotNull(blockMeta.getMinMvccVersion());
|
Assert.assertNotNull(blockMeta.getMinMvccVersion());
|
||||||
Assert.assertTrue(blockMeta.getMvccVersionIndexWidth() > 0);
|
Assert.assertTrue(blockMeta.getMvccVersionIndexWidth() > 0);
|
||||||
Assert.assertTrue(blockMeta.getMvccVersionDeltaWidth() > 0);
|
Assert.assertTrue(blockMeta.getMvccVersionDeltaWidth() > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,49 +42,49 @@ import com.google.common.collect.Lists;
|
||||||
public class TestRowDataExerciseFInts extends BaseTestRowData{
|
public class TestRowDataExerciseFInts extends BaseTestRowData{
|
||||||
|
|
||||||
static List<ByteRange> rows;
|
static List<ByteRange> rows;
|
||||||
static{
|
static{
|
||||||
List<String> rowStrings = new ArrayList<String>();
|
List<String> rowStrings = new ArrayList<String>();
|
||||||
rowStrings.add("com.edsBlog/directoryAa/pageAaa");
|
rowStrings.add("com.edsBlog/directoryAa/pageAaa");
|
||||||
rowStrings.add("com.edsBlog/directoryAa/pageBbb");
|
rowStrings.add("com.edsBlog/directoryAa/pageBbb");
|
||||||
rowStrings.add("com.edsBlog/directoryAa/pageCcc");
|
rowStrings.add("com.edsBlog/directoryAa/pageCcc");
|
||||||
rowStrings.add("com.edsBlog/directoryAa/pageDdd");
|
rowStrings.add("com.edsBlog/directoryAa/pageDdd");
|
||||||
rowStrings.add("com.edsBlog/directoryBb/pageEee");
|
rowStrings.add("com.edsBlog/directoryBb/pageEee");
|
||||||
rowStrings.add("com.edsBlog/directoryBb/pageFff");
|
rowStrings.add("com.edsBlog/directoryBb/pageFff");
|
||||||
rowStrings.add("com.edsBlog/directoryBb/pageGgg");
|
rowStrings.add("com.edsBlog/directoryBb/pageGgg");
|
||||||
rowStrings.add("com.edsBlog/directoryBb/pageHhh");
|
rowStrings.add("com.edsBlog/directoryBb/pageHhh");
|
||||||
rowStrings.add("com.isabellasBlog/directoryAa/pageAaa");
|
rowStrings.add("com.isabellasBlog/directoryAa/pageAaa");
|
||||||
rowStrings.add("com.isabellasBlog/directoryAa/pageBbb");
|
rowStrings.add("com.isabellasBlog/directoryAa/pageBbb");
|
||||||
rowStrings.add("com.isabellasBlog/directoryAa/pageCcc");
|
rowStrings.add("com.isabellasBlog/directoryAa/pageCcc");
|
||||||
rowStrings.add("com.isabellasBlog/directoryAa/pageDdd");
|
rowStrings.add("com.isabellasBlog/directoryAa/pageDdd");
|
||||||
rowStrings.add("com.isabellasBlog/directoryBb/pageEee");
|
rowStrings.add("com.isabellasBlog/directoryBb/pageEee");
|
||||||
rowStrings.add("com.isabellasBlog/directoryBb/pageFff");
|
rowStrings.add("com.isabellasBlog/directoryBb/pageFff");
|
||||||
rowStrings.add("com.isabellasBlog/directoryBb/pageGgg");
|
rowStrings.add("com.isabellasBlog/directoryBb/pageGgg");
|
||||||
rowStrings.add("com.isabellasBlog/directoryBb/pageHhh");
|
rowStrings.add("com.isabellasBlog/directoryBb/pageHhh");
|
||||||
ByteRangeTreeSet ba = new ByteRangeTreeSet();
|
ByteRangeTreeSet ba = new ByteRangeTreeSet();
|
||||||
for(String row : rowStrings){
|
for(String row : rowStrings){
|
||||||
ba.add(new SimpleMutableByteRange(Bytes.toBytes(row)));
|
ba.add(new SimpleMutableByteRange(Bytes.toBytes(row)));
|
||||||
}
|
}
|
||||||
rows = ba.compile().getSortedRanges();
|
rows = ba.compile().getSortedRanges();
|
||||||
}
|
}
|
||||||
|
|
||||||
static List<String> cols = Lists.newArrayList();
|
static List<String> cols = Lists.newArrayList();
|
||||||
static{
|
static{
|
||||||
cols.add("Chrome");
|
cols.add("Chrome");
|
||||||
cols.add("Chromeb");
|
cols.add("Chromeb");
|
||||||
cols.add("Firefox");
|
cols.add("Firefox");
|
||||||
cols.add("InternetExplorer");
|
cols.add("InternetExplorer");
|
||||||
cols.add("Opera");
|
cols.add("Opera");
|
||||||
cols.add("Safari");
|
cols.add("Safari");
|
||||||
cols.add("Z1stBrowserWithHuuuuuuuuuuuugeQualifier");
|
cols.add("Z1stBrowserWithHuuuuuuuuuuuugeQualifier");
|
||||||
cols.add("Z2ndBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z2ndBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z3rdBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z3rdBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z4thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z4thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z5thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z5thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z6thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z6thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z7thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z7thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z8thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z8thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
cols.add("Z9thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
cols.add("Z9thBrowserWithEvenBiggerQualifierMoreMoreMoreMoreMore");
|
||||||
}
|
}
|
||||||
|
|
||||||
static long ts = 1234567890;
|
static long ts = 1234567890;
|
||||||
|
|
||||||
|
|
|
@ -29,31 +29,31 @@ import com.google.common.collect.Lists;
|
||||||
|
|
||||||
public class TestRowDataNub extends BaseTestRowData{
|
public class TestRowDataNub extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
rowA = Bytes.toBytes("rowA"),
|
rowA = Bytes.toBytes("rowA"),
|
||||||
rowB = Bytes.toBytes("rowB"),//nub
|
rowB = Bytes.toBytes("rowB"),//nub
|
||||||
rowBB = Bytes.toBytes("rowBB"),
|
rowBB = Bytes.toBytes("rowBB"),
|
||||||
cf = PrefixTreeTestConstants.TEST_CF,
|
cf = PrefixTreeTestConstants.TEST_CF,
|
||||||
cq0 = Bytes.toBytes("cq0"),
|
cq0 = Bytes.toBytes("cq0"),
|
||||||
cq1 = Bytes.toBytes("cq1"),
|
cq1 = Bytes.toBytes("cq1"),
|
||||||
v0 = Bytes.toBytes("v0");
|
v0 = Bytes.toBytes("v0");
|
||||||
|
|
||||||
static long
|
static long
|
||||||
ts = 55L;
|
ts = 55L;
|
||||||
|
|
||||||
static List<KeyValue> d = Lists.newArrayList();
|
static List<KeyValue> d = Lists.newArrayList();
|
||||||
static{
|
static{
|
||||||
d.add(new KeyValue(rowA, cf, cq0, ts, v0));
|
d.add(new KeyValue(rowA, cf, cq0, ts, v0));
|
||||||
d.add(new KeyValue(rowA, cf, cq1, ts, v0));
|
d.add(new KeyValue(rowA, cf, cq1, ts, v0));
|
||||||
d.add(new KeyValue(rowB, cf, cq0, ts, v0));
|
d.add(new KeyValue(rowB, cf, cq0, ts, v0));
|
||||||
d.add(new KeyValue(rowB, cf, cq1, ts, v0));
|
d.add(new KeyValue(rowB, cf, cq1, ts, v0));
|
||||||
d.add(new KeyValue(rowBB, cf, cq0, ts, v0));
|
d.add(new KeyValue(rowBB, cf, cq0, ts, v0));
|
||||||
d.add(new KeyValue(rowBB, cf, cq1, ts, v0));
|
d.add(new KeyValue(rowBB, cf, cq1, ts, v0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<KeyValue> getInputs() {
|
public List<KeyValue> getInputs() {
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,15 +28,15 @@ import com.google.common.collect.Lists;
|
||||||
|
|
||||||
public class TestRowDataQualifierByteOrdering extends BaseTestRowData{
|
public class TestRowDataQualifierByteOrdering extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
Arow = Bytes.toBytes("Arow"),
|
Arow = Bytes.toBytes("Arow"),
|
||||||
Brow = Bytes.toBytes("Brow"),
|
Brow = Bytes.toBytes("Brow"),
|
||||||
Brow2 = Bytes.toBytes("Brow2"),
|
Brow2 = Bytes.toBytes("Brow2"),
|
||||||
fam = Bytes.toBytes("HappyFam"),
|
fam = Bytes.toBytes("HappyFam"),
|
||||||
cq0 = Bytes.toBytes("cq0"),
|
cq0 = Bytes.toBytes("cq0"),
|
||||||
cq1 = Bytes.toBytes("cq1tail"),//make sure tail does not come back as liat
|
cq1 = Bytes.toBytes("cq1tail"),//make sure tail does not come back as liat
|
||||||
cq2 = Bytes.toBytes("cq2"),
|
cq2 = Bytes.toBytes("cq2"),
|
||||||
v0 = Bytes.toBytes("v0");
|
v0 = Bytes.toBytes("v0");
|
||||||
|
|
||||||
static long ts = 55L;
|
static long ts = 55L;
|
||||||
|
|
||||||
|
|
|
@ -55,13 +55,13 @@ public class TestRowDataSearcherRowMiss extends BaseTestRowData{
|
||||||
d.add(new KeyValue(B, cf, cq, ts, v));
|
d.add(new KeyValue(B, cf, cq, ts, v));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<KeyValue> getInputs() {
|
public List<KeyValue> getInputs() {
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void individualSearcherAssertions(CellSearcher searcher) {
|
public void individualSearcherAssertions(CellSearcher searcher) {
|
||||||
assertRowOffsetsCorrect();
|
assertRowOffsetsCorrect();
|
||||||
|
|
||||||
searcher.resetToBeforeFirstEntry();
|
searcher.resetToBeforeFirstEntry();
|
||||||
|
@ -83,13 +83,13 @@ public class TestRowDataSearcherRowMiss extends BaseTestRowData{
|
||||||
testBetween2and3(searcher);
|
testBetween2and3(searcher);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************ private methods, call from above *******************/
|
/************ private methods, call from above *******************/
|
||||||
|
|
||||||
private void assertRowOffsetsCorrect(){
|
private void assertRowOffsetsCorrect(){
|
||||||
Assert.assertEquals(4, getRowStartIndexes().size());
|
Assert.assertEquals(4, getRowStartIndexes().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testBetween1and2(CellSearcher searcher){
|
private void testBetween1and2(CellSearcher searcher){
|
||||||
CellScannerPosition p;//reuse
|
CellScannerPosition p;//reuse
|
||||||
Cell betweenAAndAAA = new KeyValue(AA, cf, cq, ts-2, v);
|
Cell betweenAAndAAA = new KeyValue(AA, cf, cq, ts-2, v);
|
||||||
|
|
||||||
|
@ -105,7 +105,7 @@ public class TestRowDataSearcherRowMiss extends BaseTestRowData{
|
||||||
p = searcher.positionAtOrAfter(betweenAAndAAA);
|
p = searcher.positionAtOrAfter(betweenAAndAAA);
|
||||||
Assert.assertEquals(CellScannerPosition.AFTER, p);
|
Assert.assertEquals(CellScannerPosition.AFTER, p);
|
||||||
Assert.assertTrue(CellComparator.equals(searcher.current(), d.get(2)));
|
Assert.assertTrue(CellComparator.equals(searcher.current(), d.get(2)));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testBetween2and3(CellSearcher searcher){
|
private void testBetween2and3(CellSearcher searcher){
|
||||||
CellScannerPosition p;//reuse
|
CellScannerPosition p;//reuse
|
||||||
|
|
|
@ -29,12 +29,12 @@ import com.google.common.collect.Lists;
|
||||||
|
|
||||||
public class TestRowDataSingleQualifier extends BaseTestRowData{
|
public class TestRowDataSingleQualifier extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
rowA = Bytes.toBytes("rowA"),
|
rowA = Bytes.toBytes("rowA"),
|
||||||
rowB = Bytes.toBytes("rowB"),
|
rowB = Bytes.toBytes("rowB"),
|
||||||
cf = PrefixTreeTestConstants.TEST_CF,
|
cf = PrefixTreeTestConstants.TEST_CF,
|
||||||
cq0 = Bytes.toBytes("cq0"),
|
cq0 = Bytes.toBytes("cq0"),
|
||||||
v0 = Bytes.toBytes("v0");
|
v0 = Bytes.toBytes("v0");
|
||||||
|
|
||||||
static long ts = 55L;
|
static long ts = 55L;
|
||||||
|
|
||||||
|
|
|
@ -33,12 +33,12 @@ import com.google.common.collect.Lists;
|
||||||
|
|
||||||
public class TestRowDataTrivial extends BaseTestRowData{
|
public class TestRowDataTrivial extends BaseTestRowData{
|
||||||
|
|
||||||
static byte[]
|
static byte[]
|
||||||
rA = Bytes.toBytes("rA"),
|
rA = Bytes.toBytes("rA"),
|
||||||
rB = Bytes.toBytes("rB"),//turn "r" into a branch for the Searcher tests
|
rB = Bytes.toBytes("rB"),//turn "r" into a branch for the Searcher tests
|
||||||
cf = Bytes.toBytes("fam"),
|
cf = Bytes.toBytes("fam"),
|
||||||
cq0 = Bytes.toBytes("q0"),
|
cq0 = Bytes.toBytes("q0"),
|
||||||
v0 = Bytes.toBytes("v0");
|
v0 = Bytes.toBytes("v0");
|
||||||
|
|
||||||
static long ts = 55L;
|
static long ts = 55L;
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ import com.google.common.collect.Lists;
|
||||||
public class TestRowDataUrls extends BaseTestRowData{
|
public class TestRowDataUrls extends BaseTestRowData{
|
||||||
|
|
||||||
static List<ByteRange> rows;
|
static List<ByteRange> rows;
|
||||||
static{
|
static{
|
||||||
List<String> rowStrings = new ArrayList<String>();
|
List<String> rowStrings = new ArrayList<String>();
|
||||||
rowStrings.add("com.edsBlog/directoryAa/pageAaa");
|
rowStrings.add("com.edsBlog/directoryAa/pageAaa");
|
||||||
rowStrings.add("com.edsBlog/directoryAa/pageBbb");
|
rowStrings.add("com.edsBlog/directoryAa/pageBbb");
|
||||||
|
|
|
@ -51,33 +51,33 @@ public class TestRowDataUrlsExample extends BaseTestRowData{
|
||||||
static String FAMILY = "hits";
|
static String FAMILY = "hits";
|
||||||
static List<String> BROWSERS = Lists.newArrayList(
|
static List<String> BROWSERS = Lists.newArrayList(
|
||||||
"Chrome", "IE8", "IE9beta");//, "Opera", "Safari");
|
"Chrome", "IE8", "IE9beta");//, "Opera", "Safari");
|
||||||
static long TIMESTAMP = 1234567890;
|
static long TIMESTAMP = 1234567890;
|
||||||
|
|
||||||
static int MAX_VALUE = 50;
|
static int MAX_VALUE = 50;
|
||||||
|
|
||||||
static List<KeyValue> kvs = Lists.newArrayList();
|
static List<KeyValue> kvs = Lists.newArrayList();
|
||||||
static{
|
static{
|
||||||
for(String rowKey : URLS){
|
for(String rowKey : URLS){
|
||||||
for(String qualifier : BROWSERS){
|
for(String qualifier : BROWSERS){
|
||||||
KeyValue kv = new KeyValue(
|
KeyValue kv = new KeyValue(
|
||||||
Bytes.toBytes(rowKey),
|
Bytes.toBytes(rowKey),
|
||||||
Bytes.toBytes(FAMILY),
|
Bytes.toBytes(FAMILY),
|
||||||
Bytes.toBytes(qualifier),
|
Bytes.toBytes(qualifier),
|
||||||
TIMESTAMP,
|
TIMESTAMP,
|
||||||
KeyValue.Type.Put,
|
KeyValue.Type.Put,
|
||||||
Bytes.toBytes("VvvV"));
|
Bytes.toBytes("VvvV"));
|
||||||
kvs.add(kv);
|
kvs.add(kv);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used for generating docs.
|
* Used for generating docs.
|
||||||
*/
|
*/
|
||||||
public static void main(String... args) throws IOException{
|
public static void main(String... args) throws IOException{
|
||||||
System.out.println("-- inputs --");
|
System.out.println("-- inputs --");
|
||||||
System.out.println(KeyValueTestUtil.toStringWithPadding(kvs, true));
|
System.out.println(KeyValueTestUtil.toStringWithPadding(kvs, true));
|
||||||
ByteArrayOutputStream os = new ByteArrayOutputStream(1<<20);
|
ByteArrayOutputStream os = new ByteArrayOutputStream(1<<20);
|
||||||
PrefixTreeEncoder encoder = new PrefixTreeEncoder(os, false);
|
PrefixTreeEncoder encoder = new PrefixTreeEncoder(os, false);
|
||||||
|
|
||||||
for(KeyValue kv : kvs){
|
for(KeyValue kv : kvs){
|
||||||
|
@ -116,11 +116,11 @@ public class TestRowDataUrlsExample extends BaseTestRowData{
|
||||||
|
|
||||||
System.out.println("-- concatenated values --");
|
System.out.println("-- concatenated values --");
|
||||||
System.out.println(Bytes.toStringBinary(encoder.getValueByteRange().deepCopyToNewArray()));
|
System.out.println(Bytes.toStringBinary(encoder.getValueByteRange().deepCopyToNewArray()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<KeyValue> getInputs() {
|
public List<KeyValue> getInputs() {
|
||||||
return kvs;
|
return kvs;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,39 +40,39 @@ import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
@XmlRootElement(name="ClusterVersion")
|
@XmlRootElement(name="ClusterVersion")
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class StorageClusterVersionModel implements Serializable {
|
public class StorageClusterVersionModel implements Serializable {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private String version;
|
private String version;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the storage cluster version
|
* @return the storage cluster version
|
||||||
*/
|
*/
|
||||||
@XmlValue
|
@XmlValue
|
||||||
public String getVersion() {
|
public String getVersion() {
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param version the storage cluster version
|
* @param version the storage cluster version
|
||||||
*/
|
*/
|
||||||
public void setVersion(String version) {
|
public void setVersion(String version) {
|
||||||
this.version = version;
|
this.version = version;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see java.lang.Object#toString()
|
* @see java.lang.Object#toString()
|
||||||
*/
|
*/
|
||||||
@JsonValue
|
@JsonValue
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
|
|
||||||
//needed for jackson deserialization
|
//needed for jackson deserialization
|
||||||
private static StorageClusterVersionModel valueOf(String value) {
|
private static StorageClusterVersionModel valueOf(String value) {
|
||||||
StorageClusterVersionModel versionModel
|
StorageClusterVersionModel versionModel
|
||||||
= new StorageClusterVersionModel();
|
= new StorageClusterVersionModel();
|
||||||
versionModel.setVersion(value);
|
versionModel.setVersion(value);
|
||||||
return versionModel;
|
return versionModel;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,67 +38,67 @@ import org.apache.hadoop.hbase.rest.protobuf.generated.TableListMessage.TableLis
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class TableListModel implements Serializable, ProtobufMessageHandler {
|
public class TableListModel implements Serializable, ProtobufMessageHandler {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private List<TableModel> tables = new ArrayList<TableModel>();
|
private List<TableModel> tables = new ArrayList<TableModel>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default constructor
|
* Default constructor
|
||||||
*/
|
*/
|
||||||
public TableListModel() {}
|
public TableListModel() {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add the table name model to the list
|
* Add the table name model to the list
|
||||||
* @param table the table model
|
* @param table the table model
|
||||||
*/
|
*/
|
||||||
public void add(TableModel table) {
|
public void add(TableModel table) {
|
||||||
tables.add(table);
|
tables.add(table);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param index the index
|
* @param index the index
|
||||||
* @return the table model
|
* @return the table model
|
||||||
*/
|
*/
|
||||||
public TableModel get(int index) {
|
public TableModel get(int index) {
|
||||||
return tables.get(index);
|
return tables.get(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the tables
|
* @return the tables
|
||||||
*/
|
*/
|
||||||
@XmlElementRef(name="table")
|
@XmlElementRef(name="table")
|
||||||
public List<TableModel> getTables() {
|
public List<TableModel> getTables() {
|
||||||
return tables;
|
return tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param tables the tables to set
|
* @param tables the tables to set
|
||||||
*/
|
*/
|
||||||
public void setTables(List<TableModel> tables) {
|
public void setTables(List<TableModel> tables) {
|
||||||
this.tables = tables;
|
this.tables = tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see java.lang.Object#toString()
|
* @see java.lang.Object#toString()
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
for(TableModel aTable : tables) {
|
for(TableModel aTable : tables) {
|
||||||
sb.append(aTable.toString());
|
sb.append(aTable.toString());
|
||||||
sb.append('\n');
|
sb.append('\n');
|
||||||
}
|
}
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public byte[] createProtobufOutput() {
|
public byte[] createProtobufOutput() {
|
||||||
TableList.Builder builder = TableList.newBuilder();
|
TableList.Builder builder = TableList.newBuilder();
|
||||||
for (TableModel aTable : tables) {
|
for (TableModel aTable : tables) {
|
||||||
builder.addName(aTable.getName());
|
builder.addName(aTable.getName());
|
||||||
}
|
}
|
||||||
return builder.build().toByteArray();
|
return builder.build().toByteArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
|
|
|
@ -41,44 +41,44 @@ import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class TableModel implements Serializable {
|
public class TableModel implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default constructor
|
* Default constructor
|
||||||
*/
|
*/
|
||||||
public TableModel() {}
|
public TableModel() {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
* @param name
|
* @param name
|
||||||
*/
|
*/
|
||||||
public TableModel(String name) {
|
public TableModel(String name) {
|
||||||
super();
|
super();
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the name
|
* @return the name
|
||||||
*/
|
*/
|
||||||
@XmlAttribute
|
@XmlAttribute
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param name the name to set
|
* @param name the name to set
|
||||||
*/
|
*/
|
||||||
public void setName(String name) {
|
public void setName(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see java.lang.Object#toString()
|
* @see java.lang.Object#toString()
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return this.name;
|
return this.name;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,9 +48,9 @@ import com.sun.jersey.spi.container.servlet.ServletContainer;
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class VersionModel implements Serializable, ProtobufMessageHandler {
|
public class VersionModel implements Serializable, ProtobufMessageHandler {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private String restVersion;
|
private String restVersion;
|
||||||
private String jvmVersion;
|
private String jvmVersion;
|
||||||
private String osVersion;
|
private String osVersion;
|
||||||
private String serverVersion;
|
private String serverVersion;
|
||||||
|
@ -65,30 +65,30 @@ public class VersionModel implements Serializable, ProtobufMessageHandler {
|
||||||
* Constructor
|
* Constructor
|
||||||
* @param context the servlet context
|
* @param context the servlet context
|
||||||
*/
|
*/
|
||||||
public VersionModel(ServletContext context) {
|
public VersionModel(ServletContext context) {
|
||||||
restVersion = RESTServlet.VERSION_STRING;
|
restVersion = RESTServlet.VERSION_STRING;
|
||||||
jvmVersion = System.getProperty("java.vm.vendor") + ' ' +
|
jvmVersion = System.getProperty("java.vm.vendor") + ' ' +
|
||||||
System.getProperty("java.version") + '-' +
|
System.getProperty("java.version") + '-' +
|
||||||
System.getProperty("java.vm.version");
|
System.getProperty("java.vm.version");
|
||||||
osVersion = System.getProperty("os.name") + ' ' +
|
osVersion = System.getProperty("os.name") + ' ' +
|
||||||
System.getProperty("os.version") + ' ' +
|
System.getProperty("os.version") + ' ' +
|
||||||
System.getProperty("os.arch");
|
System.getProperty("os.arch");
|
||||||
serverVersion = context.getServerInfo();
|
serverVersion = context.getServerInfo();
|
||||||
jerseyVersion = ServletContainer.class.getPackage()
|
jerseyVersion = ServletContainer.class.getPackage()
|
||||||
.getImplementationVersion();
|
.getImplementationVersion();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the REST gateway version
|
* @return the REST gateway version
|
||||||
*/
|
*/
|
||||||
@XmlAttribute(name="REST")
|
@XmlAttribute(name="REST")
|
||||||
public String getRESTVersion() {
|
public String getRESTVersion() {
|
||||||
return restVersion;
|
return restVersion;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the JVM vendor and version
|
* @return the JVM vendor and version
|
||||||
*/
|
*/
|
||||||
@XmlAttribute(name="JVM")
|
@XmlAttribute(name="JVM")
|
||||||
public String getJVMVersion() {
|
public String getJVMVersion() {
|
||||||
return jvmVersion;
|
return jvmVersion;
|
||||||
|
@ -154,34 +154,34 @@ public class VersionModel implements Serializable, ProtobufMessageHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see java.lang.Object#toString()
|
* @see java.lang.Object#toString()
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
sb.append("rest ");
|
sb.append("rest ");
|
||||||
sb.append(restVersion);
|
sb.append(restVersion);
|
||||||
sb.append(" [JVM: ");
|
sb.append(" [JVM: ");
|
||||||
sb.append(jvmVersion);
|
sb.append(jvmVersion);
|
||||||
sb.append("] [OS: ");
|
sb.append("] [OS: ");
|
||||||
sb.append(osVersion);
|
sb.append(osVersion);
|
||||||
sb.append("] [Server: ");
|
sb.append("] [Server: ");
|
||||||
sb.append(serverVersion);
|
sb.append(serverVersion);
|
||||||
sb.append("] [Jersey: ");
|
sb.append("] [Jersey: ");
|
||||||
sb.append(jerseyVersion);
|
sb.append(jerseyVersion);
|
||||||
sb.append("]\n");
|
sb.append("]\n");
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public byte[] createProtobufOutput() {
|
public byte[] createProtobufOutput() {
|
||||||
Version.Builder builder = Version.newBuilder();
|
Version.Builder builder = Version.newBuilder();
|
||||||
builder.setRestVersion(restVersion);
|
builder.setRestVersion(restVersion);
|
||||||
builder.setJvmVersion(jvmVersion);
|
builder.setJvmVersion(jvmVersion);
|
||||||
builder.setOsVersion(osVersion);
|
builder.setOsVersion(osVersion);
|
||||||
builder.setServerVersion(serverVersion);
|
builder.setServerVersion(serverVersion);
|
||||||
builder.setJerseyVersion(jerseyVersion);
|
builder.setJerseyVersion(jerseyVersion);
|
||||||
return builder.build().toByteArray();
|
return builder.build().toByteArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -55,12 +55,12 @@ import com.sun.jersey.api.json.JSONJAXBContext;
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class JAXBContextResolver implements ContextResolver<JAXBContext> {
|
public class JAXBContextResolver implements ContextResolver<JAXBContext> {
|
||||||
|
|
||||||
private final JAXBContext context;
|
private final JAXBContext context;
|
||||||
|
|
||||||
private final Set<Class<?>> types;
|
private final Set<Class<?>> types;
|
||||||
|
|
||||||
private final Class<?>[] cTypes = {
|
private final Class<?>[] cTypes = {
|
||||||
CellModel.class,
|
CellModel.class,
|
||||||
CellSetModel.class,
|
CellSetModel.class,
|
||||||
ColumnSchemaModel.class,
|
ColumnSchemaModel.class,
|
||||||
RowModel.class,
|
RowModel.class,
|
||||||
|
@ -68,22 +68,22 @@ public class JAXBContextResolver implements ContextResolver<JAXBContext> {
|
||||||
StorageClusterStatusModel.class,
|
StorageClusterStatusModel.class,
|
||||||
StorageClusterVersionModel.class,
|
StorageClusterVersionModel.class,
|
||||||
TableInfoModel.class,
|
TableInfoModel.class,
|
||||||
TableListModel.class,
|
TableListModel.class,
|
||||||
TableModel.class,
|
TableModel.class,
|
||||||
TableRegionModel.class,
|
TableRegionModel.class,
|
||||||
TableSchemaModel.class,
|
TableSchemaModel.class,
|
||||||
VersionModel.class
|
VersionModel.class
|
||||||
};
|
};
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public JAXBContextResolver() throws Exception {
|
public JAXBContextResolver() throws Exception {
|
||||||
this.types = new HashSet(Arrays.asList(cTypes));
|
this.types = new HashSet(Arrays.asList(cTypes));
|
||||||
this.context = new JSONJAXBContext(JSONConfiguration.natural().build(),
|
this.context = new JSONJAXBContext(JSONConfiguration.natural().build(),
|
||||||
cTypes);
|
cTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JAXBContext getContext(Class<?> objectType) {
|
public JAXBContext getContext(Class<?> objectType) {
|
||||||
return (types.contains(objectType)) ? context : null;
|
return (types.contains(objectType)) ? context : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -54,21 +54,21 @@ public class PlainTextMessageBodyProducer
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public long getSize(Object object, Class<?> type, Type genericType,
|
public long getSize(Object object, Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType) {
|
Annotation[] annotations, MediaType mediaType) {
|
||||||
byte[] bytes = object.toString().getBytes();
|
byte[] bytes = object.toString().getBytes();
|
||||||
buffer.set(bytes);
|
buffer.set(bytes);
|
||||||
return bytes.length;
|
return bytes.length;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeTo(Object object, Class<?> type, Type genericType,
|
public void writeTo(Object object, Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType,
|
Annotation[] annotations, MediaType mediaType,
|
||||||
MultivaluedMap<String, Object> httpHeaders, OutputStream outStream)
|
MultivaluedMap<String, Object> httpHeaders, OutputStream outStream)
|
||||||
throws IOException, WebApplicationException {
|
throws IOException, WebApplicationException {
|
||||||
byte[] bytes = buffer.get();
|
byte[] bytes = buffer.get();
|
||||||
outStream.write(bytes);
|
outStream.write(bytes);
|
||||||
buffer.remove();
|
buffer.remove();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,32 +50,32 @@ public class ProtobufMessageBodyProducer
|
||||||
|
|
||||||
private ThreadLocal<byte[]> buffer = new ThreadLocal<byte[]>();
|
private ThreadLocal<byte[]> buffer = new ThreadLocal<byte[]>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isWriteable(Class<?> type, Type genericType,
|
public boolean isWriteable(Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType) {
|
Annotation[] annotations, MediaType mediaType) {
|
||||||
return ProtobufMessageHandler.class.isAssignableFrom(type);
|
return ProtobufMessageHandler.class.isAssignableFrom(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public long getSize(ProtobufMessageHandler m, Class<?> type, Type genericType,
|
public long getSize(ProtobufMessageHandler m, Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType) {
|
Annotation[] annotations, MediaType mediaType) {
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
try {
|
try {
|
||||||
baos.write(m.createProtobufOutput());
|
baos.write(m.createProtobufOutput());
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
byte[] bytes = baos.toByteArray();
|
byte[] bytes = baos.toByteArray();
|
||||||
buffer.set(bytes);
|
buffer.set(bytes);
|
||||||
return bytes.length;
|
return bytes.length;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeTo(ProtobufMessageHandler m, Class<?> type, Type genericType,
|
public void writeTo(ProtobufMessageHandler m, Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType,
|
Annotation[] annotations, MediaType mediaType,
|
||||||
MultivaluedMap<String, Object> httpHeaders, OutputStream entityStream)
|
MultivaluedMap<String, Object> httpHeaders, OutputStream entityStream)
|
||||||
throws IOException, WebApplicationException {
|
throws IOException, WebApplicationException {
|
||||||
byte[] bytes = buffer.get();
|
byte[] bytes = buffer.get();
|
||||||
entityStream.write(bytes);
|
entityStream.write(bytes);
|
||||||
buffer.remove();
|
buffer.remove();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,10 +26,10 @@ import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
*/
|
*/
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public interface HBaseRPCErrorHandler {
|
public interface HBaseRPCErrorHandler {
|
||||||
/**
|
/**
|
||||||
* Take actions on the event of an OutOfMemoryError.
|
* Take actions on the event of an OutOfMemoryError.
|
||||||
* @param e the throwable
|
* @param e the throwable
|
||||||
* @return if the server should be shut down
|
* @return if the server should be shut down
|
||||||
*/
|
*/
|
||||||
boolean checkOOME(final Throwable e) ;
|
boolean checkOOME(final Throwable e) ;
|
||||||
}
|
}
|
||||||
|
|
|
@ -976,7 +976,7 @@ public class RegionPlacementMaintainer {
|
||||||
opt.addOption("munkres", false,
|
opt.addOption("munkres", false,
|
||||||
"use munkres to place secondaries and tertiaries");
|
"use munkres to place secondaries and tertiaries");
|
||||||
opt.addOption("ld", "locality-dispersion", false, "print locality and dispersion " +
|
opt.addOption("ld", "locality-dispersion", false, "print locality and dispersion " +
|
||||||
"information for current plan");
|
"information for current plan");
|
||||||
try {
|
try {
|
||||||
// Set the log4j
|
// Set the log4j
|
||||||
Logger.getLogger("org.apache.zookeeper").setLevel(Level.ERROR);
|
Logger.getLogger("org.apache.zookeeper").setLevel(Level.ERROR);
|
||||||
|
|
|
@ -94,7 +94,7 @@ public class SnapshotOfRegionAssignmentFromMeta {
|
||||||
*/
|
*/
|
||||||
public void initialize() throws IOException {
|
public void initialize() throws IOException {
|
||||||
LOG.info("Start to scan the hbase:meta for the current region assignment " +
|
LOG.info("Start to scan the hbase:meta for the current region assignment " +
|
||||||
"snappshot");
|
"snappshot");
|
||||||
// TODO: at some point this code could live in the MetaTableAccessor
|
// TODO: at some point this code could live in the MetaTableAccessor
|
||||||
Visitor v = new Visitor() {
|
Visitor v = new Visitor() {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -183,9 +183,9 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Chore
|
||||||
// if the directory still has children, we can't delete it, so we are done
|
// if the directory still has children, we can't delete it, so we are done
|
||||||
if (!allChildrenDeleted) return false;
|
if (!allChildrenDeleted) return false;
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e = e instanceof RemoteException ?
|
e = e instanceof RemoteException ?
|
||||||
((RemoteException)e).unwrapRemoteException() : e;
|
((RemoteException)e).unwrapRemoteException() : e;
|
||||||
LOG.warn("Error while listing directory: " + dir, e);
|
LOG.warn("Error while listing directory: " + dir, e);
|
||||||
// couldn't list directory, so don't try to delete, and don't return success
|
// couldn't list directory, so don't try to delete, and don't return success
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -390,9 +390,9 @@ class MemStoreFlusher implements FlushRequester {
|
||||||
this.server.compactSplitThread.requestSystemCompaction(
|
this.server.compactSplitThread.requestSystemCompaction(
|
||||||
region, Thread.currentThread().getName());
|
region, Thread.currentThread().getName());
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e = e instanceof RemoteException ?
|
e = e instanceof RemoteException ?
|
||||||
((RemoteException)e).unwrapRemoteException() : e;
|
((RemoteException)e).unwrapRemoteException() : e;
|
||||||
LOG.error(
|
LOG.error(
|
||||||
"Cache flush failed for region " + Bytes.toStringBinary(region.getRegionName()),
|
"Cache flush failed for region " + Bytes.toStringBinary(region.getRegionName()),
|
||||||
e);
|
e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,7 +115,7 @@ public class SplitLogWorker implements Runnable {
|
||||||
|| cause instanceof ConnectException
|
|| cause instanceof ConnectException
|
||||||
|| cause instanceof SocketTimeoutException)) {
|
|| cause instanceof SocketTimeoutException)) {
|
||||||
LOG.warn("log replaying of " + filename + " can't connect to the target regionserver, "
|
LOG.warn("log replaying of " + filename + " can't connect to the target regionserver, "
|
||||||
+ "resigning", e);
|
+ "resigning", e);
|
||||||
return Status.RESIGNED;
|
return Status.RESIGNED;
|
||||||
} else if (cause instanceof InterruptedException) {
|
} else if (cause instanceof InterruptedException) {
|
||||||
LOG.warn("log splitting of " + filename + " interrupted, resigning", e);
|
LOG.warn("log splitting of " + filename + " interrupted, resigning", e);
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class WALSplitterHandler extends EventHandler {
|
||||||
public WALSplitterHandler(final Server server, SplitLogWorkerCoordination coordination,
|
public WALSplitterHandler(final Server server, SplitLogWorkerCoordination coordination,
|
||||||
SplitLogWorkerCoordination.SplitTaskDetails splitDetails, CancelableProgressable reporter,
|
SplitLogWorkerCoordination.SplitTaskDetails splitDetails, CancelableProgressable reporter,
|
||||||
AtomicInteger inProgressTasks, TaskExecutor splitTaskExecutor, RecoveryMode mode) {
|
AtomicInteger inProgressTasks, TaskExecutor splitTaskExecutor, RecoveryMode mode) {
|
||||||
super(server, EventType.RS_LOG_REPLAY);
|
super(server, EventType.RS_LOG_REPLAY);
|
||||||
this.splitTaskDetails = splitDetails;
|
this.splitTaskDetails = splitDetails;
|
||||||
this.coordination = coordination;
|
this.coordination = coordination;
|
||||||
this.reporter = reporter;
|
this.reporter = reporter;
|
||||||
|
|
|
@ -367,8 +367,8 @@ public class HBaseFsck extends Configured {
|
||||||
if (hbckOutFd == null) {
|
if (hbckOutFd == null) {
|
||||||
setRetCode(-1);
|
setRetCode(-1);
|
||||||
LOG.error("Another instance of hbck is running, exiting this instance.[If you are sure" +
|
LOG.error("Another instance of hbck is running, exiting this instance.[If you are sure" +
|
||||||
" no other instance is running, delete the lock file " +
|
" no other instance is running, delete the lock file " +
|
||||||
HBCK_LOCK_PATH + " and rerun the tool]");
|
HBCK_LOCK_PATH + " and rerun the tool]");
|
||||||
throw new IOException("Duplicate hbck - Abort");
|
throw new IOException("Duplicate hbck - Abort");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1640,8 +1640,8 @@ public class HBaseFsck extends Configured {
|
||||||
*/
|
*/
|
||||||
private void checkAndFixConsistency()
|
private void checkAndFixConsistency()
|
||||||
throws IOException, KeeperException, InterruptedException {
|
throws IOException, KeeperException, InterruptedException {
|
||||||
// Divide the checks in two phases. One for default/primary replicas and another
|
// Divide the checks in two phases. One for default/primary replicas and another
|
||||||
// for the non-primary ones. Keeps code cleaner this way.
|
// for the non-primary ones. Keeps code cleaner this way.
|
||||||
for (java.util.Map.Entry<String, HbckInfo> e: regionInfoMap.entrySet()) {
|
for (java.util.Map.Entry<String, HbckInfo> e: regionInfoMap.entrySet()) {
|
||||||
if (e.getValue().getReplicaId() == HRegionInfo.DEFAULT_REPLICA_ID) {
|
if (e.getValue().getReplicaId() == HRegionInfo.DEFAULT_REPLICA_ID) {
|
||||||
checkRegionConsistency(e.getKey(), e.getValue());
|
checkRegionConsistency(e.getKey(), e.getValue());
|
||||||
|
@ -1890,8 +1890,8 @@ public class HBaseFsck extends Configured {
|
||||||
private void checkRegionConsistency(final String key, final HbckInfo hbi)
|
private void checkRegionConsistency(final String key, final HbckInfo hbi)
|
||||||
throws IOException, KeeperException, InterruptedException {
|
throws IOException, KeeperException, InterruptedException {
|
||||||
|
|
||||||
if (hbi.isSkipChecks()) return;
|
if (hbi.isSkipChecks()) return;
|
||||||
String descriptiveName = hbi.toString();
|
String descriptiveName = hbi.toString();
|
||||||
boolean inMeta = hbi.metaEntry != null;
|
boolean inMeta = hbi.metaEntry != null;
|
||||||
// In case not checking HDFS, assume the region is on HDFS
|
// In case not checking HDFS, assume the region is on HDFS
|
||||||
boolean inHdfs = !shouldCheckHdfs() || hbi.getHdfsRegionDir() != null;
|
boolean inHdfs = !shouldCheckHdfs() || hbi.getHdfsRegionDir() != null;
|
||||||
|
|
|
@ -50,7 +50,7 @@ import org.apache.zookeeper.KeeperException;
|
||||||
public class RegionServerTracker extends ZooKeeperListener {
|
public class RegionServerTracker extends ZooKeeperListener {
|
||||||
private static final Log LOG = LogFactory.getLog(RegionServerTracker.class);
|
private static final Log LOG = LogFactory.getLog(RegionServerTracker.class);
|
||||||
private NavigableMap<ServerName, RegionServerInfo> regionServers =
|
private NavigableMap<ServerName, RegionServerInfo> regionServers =
|
||||||
new TreeMap<ServerName, RegionServerInfo>();
|
new TreeMap<ServerName, RegionServerInfo>();
|
||||||
private ServerManager serverManager;
|
private ServerManager serverManager;
|
||||||
private Server server;
|
private Server server;
|
||||||
|
|
||||||
|
|
|
@ -1032,8 +1032,8 @@ public class HBaseTestingUtility extends HBaseCommonTestingUtility {
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public Path getDefaultRootDirPath() throws IOException {
|
public Path getDefaultRootDirPath() throws IOException {
|
||||||
FileSystem fs = FileSystem.get(this.conf);
|
FileSystem fs = FileSystem.get(this.conf);
|
||||||
return new Path(fs.makeQualified(fs.getHomeDirectory()),"hbase");
|
return new Path(fs.makeQualified(fs.getHomeDirectory()),"hbase");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -135,7 +135,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal median = aClient.median(TEST_TABLE, ci, scan);
|
BigDecimal median = aClient.median(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("8.00"), median);
|
assertEquals(new BigDecimal("8.00"), median);
|
||||||
}
|
}
|
||||||
|
@ -154,7 +154,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal maximum = aClient.max(TEST_TABLE, ci, scan);
|
BigDecimal maximum = aClient.max(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("19.00"), maximum);
|
assertEquals(new BigDecimal("19.00"), maximum);
|
||||||
}
|
}
|
||||||
|
@ -203,7 +203,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
public void testMaxWithValidRangeWithNullCF() {
|
public void testMaxWithValidRangeWithNullCF() {
|
||||||
AggregationClient aClient = new AggregationClient(conf);
|
AggregationClient aClient = new AggregationClient(conf);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
BigDecimal max = null;
|
BigDecimal max = null;
|
||||||
try {
|
try {
|
||||||
|
@ -219,7 +219,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
public void testMaxWithInvalidRange() {
|
public void testMaxWithInvalidRange() {
|
||||||
AggregationClient aClient = new AggregationClient(conf);
|
AggregationClient aClient = new AggregationClient(conf);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.setStartRow(ROWS[4]);
|
scan.setStartRow(ROWS[4]);
|
||||||
scan.setStopRow(ROWS[2]);
|
scan.setStopRow(ROWS[2]);
|
||||||
|
@ -244,7 +244,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
try {
|
try {
|
||||||
AggregationClient aClient = new AggregationClient(conf);
|
AggregationClient aClient = new AggregationClient(conf);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
max = aClient.max(TEST_TABLE, ci, scan);
|
max = aClient.max(TEST_TABLE, ci, scan);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
max = BigDecimal.ZERO;
|
max = BigDecimal.ZERO;
|
||||||
|
@ -261,7 +261,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Filter f = new PrefixFilter(Bytes.toBytes("foo:bar"));
|
Filter f = new PrefixFilter(Bytes.toBytes("foo:bar"));
|
||||||
scan.setFilter(f);
|
scan.setFilter(f);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
max = aClient.max(TEST_TABLE, ci, scan);
|
max = aClient.max(TEST_TABLE, ci, scan);
|
||||||
assertEquals(null, max);
|
assertEquals(null, max);
|
||||||
}
|
}
|
||||||
|
@ -281,7 +281,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(HConstants.EMPTY_START_ROW);
|
scan.setStartRow(HConstants.EMPTY_START_ROW);
|
||||||
scan.setStopRow(HConstants.EMPTY_END_ROW);
|
scan.setStopRow(HConstants.EMPTY_END_ROW);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("0.00"), min);
|
assertEquals(new BigDecimal("0.00"), min);
|
||||||
}
|
}
|
||||||
|
@ -297,7 +297,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[5]);
|
scan.setStartRow(ROWS[5]);
|
||||||
scan.setStopRow(ROWS[15]);
|
scan.setStopRow(ROWS[15]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("5.00"), min);
|
assertEquals(new BigDecimal("5.00"), min);
|
||||||
}
|
}
|
||||||
|
@ -310,7 +310,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(HConstants.EMPTY_START_ROW);
|
scan.setStartRow(HConstants.EMPTY_START_ROW);
|
||||||
scan.setStopRow(HConstants.EMPTY_END_ROW);
|
scan.setStopRow(HConstants.EMPTY_END_ROW);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("0.00"), min);
|
assertEquals(new BigDecimal("0.00"), min);
|
||||||
}
|
}
|
||||||
|
@ -323,7 +323,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[7]);
|
scan.setStopRow(ROWS[7]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
BigDecimal min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("0.60"), min);
|
assertEquals(new BigDecimal("0.60"), min);
|
||||||
}
|
}
|
||||||
|
@ -335,7 +335,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[5]);
|
scan.setStartRow(ROWS[5]);
|
||||||
scan.setStopRow(ROWS[15]);
|
scan.setStopRow(ROWS[15]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = null;
|
BigDecimal min = null;
|
||||||
try {
|
try {
|
||||||
min = aClient.min(TEST_TABLE, ci, scan);
|
min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
|
@ -354,7 +354,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[4]);
|
scan.setStartRow(ROWS[4]);
|
||||||
scan.setStopRow(ROWS[2]);
|
scan.setStopRow(ROWS[2]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
try {
|
try {
|
||||||
min = aClient.min(TEST_TABLE, ci, scan);
|
min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
|
@ -370,7 +370,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[6]);
|
scan.setStopRow(ROWS[6]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = null;
|
BigDecimal min = null;
|
||||||
try {
|
try {
|
||||||
min = aClient.min(TEST_TABLE, ci, scan);
|
min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
|
@ -387,7 +387,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Filter f = new PrefixFilter(Bytes.toBytes("foo:bar"));
|
Filter f = new PrefixFilter(Bytes.toBytes("foo:bar"));
|
||||||
scan.setFilter(f);
|
scan.setFilter(f);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal min = null;
|
BigDecimal min = null;
|
||||||
min = aClient.min(TEST_TABLE, ci, scan);
|
min = aClient.min(TEST_TABLE, ci, scan);
|
||||||
assertEquals(null, min);
|
assertEquals(null, min);
|
||||||
|
@ -405,7 +405,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("190.00"), sum);
|
assertEquals(new BigDecimal("190.00"), sum);
|
||||||
}
|
}
|
||||||
|
@ -421,7 +421,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[5]);
|
scan.setStartRow(ROWS[5]);
|
||||||
scan.setStopRow(ROWS[15]);
|
scan.setStopRow(ROWS[15]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("95.00"), sum);
|
assertEquals(new BigDecimal("95.00"), sum);
|
||||||
}
|
}
|
||||||
|
@ -432,7 +432,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addFamily(TEST_FAMILY);
|
scan.addFamily(TEST_FAMILY);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("209.00"), sum); // 190 + 19
|
assertEquals(new BigDecimal("209.00"), sum); // 190 + 19
|
||||||
}
|
}
|
||||||
|
@ -445,7 +445,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[7]);
|
scan.setStopRow(ROWS[7]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
BigDecimal sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
assertEquals(new BigDecimal("6.60"), sum); // 6 + 60
|
assertEquals(new BigDecimal("6.60"), sum); // 6 + 60
|
||||||
}
|
}
|
||||||
|
@ -457,7 +457,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[7]);
|
scan.setStopRow(ROWS[7]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = null;
|
BigDecimal sum = null;
|
||||||
try {
|
try {
|
||||||
sum = aClient.sum(TEST_TABLE, ci, scan);
|
sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
|
@ -475,7 +475,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[2]);
|
scan.setStopRow(ROWS[2]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = null;
|
BigDecimal sum = null;
|
||||||
try {
|
try {
|
||||||
sum = aClient.sum(TEST_TABLE, ci, scan);
|
sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
|
@ -492,7 +492,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.addFamily(TEST_FAMILY);
|
scan.addFamily(TEST_FAMILY);
|
||||||
scan.setFilter(f);
|
scan.setFilter(f);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
BigDecimal sum = null;
|
BigDecimal sum = null;
|
||||||
sum = aClient.sum(TEST_TABLE, ci, scan);
|
sum = aClient.sum(TEST_TABLE, ci, scan);
|
||||||
assertEquals(null, sum);
|
assertEquals(null, sum);
|
||||||
|
@ -510,7 +510,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
assertEquals(9.5, avg, 0);
|
assertEquals(9.5, avg, 0);
|
||||||
}
|
}
|
||||||
|
@ -526,7 +526,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[5]);
|
scan.setStartRow(ROWS[5]);
|
||||||
scan.setStopRow(ROWS[15]);
|
scan.setStopRow(ROWS[15]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
assertEquals(9.5, avg, 0);
|
assertEquals(9.5, avg, 0);
|
||||||
}
|
}
|
||||||
|
@ -537,7 +537,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addFamily(TEST_FAMILY);
|
scan.addFamily(TEST_FAMILY);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
assertEquals(10.45, avg, 0.01);
|
assertEquals(10.45, avg, 0.01);
|
||||||
}
|
}
|
||||||
|
@ -550,7 +550,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[7]);
|
scan.setStopRow(ROWS[7]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
double avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
assertEquals(6 + 0.60, avg, 0);
|
assertEquals(6 + 0.60, avg, 0);
|
||||||
}
|
}
|
||||||
|
@ -560,7 +560,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
AggregationClient aClient = new AggregationClient(conf);
|
AggregationClient aClient = new AggregationClient(conf);
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Double avg = null;
|
Double avg = null;
|
||||||
try {
|
try {
|
||||||
avg = aClient.avg(TEST_TABLE, ci, scan);
|
avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
|
@ -578,7 +578,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[5]);
|
scan.setStartRow(ROWS[5]);
|
||||||
scan.setStopRow(ROWS[1]);
|
scan.setStopRow(ROWS[1]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Double avg = null;
|
Double avg = null;
|
||||||
try {
|
try {
|
||||||
avg = aClient.avg(TEST_TABLE, ci, scan);
|
avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
|
@ -595,7 +595,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Filter f = new PrefixFilter(Bytes.toBytes("foo:bar"));
|
Filter f = new PrefixFilter(Bytes.toBytes("foo:bar"));
|
||||||
scan.setFilter(f);
|
scan.setFilter(f);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Double avg = null;
|
Double avg = null;
|
||||||
avg = aClient.avg(TEST_TABLE, ci, scan);
|
avg = aClient.avg(TEST_TABLE, ci, scan);
|
||||||
assertEquals(Double.NaN, avg, 0);
|
assertEquals(Double.NaN, avg, 0);
|
||||||
|
@ -613,7 +613,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
scan.addColumn(TEST_FAMILY, TEST_QUALIFIER);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double std = aClient.std(TEST_TABLE, ci, scan);
|
double std = aClient.std(TEST_TABLE, ci, scan);
|
||||||
assertEquals(5.766, std, 0.05d);
|
assertEquals(5.766, std, 0.05d);
|
||||||
}
|
}
|
||||||
|
@ -630,7 +630,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[5]);
|
scan.setStartRow(ROWS[5]);
|
||||||
scan.setStopRow(ROWS[15]);
|
scan.setStopRow(ROWS[15]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double std = aClient.std(TEST_TABLE, ci, scan);
|
double std = aClient.std(TEST_TABLE, ci, scan);
|
||||||
assertEquals(2.87, std, 0.05d);
|
assertEquals(2.87, std, 0.05d);
|
||||||
}
|
}
|
||||||
|
@ -645,7 +645,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
Scan scan = new Scan();
|
Scan scan = new Scan();
|
||||||
scan.addFamily(TEST_FAMILY);
|
scan.addFamily(TEST_FAMILY);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double std = aClient.std(TEST_TABLE, ci, scan);
|
double std = aClient.std(TEST_TABLE, ci, scan);
|
||||||
assertEquals(6.342, std, 0.05d);
|
assertEquals(6.342, std, 0.05d);
|
||||||
}
|
}
|
||||||
|
@ -658,7 +658,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[7]);
|
scan.setStopRow(ROWS[7]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
double std = aClient.std(TEST_TABLE, ci, scan);
|
double std = aClient.std(TEST_TABLE, ci, scan);
|
||||||
System.out.println("std is:" + std);
|
System.out.println("std is:" + std);
|
||||||
assertEquals(0, std, 0.05d);
|
assertEquals(0, std, 0.05d);
|
||||||
|
@ -671,7 +671,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[17]);
|
scan.setStopRow(ROWS[17]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Double std = null;
|
Double std = null;
|
||||||
try {
|
try {
|
||||||
std = aClient.std(TEST_TABLE, ci, scan);
|
std = aClient.std(TEST_TABLE, ci, scan);
|
||||||
|
@ -689,7 +689,7 @@ public class TestBigDecimalColumnInterpreter {
|
||||||
scan.setStartRow(ROWS[6]);
|
scan.setStartRow(ROWS[6]);
|
||||||
scan.setStopRow(ROWS[1]);
|
scan.setStopRow(ROWS[1]);
|
||||||
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
final ColumnInterpreter<BigDecimal, BigDecimal, EmptyMsg, BigDecimalMsg, BigDecimalMsg> ci =
|
||||||
new BigDecimalColumnInterpreter();
|
new BigDecimalColumnInterpreter();
|
||||||
Double std = null;
|
Double std = null;
|
||||||
try {
|
try {
|
||||||
std = aClient.std(TEST_TABLE, ci, scan);
|
std = aClient.std(TEST_TABLE, ci, scan);
|
||||||
|
|
|
@ -50,18 +50,18 @@ import org.junit.experimental.categories.Category;
|
||||||
public class TestDependentColumnFilter {
|
public class TestDependentColumnFilter {
|
||||||
private final Log LOG = LogFactory.getLog(this.getClass());
|
private final Log LOG = LogFactory.getLog(this.getClass());
|
||||||
private static final byte[][] ROWS = {
|
private static final byte[][] ROWS = {
|
||||||
Bytes.toBytes("test1"),Bytes.toBytes("test2")
|
Bytes.toBytes("test1"),Bytes.toBytes("test2")
|
||||||
};
|
};
|
||||||
private static final byte[][] FAMILIES = {
|
private static final byte[][] FAMILIES = {
|
||||||
Bytes.toBytes("familyOne"),Bytes.toBytes("familyTwo")
|
Bytes.toBytes("familyOne"),Bytes.toBytes("familyTwo")
|
||||||
};
|
};
|
||||||
private static final long STAMP_BASE = System.currentTimeMillis();
|
private static final long STAMP_BASE = System.currentTimeMillis();
|
||||||
private static final long[] STAMPS = {
|
private static final long[] STAMPS = {
|
||||||
STAMP_BASE-100, STAMP_BASE-200, STAMP_BASE-300
|
STAMP_BASE-100, STAMP_BASE-200, STAMP_BASE-300
|
||||||
};
|
};
|
||||||
private static final byte[] QUALIFIER = Bytes.toBytes("qualifier");
|
private static final byte[] QUALIFIER = Bytes.toBytes("qualifier");
|
||||||
private static final byte[][] BAD_VALS = {
|
private static final byte[][] BAD_VALS = {
|
||||||
Bytes.toBytes("bad1"), Bytes.toBytes("bad2"), Bytes.toBytes("bad3")
|
Bytes.toBytes("bad1"), Bytes.toBytes("bad2"), Bytes.toBytes("bad3")
|
||||||
};
|
};
|
||||||
private static final byte[] MATCH_VAL = Bytes.toBytes("match");
|
private static final byte[] MATCH_VAL = Bytes.toBytes("match");
|
||||||
private final static HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility();
|
private final static HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility();
|
||||||
|
@ -119,14 +119,14 @@ public class TestDependentColumnFilter {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<KeyValue> makeTestVals() {
|
private List<KeyValue> makeTestVals() {
|
||||||
List<KeyValue> testVals = new ArrayList<KeyValue>();
|
List<KeyValue> testVals = new ArrayList<KeyValue>();
|
||||||
testVals.add(new KeyValue(ROWS[0], FAMILIES[0], QUALIFIER, STAMPS[0], BAD_VALS[0]));
|
testVals.add(new KeyValue(ROWS[0], FAMILIES[0], QUALIFIER, STAMPS[0], BAD_VALS[0]));
|
||||||
testVals.add(new KeyValue(ROWS[0], FAMILIES[0], QUALIFIER, STAMPS[1], BAD_VALS[1]));
|
testVals.add(new KeyValue(ROWS[0], FAMILIES[0], QUALIFIER, STAMPS[1], BAD_VALS[1]));
|
||||||
testVals.add(new KeyValue(ROWS[0], FAMILIES[1], QUALIFIER, STAMPS[1], BAD_VALS[2]));
|
testVals.add(new KeyValue(ROWS[0], FAMILIES[1], QUALIFIER, STAMPS[1], BAD_VALS[2]));
|
||||||
testVals.add(new KeyValue(ROWS[0], FAMILIES[1], QUALIFIER, STAMPS[0], MATCH_VAL));
|
testVals.add(new KeyValue(ROWS[0], FAMILIES[1], QUALIFIER, STAMPS[0], MATCH_VAL));
|
||||||
testVals.add(new KeyValue(ROWS[0], FAMILIES[1], QUALIFIER, STAMPS[2], BAD_VALS[2]));
|
testVals.add(new KeyValue(ROWS[0], FAMILIES[1], QUALIFIER, STAMPS[2], BAD_VALS[2]));
|
||||||
|
|
||||||
return testVals;
|
return testVals;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -615,7 +615,7 @@ public class TestParseFilter {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUnescapedQuote3 () throws IOException {
|
public void testUnescapedQuote3 () throws IOException {
|
||||||
String filterString = " InclusiveStopFilter ('''')";
|
String filterString = " InclusiveStopFilter ('''')";
|
||||||
InclusiveStopFilter inclusiveStopFilter =
|
InclusiveStopFilter inclusiveStopFilter =
|
||||||
doTestFilter(filterString, InclusiveStopFilter.class);
|
doTestFilter(filterString, InclusiveStopFilter.class);
|
||||||
byte [] stopRowKey = inclusiveStopFilter.getStopRowKey();
|
byte [] stopRowKey = inclusiveStopFilter.getStopRowKey();
|
||||||
|
|
|
@ -175,8 +175,8 @@ public class TestHFilePerformance extends AbstractHBaseTool {
|
||||||
|
|
||||||
if ("HFile".equals(fileType)){
|
if ("HFile".equals(fileType)){
|
||||||
HFileContextBuilder builder = new HFileContextBuilder()
|
HFileContextBuilder builder = new HFileContextBuilder()
|
||||||
.withCompression(AbstractHFileWriter.compressionByName(codecName))
|
.withCompression(AbstractHFileWriter.compressionByName(codecName))
|
||||||
.withBlockSize(minBlockSize);
|
.withBlockSize(minBlockSize);
|
||||||
if (cipherName != "none") {
|
if (cipherName != "none") {
|
||||||
byte[] cipherKey = new byte[AES.KEY_LENGTH];
|
byte[] cipherKey = new byte[AES.KEY_LENGTH];
|
||||||
new SecureRandom().nextBytes(cipherKey);
|
new SecureRandom().nextBytes(cipherKey);
|
||||||
|
|
|
@ -104,7 +104,7 @@ public class TestClockSkewDetection {
|
||||||
long warningSkew = c.getLong("hbase.master.warningclockskew", 1000);
|
long warningSkew = c.getLong("hbase.master.warningclockskew", 1000);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
//Master Time > Region Server Time
|
//Master Time > Region Server Time
|
||||||
LOG.debug("Test: Master Time > Region Server Time");
|
LOG.debug("Test: Master Time > Region Server Time");
|
||||||
LOG.debug("regionServerStartup 2");
|
LOG.debug("regionServerStartup 2");
|
||||||
InetAddress ia2 = InetAddress.getLocalHost();
|
InetAddress ia2 = InetAddress.getLocalHost();
|
||||||
|
|
|
@ -398,7 +398,7 @@ public class TestMajorCompaction {
|
||||||
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);
|
||||||
HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY), ("" +
|
HBaseTestCase.addContent(loader, Bytes.toString(COLUMN_FAMILY), ("" +
|
||||||
"bbb").getBytes(), null);
|
"bbb").getBytes(), null);
|
||||||
loader.flushcache();
|
loader.flushcache();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -287,11 +287,11 @@ public class TestTags {
|
||||||
put1.add(fam, qual, HConstants.LATEST_TIMESTAMP, value1);
|
put1.add(fam, qual, HConstants.LATEST_TIMESTAMP, value1);
|
||||||
table.put(put1);
|
table.put(put1);
|
||||||
admin.flush(tableName);
|
admin.flush(tableName);
|
||||||
// We are lacking an API for confirming flush request compaction.
|
// We are lacking an API for confirming flush request compaction.
|
||||||
// Just sleep for a short time. We won't be able to confirm flush
|
// Just sleep for a short time. We won't be able to confirm flush
|
||||||
// completion but the test won't hang now or in the future if
|
// completion but the test won't hang now or in the future if
|
||||||
// default compaction policy causes compaction between flush and
|
// default compaction policy causes compaction between flush and
|
||||||
// when we go to confirm it.
|
// when we go to confirm it.
|
||||||
Thread.sleep(1000);
|
Thread.sleep(1000);
|
||||||
|
|
||||||
put1 = new Put(row2);
|
put1 = new Put(row2);
|
||||||
|
|
|
@ -511,7 +511,7 @@ public class TestReplicationSmallTests extends TestReplicationBase {
|
||||||
*/
|
*/
|
||||||
@Test(timeout = 300000)
|
@Test(timeout = 300000)
|
||||||
public void testVerifyListReplicatedTable() throws Exception {
|
public void testVerifyListReplicatedTable() throws Exception {
|
||||||
LOG.info("testVerifyListReplicatedTable");
|
LOG.info("testVerifyListReplicatedTable");
|
||||||
|
|
||||||
final String tName = "VerifyListReplicated_";
|
final String tName = "VerifyListReplicated_";
|
||||||
final String colFam = "cf1";
|
final String colFam = "cf1";
|
||||||
|
|
|
@ -121,7 +121,7 @@ public class LoadTestTool extends AbstractHBaseTool {
|
||||||
|
|
||||||
public static final String OPT_INMEMORY = "in_memory";
|
public static final String OPT_INMEMORY = "in_memory";
|
||||||
public static final String OPT_USAGE_IN_MEMORY = "Tries to keep the HFiles of the CF " +
|
public static final String OPT_USAGE_IN_MEMORY = "Tries to keep the HFiles of the CF " +
|
||||||
"inmemory as far as possible. Not guaranteed that reads are always served from inmemory";
|
"inmemory as far as possible. Not guaranteed that reads are always served from inmemory";
|
||||||
|
|
||||||
public static final String OPT_GENERATOR = "generator";
|
public static final String OPT_GENERATOR = "generator";
|
||||||
public static final String OPT_GENERATOR_USAGE = "The class which generates load for the tool."
|
public static final String OPT_GENERATOR_USAGE = "The class which generates load for the tool."
|
||||||
|
|
|
@ -379,9 +379,9 @@ public class MultiThreadedReader extends MultiThreadedAction
|
||||||
numKeysVerified.incrementAndGet();
|
numKeysVerified.incrementAndGet();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
HRegionLocation hloc = connection.getRegionLocation(tableName,
|
HRegionLocation hloc = connection.getRegionLocation(tableName,
|
||||||
get.getRow(), false);
|
get.getRow(), false);
|
||||||
String rowKey = Bytes.toString(get.getRow());
|
String rowKey = Bytes.toString(get.getRow());
|
||||||
LOG.info("Key = " + rowKey + ", Region location: " + hloc);
|
LOG.info("Key = " + rowKey + ", Region location: " + hloc);
|
||||||
if(isNullExpected) {
|
if(isNullExpected) {
|
||||||
nullResult.incrementAndGet();
|
nullResult.incrementAndGet();
|
||||||
|
|
|
@ -300,7 +300,7 @@ public class MultiThreadedUpdater extends MultiThreadedWriterBase {
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
if (ignoreNonceConflicts && (e instanceof OperationConflictException)) {
|
if (ignoreNonceConflicts && (e instanceof OperationConflictException)) {
|
||||||
LOG.info("Detected nonce conflict, ignoring: " + e.getMessage());
|
LOG.info("Detected nonce conflict, ignoring: " + e.getMessage());
|
||||||
totalOpTimeMs.addAndGet(System.currentTimeMillis() - start);
|
totalOpTimeMs.addAndGet(System.currentTimeMillis() - start);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
failedKeySet.add(keyBase);
|
failedKeySet.add(keyBase);
|
||||||
|
|
|
@ -59,75 +59,75 @@ public class TestHTablePool {
|
||||||
|
|
||||||
protected abstract PoolType getPoolType();
|
protected abstract PoolType getPoolType();
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testTableWithStringName() throws Exception {
|
public void testTableWithStringName() throws Exception {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
||||||
Integer.MAX_VALUE, getPoolType());
|
Integer.MAX_VALUE, getPoolType());
|
||||||
String tableName = TABLENAME;
|
String tableName = TABLENAME;
|
||||||
|
|
||||||
// Request a table from an empty pool
|
// Request a table from an empty pool
|
||||||
Table table = pool.getTable(tableName);
|
Table table = pool.getTable(tableName);
|
||||||
Assert.assertNotNull(table);
|
Assert.assertNotNull(table);
|
||||||
|
|
||||||
// Close table (returns table to the pool)
|
// Close table (returns table to the pool)
|
||||||
table.close();
|
table.close();
|
||||||
|
|
||||||
// Request a table of the same name
|
// Request a table of the same name
|
||||||
Table sameTable = pool.getTable(tableName);
|
Table sameTable = pool.getTable(tableName);
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table).getWrappedTable(),
|
((HTablePool.PooledHTable) table).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable).getWrappedTable());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testTableWithByteArrayName() throws IOException {
|
public void testTableWithByteArrayName() throws IOException {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
||||||
Integer.MAX_VALUE, getPoolType());
|
Integer.MAX_VALUE, getPoolType());
|
||||||
|
|
||||||
// Request a table from an empty pool
|
// Request a table from an empty pool
|
||||||
Table table = pool.getTable(TABLENAME);
|
Table table = pool.getTable(TABLENAME);
|
||||||
Assert.assertNotNull(table);
|
Assert.assertNotNull(table);
|
||||||
|
|
||||||
// Close table (returns table to the pool)
|
// Close table (returns table to the pool)
|
||||||
table.close();
|
table.close();
|
||||||
|
|
||||||
// Request a table of the same name
|
// Request a table of the same name
|
||||||
Table sameTable = pool.getTable(TABLENAME);
|
Table sameTable = pool.getTable(TABLENAME);
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table).getWrappedTable(),
|
((HTablePool.PooledHTable) table).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable).getWrappedTable());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testTablesWithDifferentNames() throws IOException {
|
public void testTablesWithDifferentNames() throws IOException {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
||||||
Integer.MAX_VALUE, getPoolType());
|
Integer.MAX_VALUE, getPoolType());
|
||||||
// We add the class to the table name as the HBase cluster is reused
|
// We add the class to the table name as the HBase cluster is reused
|
||||||
// during the tests: this gives naming unicity.
|
// during the tests: this gives naming unicity.
|
||||||
byte[] otherTable = Bytes.toBytes(
|
byte[] otherTable = Bytes.toBytes(
|
||||||
"OtherTable_" + getClass().getSimpleName()
|
"OtherTable_" + getClass().getSimpleName()
|
||||||
);
|
);
|
||||||
TEST_UTIL.createTable(otherTable, HConstants.CATALOG_FAMILY);
|
TEST_UTIL.createTable(otherTable, HConstants.CATALOG_FAMILY);
|
||||||
|
|
||||||
// Request a table from an empty pool
|
// Request a table from an empty pool
|
||||||
Table table1 = pool.getTable(TABLENAME);
|
Table table1 = pool.getTable(TABLENAME);
|
||||||
Table table2 = pool.getTable(otherTable);
|
Table table2 = pool.getTable(otherTable);
|
||||||
Assert.assertNotNull(table2);
|
Assert.assertNotNull(table2);
|
||||||
|
|
||||||
// Close tables (returns tables to the pool)
|
// Close tables (returns tables to the pool)
|
||||||
table1.close();
|
table1.close();
|
||||||
table2.close();
|
table2.close();
|
||||||
|
|
||||||
// Request tables of the same names
|
// Request tables of the same names
|
||||||
Table sameTable1 = pool.getTable(TABLENAME);
|
Table sameTable1 = pool.getTable(TABLENAME);
|
||||||
Table sameTable2 = pool.getTable(otherTable);
|
Table sameTable2 = pool.getTable(otherTable);
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table1).getWrappedTable(),
|
((HTablePool.PooledHTable) table1).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable1).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable1).getWrappedTable());
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table2).getWrappedTable(),
|
((HTablePool.PooledHTable) table2).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable2).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable2).getWrappedTable());
|
||||||
}
|
}
|
||||||
@Test
|
@Test
|
||||||
public void testProxyImplementationReturned() {
|
public void testProxyImplementationReturned() {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
||||||
|
@ -146,8 +146,8 @@ public class TestHTablePool {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
||||||
Integer.MAX_VALUE);
|
Integer.MAX_VALUE);
|
||||||
String tableName = TABLENAME;// Request a table from
|
String tableName = TABLENAME;// Request a table from
|
||||||
// an
|
// an
|
||||||
// empty pool
|
// empty pool
|
||||||
|
|
||||||
// get table will return proxy implementation
|
// get table will return proxy implementation
|
||||||
HTableInterface table = pool.getTable(tableName);
|
HTableInterface table = pool.getTable(tableName);
|
||||||
|
@ -168,8 +168,8 @@ public class TestHTablePool {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(),
|
||||||
Integer.MAX_VALUE);
|
Integer.MAX_VALUE);
|
||||||
String tableName = TABLENAME;// Request a table from
|
String tableName = TABLENAME;// Request a table from
|
||||||
// an
|
// an
|
||||||
// empty pool
|
// empty pool
|
||||||
|
|
||||||
// get table will return proxy implementation
|
// get table will return proxy implementation
|
||||||
final Table table = pool.getTable(tableName);
|
final Table table = pool.getTable(tableName);
|
||||||
|
@ -213,154 +213,154 @@ public class TestHTablePool {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Category({ClientTests.class, MediumTests.class})
|
@Category({ClientTests.class, MediumTests.class})
|
||||||
public static class TestHTableReusablePool extends TestHTablePoolType {
|
public static class TestHTableReusablePool extends TestHTablePoolType {
|
||||||
@Override
|
@Override
|
||||||
protected PoolType getPoolType() {
|
protected PoolType getPoolType() {
|
||||||
return PoolType.Reusable;
|
return PoolType.Reusable;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testTableWithMaxSize() throws Exception {
|
public void testTableWithMaxSize() throws Exception {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 2,
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 2,
|
||||||
getPoolType());
|
getPoolType());
|
||||||
|
|
||||||
// Request tables from an empty pool
|
// Request tables from an empty pool
|
||||||
Table table1 = pool.getTable(TABLENAME);
|
Table table1 = pool.getTable(TABLENAME);
|
||||||
Table table2 = pool.getTable(TABLENAME);
|
Table table2 = pool.getTable(TABLENAME);
|
||||||
Table table3 = pool.getTable(TABLENAME);
|
Table table3 = pool.getTable(TABLENAME);
|
||||||
|
|
||||||
// Close tables (returns tables to the pool)
|
// Close tables (returns tables to the pool)
|
||||||
table1.close();
|
table1.close();
|
||||||
table2.close();
|
table2.close();
|
||||||
// The pool should reject this one since it is already full
|
// The pool should reject this one since it is already full
|
||||||
table3.close();
|
table3.close();
|
||||||
|
|
||||||
// Request tables of the same name
|
// Request tables of the same name
|
||||||
Table sameTable1 = pool.getTable(TABLENAME);
|
Table sameTable1 = pool.getTable(TABLENAME);
|
||||||
Table sameTable2 = pool.getTable(TABLENAME);
|
Table sameTable2 = pool.getTable(TABLENAME);
|
||||||
Table sameTable3 = pool.getTable(TABLENAME);
|
Table sameTable3 = pool.getTable(TABLENAME);
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table1).getWrappedTable(),
|
((HTablePool.PooledHTable) table1).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable1).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable1).getWrappedTable());
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table2).getWrappedTable(),
|
((HTablePool.PooledHTable) table2).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable2).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable2).getWrappedTable());
|
||||||
Assert.assertNotSame(
|
Assert.assertNotSame(
|
||||||
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable3).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable3).getWrappedTable());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCloseTablePool() throws IOException {
|
public void testCloseTablePool() throws IOException {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 4,
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 4,
|
||||||
getPoolType());
|
getPoolType());
|
||||||
HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration());
|
HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration());
|
||||||
|
|
||||||
if (admin.tableExists(TABLENAME)) {
|
if (admin.tableExists(TABLENAME)) {
|
||||||
admin.disableTable(TABLENAME);
|
admin.disableTable(TABLENAME);
|
||||||
admin.deleteTable(TABLENAME);
|
admin.deleteTable(TABLENAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
HTableDescriptor tableDescriptor = new HTableDescriptor(TableName.valueOf(TABLENAME));
|
HTableDescriptor tableDescriptor = new HTableDescriptor(TableName.valueOf(TABLENAME));
|
||||||
tableDescriptor.addFamily(new HColumnDescriptor("randomFamily"));
|
tableDescriptor.addFamily(new HColumnDescriptor("randomFamily"));
|
||||||
admin.createTable(tableDescriptor);
|
admin.createTable(tableDescriptor);
|
||||||
|
|
||||||
// Request tables from an empty pool
|
// Request tables from an empty pool
|
||||||
Table[] tables = new Table[4];
|
Table[] tables = new Table[4];
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
tables[i] = pool.getTable(TABLENAME);
|
tables[i] = pool.getTable(TABLENAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
pool.closeTablePool(TABLENAME);
|
pool.closeTablePool(TABLENAME);
|
||||||
|
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
tables[i].close();
|
tables[i].close();
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.assertEquals(4,
|
Assert.assertEquals(4,
|
||||||
pool.getCurrentPoolSize(TABLENAME));
|
pool.getCurrentPoolSize(TABLENAME));
|
||||||
|
|
||||||
pool.closeTablePool(TABLENAME);
|
pool.closeTablePool(TABLENAME);
|
||||||
|
|
||||||
Assert.assertEquals(0,
|
Assert.assertEquals(0,
|
||||||
pool.getCurrentPoolSize(TABLENAME));
|
pool.getCurrentPoolSize(TABLENAME));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Category({ClientTests.class, MediumTests.class})
|
@Category({ClientTests.class, MediumTests.class})
|
||||||
public static class TestHTableThreadLocalPool extends TestHTablePoolType {
|
public static class TestHTableThreadLocalPool extends TestHTablePoolType {
|
||||||
@Override
|
@Override
|
||||||
protected PoolType getPoolType() {
|
protected PoolType getPoolType() {
|
||||||
return PoolType.ThreadLocal;
|
return PoolType.ThreadLocal;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testTableWithMaxSize() throws Exception {
|
public void testTableWithMaxSize() throws Exception {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 2,
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 2,
|
||||||
getPoolType());
|
getPoolType());
|
||||||
|
|
||||||
// Request tables from an empty pool
|
// Request tables from an empty pool
|
||||||
Table table1 = pool.getTable(TABLENAME);
|
Table table1 = pool.getTable(TABLENAME);
|
||||||
Table table2 = pool.getTable(TABLENAME);
|
Table table2 = pool.getTable(TABLENAME);
|
||||||
Table table3 = pool.getTable(TABLENAME);
|
Table table3 = pool.getTable(TABLENAME);
|
||||||
|
|
||||||
// Close tables (returns tables to the pool)
|
// Close tables (returns tables to the pool)
|
||||||
table1.close();
|
table1.close();
|
||||||
table2.close();
|
table2.close();
|
||||||
// The pool should not reject this one since the number of threads
|
// The pool should not reject this one since the number of threads
|
||||||
// <= 2
|
// <= 2
|
||||||
table3.close();
|
table3.close();
|
||||||
|
|
||||||
// Request tables of the same name
|
// Request tables of the same name
|
||||||
Table sameTable1 = pool.getTable(TABLENAME);
|
Table sameTable1 = pool.getTable(TABLENAME);
|
||||||
Table sameTable2 = pool.getTable(TABLENAME);
|
Table sameTable2 = pool.getTable(TABLENAME);
|
||||||
Table sameTable3 = pool.getTable(TABLENAME);
|
Table sameTable3 = pool.getTable(TABLENAME);
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable1).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable1).getWrappedTable());
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable2).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable2).getWrappedTable());
|
||||||
Assert.assertSame(
|
Assert.assertSame(
|
||||||
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
((HTablePool.PooledHTable) table3).getWrappedTable(),
|
||||||
((HTablePool.PooledHTable) sameTable3).getWrappedTable());
|
((HTablePool.PooledHTable) sameTable3).getWrappedTable());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCloseTablePool() throws IOException {
|
public void testCloseTablePool() throws IOException {
|
||||||
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 4,
|
HTablePool pool = new HTablePool(TEST_UTIL.getConfiguration(), 4,
|
||||||
getPoolType());
|
getPoolType());
|
||||||
HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration());
|
HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration());
|
||||||
|
|
||||||
if (admin.tableExists(TABLENAME)) {
|
if (admin.tableExists(TABLENAME)) {
|
||||||
admin.disableTable(TABLENAME);
|
admin.disableTable(TABLENAME);
|
||||||
admin.deleteTable(TABLENAME);
|
admin.deleteTable(TABLENAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
HTableDescriptor tableDescriptor = new HTableDescriptor(TableName.valueOf(TABLENAME));
|
HTableDescriptor tableDescriptor = new HTableDescriptor(TableName.valueOf(TABLENAME));
|
||||||
tableDescriptor.addFamily(new HColumnDescriptor("randomFamily"));
|
tableDescriptor.addFamily(new HColumnDescriptor("randomFamily"));
|
||||||
admin.createTable(tableDescriptor);
|
admin.createTable(tableDescriptor);
|
||||||
|
|
||||||
// Request tables from an empty pool
|
// Request tables from an empty pool
|
||||||
Table[] tables = new Table[4];
|
Table[] tables = new Table[4];
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
tables[i] = pool.getTable(TABLENAME);
|
tables[i] = pool.getTable(TABLENAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
pool.closeTablePool(TABLENAME);
|
pool.closeTablePool(TABLENAME);
|
||||||
|
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
tables[i].close();
|
tables[i].close();
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.assertEquals(1,
|
Assert.assertEquals(1,
|
||||||
pool.getCurrentPoolSize(TABLENAME));
|
pool.getCurrentPoolSize(TABLENAME));
|
||||||
|
|
||||||
pool.closeTablePool(TABLENAME);
|
pool.closeTablePool(TABLENAME);
|
||||||
|
|
||||||
Assert.assertEquals(0,
|
Assert.assertEquals(0,
|
||||||
pool.getCurrentPoolSize(TABLENAME));
|
pool.getCurrentPoolSize(TABLENAME));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue