HADOOP-8757. Metrics should disallow names with invalid characters (rchiang via rkanter)

(cherry picked from commit b6ff9c03a4)
This commit is contained in:
Robert Kanter 2015-01-15 11:39:43 -08:00
parent ed5a0d0aa8
commit 24a8b8e5a7
3 changed files with 59 additions and 0 deletions

View File

@ -120,6 +120,9 @@ Release 2.7.0 - UNRELEASED
HADOOP-11481. ClassCastException while using a key created by keytool to HADOOP-11481. ClassCastException while using a key created by keytool to
create encryption zone. (Charles Lamb via Colin P. McCabe) create encryption zone. (Charles Lamb via Colin P. McCabe)
HADOOP-8757. Metrics should disallow names with invalid characters
(rchiang via rkanter)
OPTIMIZATIONS OPTIMIZATIONS
HADOOP-11323. WritableComparator#compare keeps reference to byte array. HADOOP-11323. WritableComparator#compare keeps reference to byte array.

View File

@ -363,6 +363,20 @@ public class MetricsRegistry {
} }
private void checkMetricName(String name) { private void checkMetricName(String name) {
// Check for invalid characters in metric name
boolean foundWhitespace = false;
for (int i = 0; i < name.length(); i++) {
char c = name.charAt(i);
if (Character.isWhitespace(c)) {
foundWhitespace = true;
break;
}
}
if (foundWhitespace) {
throw new MetricsException("Metric name '"+ name +
"' contains illegal whitespace character");
}
// Check if name has already been registered
if (metricsMap.containsKey(name)) { if (metricsMap.containsKey(name)) {
throw new MetricsException("Metric name "+ name +" already exists!"); throw new MetricsException("Metric name "+ name +" already exists!");
} }

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.metrics2.lib; package org.apache.hadoop.metrics2.lib;
import org.junit.Ignore;
import org.junit.Test; import org.junit.Test;
import static org.junit.Assert.*; import static org.junit.Assert.*;
import static org.mockito.Mockito.*; import static org.mockito.Mockito.*;
@ -56,6 +57,46 @@ public class TestMetricsRegistry {
}); });
} }
/**
* Test adding metrics with whitespace in the name
*/
@Test
public void testMetricsRegistryIllegalMetricNames() {
final MetricsRegistry r = new MetricsRegistry("test");
// Fill up with some basics
r.newCounter("c1", "c1 desc", 1);
r.newGauge("g1", "g1 desc", 1);
r.newQuantiles("q1", "q1 desc", "q1 name", "q1 val type", 1);
// Add some illegal names
expectMetricsException("Metric name 'badcount 2' contains "+
"illegal whitespace character", new Runnable() {
@Override
public void run() { r.newCounter("badcount 2", "c2 desc", 2); }
});
expectMetricsException("Metric name 'badcount3 ' contains "+
"illegal whitespace character", new Runnable() {
@Override
public void run() { r.newCounter("badcount3 ", "c3 desc", 3); }
});
expectMetricsException("Metric name ' badcount4' contains "+
"illegal whitespace character", new Runnable() {
@Override
public void run() { r.newCounter(" badcount4", "c4 desc", 4); }
});
expectMetricsException("Metric name 'withtab5 ' contains "+
"illegal whitespace character", new Runnable() {
@Override
public void run() { r.newCounter("withtab5 ", "c5 desc", 5); }
});
expectMetricsException("Metric name 'withnewline6\n' contains "+
"illegal whitespace character", new Runnable() {
@Override
public void run() { r.newCounter("withnewline6\n", "c6 desc", 6); }
});
// Final validation
assertEquals("num metrics in registry", 3, r.metrics().size());
}
/** /**
* Test the add by name method * Test the add by name method
*/ */
@ -81,6 +122,7 @@ public class TestMetricsRegistry {
}); });
} }
@Ignore
private void expectMetricsException(String prefix, Runnable fun) { private void expectMetricsException(String prefix, Runnable fun) {
try { try {
fun.run(); fun.run();