HDDS-1863. Freon RandomKeyGenerator even if keySize is set to 0, it returns some random data to key. (#1167)

This commit is contained in:
Bharat Viswanadham 2019-08-08 15:40:19 -07:00 committed by GitHub
parent 6ad9a11494
commit aa5f445fb9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 21 additions and 8 deletions

View File

@ -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) {

View File

@ -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 =