HADOOP-13291. Probing stats in DFSOpsCountStatistics/S3AStorageStatistics should be correctly implemented. Contributed by Mingliang Liu.
This commit is contained in:
parent
588ea6d431
commit
2f95d22b17
|
@ -139,7 +139,8 @@ public class DFSOpsCountStatistics extends StorageStatistics {
|
|||
throw new NoSuchElementException();
|
||||
}
|
||||
final Entry<OpType, AtomicLong> entry = iterator.next();
|
||||
return new LongStatistic(entry.getKey().name(), entry.getValue().get());
|
||||
return new LongStatistic(entry.getKey().getSymbol(),
|
||||
entry.getValue().get());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -161,7 +162,7 @@ public class DFSOpsCountStatistics extends StorageStatistics {
|
|||
|
||||
@Override
|
||||
public boolean isTracked(String key) {
|
||||
return OpType.fromSymbol(key) == null;
|
||||
return OpType.fromSymbol(key) != null;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -0,0 +1,108 @@
|
|||
/**
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
* <p>
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* <p>
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package org.apache.hadoop.hdfs;
|
||||
|
||||
import org.apache.commons.lang3.RandomUtils;
|
||||
import org.apache.hadoop.fs.StorageStatistics.LongStatistic;
|
||||
|
||||
import org.apache.hadoop.hdfs.DFSOpsCountStatistics.OpType;
|
||||
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Rule;
|
||||
import org.junit.Test;
|
||||
|
||||
import org.junit.rules.ExpectedException;
|
||||
import org.junit.rules.Timeout;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
import static org.junit.Assert.assertNull;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* This tests basic operations of {@link DFSOpsCountStatistics} class.
|
||||
*/
|
||||
public class TestDFSOpsCountStatistics {
|
||||
|
||||
private static final DFSOpsCountStatistics STORAGE_STATISTICS =
|
||||
new DFSOpsCountStatistics();
|
||||
private static final Map<String, Long> OP_COUNTER_MAP = new HashMap<>();
|
||||
private static final String NO_SUCH_OP = "no-such-dfs-operation-dude";
|
||||
|
||||
@Rule
|
||||
public final Timeout globalTimeout = new Timeout(10 * 1000);
|
||||
@Rule
|
||||
public final ExpectedException exception = ExpectedException.none();
|
||||
|
||||
@BeforeClass
|
||||
public static void setup() {
|
||||
for (OpType opType : OpType.values()) {
|
||||
final Long opCount = RandomUtils.nextLong(0, 100);
|
||||
OP_COUNTER_MAP.put(opType.getSymbol(), opCount);
|
||||
for (long i = 0; i < opCount; i++) {
|
||||
STORAGE_STATISTICS.incrementOpCounter(opType);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testGetLongStatistics() {
|
||||
short iterations = 0; // number of the iter.hasNext()
|
||||
final Iterator<LongStatistic> iter = STORAGE_STATISTICS.getLongStatistics();
|
||||
|
||||
while (iter.hasNext()) {
|
||||
final LongStatistic longStat = iter.next();
|
||||
assertNotNull(longStat);
|
||||
assertTrue(OP_COUNTER_MAP.containsKey(longStat.getName()));
|
||||
assertEquals(OP_COUNTER_MAP.get(longStat.getName()).longValue(),
|
||||
longStat.getValue());
|
||||
iterations++;
|
||||
}
|
||||
|
||||
// check that all the OpType enum entries are iterated via iter
|
||||
assertEquals(OpType.values().length, iterations);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testGetLong() {
|
||||
assertNull(STORAGE_STATISTICS.getLong(NO_SUCH_OP));
|
||||
|
||||
for (OpType opType : OpType.values()) {
|
||||
final String key = opType.getSymbol();
|
||||
assertEquals(OP_COUNTER_MAP.get(key), STORAGE_STATISTICS.getLong(key));
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testIsTracked() {
|
||||
assertFalse(STORAGE_STATISTICS.isTracked(NO_SUCH_OP));
|
||||
|
||||
final Iterator<LongStatistic> iter = STORAGE_STATISTICS.getLongStatistics();
|
||||
while (iter.hasNext()) {
|
||||
final LongStatistic longStatistic = iter.next();
|
||||
assertTrue(STORAGE_STATISTICS.isTracked(longStatistic.getName()));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -76,7 +76,8 @@ public class S3AStorageStatistics extends StorageStatistics {
|
|||
throw new NoSuchElementException();
|
||||
}
|
||||
final Map.Entry<Statistic, AtomicLong> entry = iterator.next();
|
||||
return new LongStatistic(entry.getKey().name(), entry.getValue().get());
|
||||
return new LongStatistic(entry.getKey().getSymbol(),
|
||||
entry.getValue().get());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -98,7 +99,7 @@ public class S3AStorageStatistics extends StorageStatistics {
|
|||
|
||||
@Override
|
||||
public boolean isTracked(String key) {
|
||||
return Statistic.fromSymbol(key) == null;
|
||||
return Statistic.fromSymbol(key) != null;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue