HDDS-1863. Freon RandomKeyGenerator even if keySize is set to 0, it returns some random data to key. (#1167)
This commit is contained in:
parent
6ad9a11494
commit
aa5f445fb9
|
@ -26,7 +26,6 @@ import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.UUID;
|
|
||||||
import java.util.concurrent.BlockingQueue;
|
import java.util.concurrent.BlockingQueue;
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
@ -263,9 +262,7 @@ public final class RandomKeyGenerator implements Callable<Void> {
|
||||||
// Compute the common initial digest for all keys without their UUID
|
// Compute the common initial digest for all keys without their UUID
|
||||||
if (validateWrites) {
|
if (validateWrites) {
|
||||||
commonInitialMD = DigestUtils.getDigest(DIGEST_ALGORITHM);
|
commonInitialMD = DigestUtils.getDigest(DIGEST_ALGORITHM);
|
||||||
int uuidLength = UUID.randomUUID().toString().length();
|
for (long nrRemaining = keySize; nrRemaining > 0;
|
||||||
keySize = Math.max(uuidLength, keySize);
|
|
||||||
for (long nrRemaining = keySize - uuidLength; nrRemaining > 0;
|
|
||||||
nrRemaining -= bufferSize) {
|
nrRemaining -= bufferSize) {
|
||||||
int curSize = (int)Math.min(bufferSize, nrRemaining);
|
int curSize = (int)Math.min(bufferSize, nrRemaining);
|
||||||
commonInitialMD.update(keyValueBuffer, 0, curSize);
|
commonInitialMD.update(keyValueBuffer, 0, curSize);
|
||||||
|
@ -682,7 +679,6 @@ public final class RandomKeyGenerator implements Callable<Void> {
|
||||||
+ RandomStringUtils.randomNumeric(5);
|
+ RandomStringUtils.randomNumeric(5);
|
||||||
LOG.trace("Adding key: {} in bucket: {} of volume: {}",
|
LOG.trace("Adding key: {} in bucket: {} of volume: {}",
|
||||||
keyName, bucketName, volumeName);
|
keyName, bucketName, volumeName);
|
||||||
byte[] randomValue = DFSUtil.string2Bytes(UUID.randomUUID().toString());
|
|
||||||
try {
|
try {
|
||||||
try (Scope scope = GlobalTracer.get().buildSpan("createKey")
|
try (Scope scope = GlobalTracer.get().buildSpan("createKey")
|
||||||
.startActive(true)) {
|
.startActive(true)) {
|
||||||
|
@ -697,12 +693,11 @@ public final class RandomKeyGenerator implements Callable<Void> {
|
||||||
try (Scope writeScope = GlobalTracer.get().buildSpan("writeKeyData")
|
try (Scope writeScope = GlobalTracer.get().buildSpan("writeKeyData")
|
||||||
.startActive(true)) {
|
.startActive(true)) {
|
||||||
long keyWriteStart = System.nanoTime();
|
long keyWriteStart = System.nanoTime();
|
||||||
for (long nrRemaining = keySize - randomValue.length;
|
for (long nrRemaining = keySize;
|
||||||
nrRemaining > 0; nrRemaining -= bufferSize) {
|
nrRemaining > 0; nrRemaining -= bufferSize) {
|
||||||
int curSize = (int) Math.min(bufferSize, nrRemaining);
|
int curSize = (int) Math.min(bufferSize, nrRemaining);
|
||||||
os.write(keyValueBuffer, 0, curSize);
|
os.write(keyValueBuffer, 0, curSize);
|
||||||
}
|
}
|
||||||
os.write(randomValue);
|
|
||||||
os.close();
|
os.close();
|
||||||
|
|
||||||
long keyWriteDuration = System.nanoTime() - keyWriteStart;
|
long keyWriteDuration = System.nanoTime() - keyWriteStart;
|
||||||
|
@ -716,7 +711,6 @@ public final class RandomKeyGenerator implements Callable<Void> {
|
||||||
|
|
||||||
if (validateWrites) {
|
if (validateWrites) {
|
||||||
MessageDigest tmpMD = (MessageDigest) commonInitialMD.clone();
|
MessageDigest tmpMD = (MessageDigest) commonInitialMD.clone();
|
||||||
tmpMD.update(randomValue);
|
|
||||||
boolean validate = validationQueue.offer(
|
boolean validate = validationQueue.offer(
|
||||||
new KeyValidate(bucket, keyName, tmpMD.digest()));
|
new KeyValidate(bucket, keyName, tmpMD.digest()));
|
||||||
if (validate) {
|
if (validate) {
|
||||||
|
|
|
@ -128,6 +128,25 @@ public class TestRandomKeyGenerator {
|
||||||
Assert.assertEquals(1, randomKeyGenerator.getSuccessfulValidationCount());
|
Assert.assertEquals(1, randomKeyGenerator.getSuccessfulValidationCount());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void fileWithSizeZero() throws Exception {
|
||||||
|
RandomKeyGenerator randomKeyGenerator =
|
||||||
|
new RandomKeyGenerator((OzoneConfiguration) cluster.getConf());
|
||||||
|
randomKeyGenerator.setNumOfVolumes(1);
|
||||||
|
randomKeyGenerator.setNumOfBuckets(1);
|
||||||
|
randomKeyGenerator.setNumOfKeys(1);
|
||||||
|
randomKeyGenerator.setNumOfThreads(1);
|
||||||
|
randomKeyGenerator.setKeySize(0);
|
||||||
|
randomKeyGenerator.setFactor(ReplicationFactor.THREE);
|
||||||
|
randomKeyGenerator.setType(ReplicationType.RATIS);
|
||||||
|
randomKeyGenerator.setValidateWrites(true);
|
||||||
|
randomKeyGenerator.call();
|
||||||
|
Assert.assertEquals(1, randomKeyGenerator.getNumberOfVolumesCreated());
|
||||||
|
Assert.assertEquals(1, randomKeyGenerator.getNumberOfBucketsCreated());
|
||||||
|
Assert.assertEquals(1, randomKeyGenerator.getNumberOfKeysAdded());
|
||||||
|
Assert.assertEquals(1, randomKeyGenerator.getSuccessfulValidationCount());
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testThreadPoolSize() throws Exception {
|
public void testThreadPoolSize() throws Exception {
|
||||||
RandomKeyGenerator randomKeyGenerator =
|
RandomKeyGenerator randomKeyGenerator =
|
||||||
|
|
Loading…
Reference in New Issue