HBASE-22032 KeyValue validation should check for null byte array

Signed-off-by: Andrew Purtell <apurtell@apache.org>

Conflicts:
	hbase-common/src/test/java/org/apache/hadoop/hbase/TestKeyValue.java
This commit is contained in:
Geoffrey Jacoby 2019-03-11 14:08:49 -07:00 committed by Andrew Purtell
parent 04b78bb416
commit 2c58dc503b
No known key found for this signature in database
GPG Key ID: 8597754DD5365CCD
2 changed files with 32 additions and 11 deletions

View File

@ -509,11 +509,17 @@ public class KeyValueUtil {
} }
static String bytesToHex(byte[] buf, int offset, int length) { static String bytesToHex(byte[] buf, int offset, int length) {
return ", KeyValueBytesHex=" + Bytes.toStringBinary(buf, offset, length) + ", offset=" + offset String bufferContents = buf != null ? Bytes.toStringBinary(buf, offset, length) : "<null>";
return ", KeyValueBytesHex=" + bufferContents + ", offset=" + offset
+ ", length=" + length; + ", length=" + length;
} }
static void checkKeyValueBytes(byte[] buf, int offset, int length, boolean withTags) { static void checkKeyValueBytes(byte[] buf, int offset, int length, boolean withTags) {
if (buf == null) {
throw new IllegalArgumentException("Invalid to have null " +
"byte array in KeyValue.");
}
int pos = offset, endOffset = offset + length; int pos = offset, endOffset = offset + length;
// check the key // check the key
if (pos + Bytes.SIZEOF_INT > endOffset) { if (pos + Bytes.SIZEOF_INT > endOffset) {

View File

@ -24,6 +24,7 @@ import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotEquals; import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
@ -624,6 +625,20 @@ public class TestKeyValue {
} }
} }
@Test
public void testNullByteArrayKeyValueFailure() {
//can't add to testCheckKeyValueBytesFailureCase because it
//goes through the InputStream KeyValue API which can't produce a null buffer
try {
KeyValue kv = new KeyValue(null, 0, 0);
} catch (IllegalArgumentException iae){
assertEquals("Invalid to have null byte array in KeyValue.", iae.getMessage());
return;
}
fail("Should have thrown an IllegalArgumentException when " +
"creating a KeyValue with a null buffer");
}
private static class FailureCase { private static class FailureCase {
byte[] buf; byte[] buf;
int offset; int offset;
@ -673,16 +688,16 @@ public class TestKeyValue {
+ "\\x00\\x00\\x00\\x00\\x00\\x00\\x01\\x04VALUE"), // case.12 + "\\x00\\x00\\x00\\x00\\x00\\x00\\x01\\x04VALUE"), // case.12
}; };
String[] outputs = new String[] { "Overflow when reading key length at position=0", String[] outputs = new String[] { "Overflow when reading key length at position=0",
"Overflow when reading key length at position=0", "Overflow when reading key length at position=0",
"Invalid key length in KeyValue. keyLength=1", "Invalid key length in KeyValue. keyLength=1",
"Overflow when reading value length at position=4", "Overflow when reading value length at position=4",
"Invalid value length in KeyValue, valueLength=1", "Invalid value length in KeyValue, valueLength=1",
"Overflow when reading row length at position=8", "Overflow when reading row length at position=8",
"Invalid row length in KeyValue, rowLength=1", "Invalid row length in KeyValue, rowLength=1",
"Overflow when reading family length at position=13", "Overflow when reading family length at position=13",
"Invalid family length in KeyValue, familyLength=1", "Timestamp cannot be negative, ts=-1", "Invalid family length in KeyValue, familyLength=1", "Timestamp cannot be negative, ts=-1",
"Invalid type in KeyValue, type=3", "Overflow when reading value part at position=25", "Invalid type in KeyValue, type=3", "Overflow when reading value part at position=25",
"Invalid tags length in KeyValue at position=26", }; "Invalid tags length in KeyValue at position=26"};
byte[][] withTagsInputs = new byte[][] { byte[][] withTagsInputs = new byte[][] {
Bytes.toBytesBinary("\\x00\\x00\\x00\\x11\\x00\\x00\\x00\\x01\\x00\\x03ROW\\x01FQ\\x00" Bytes.toBytesBinary("\\x00\\x00\\x00\\x11\\x00\\x00\\x00\\x01\\x00\\x03ROW\\x01FQ\\x00"
+ "\\x00\\x00\\x00\\x00\\x00\\x00\\x01\\x04V\\x01"), // case.13 + "\\x00\\x00\\x00\\x00\\x00\\x00\\x01\\x04V\\x01"), // case.13