HADOOP-8981. Merge r1422279 from branch-trunk-win to trunk
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1440780 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
28c308d5e8
commit
e668c16975
@ -588,6 +588,8 @@ Release 2.0.3-alpha - Unreleased
|
||||
|
||||
HADOOP-9221. Convert remaining xdocs to APT. (Andy Isaacson via atm)
|
||||
|
||||
HADOOP-8981. TestMetricsSystemImpl fails on Windows. (Xuan Gong via suresh)
|
||||
|
||||
Release 2.0.2-alpha - 2012-09-07
|
||||
|
||||
INCOMPATIBLE CHANGES
|
||||
|
@ -56,6 +56,7 @@
|
||||
import org.apache.hadoop.metrics2.lib.MutableRate;
|
||||
import org.apache.hadoop.metrics2.lib.MutableGaugeLong;
|
||||
import org.apache.hadoop.util.StringUtils;
|
||||
import org.apache.hadoop.metrics2.lib.DefaultMetricsSystem;
|
||||
|
||||
/**
|
||||
* Test the MetricsSystemImpl class
|
||||
@ -80,7 +81,7 @@ public static class TestSink implements MetricsSink {
|
||||
}
|
||||
}
|
||||
|
||||
@Test public void testInitFirst() throws Exception {
|
||||
@Test public void testInitFirstVerifyStopInvokedImmediately() throws Exception {
|
||||
new ConfigBuilder().add("*.period", 8)
|
||||
//.add("test.sink.plugin.urls", getPluginUrlsAsString())
|
||||
.add("test.sink.test.class", TestSink.class.getName())
|
||||
@ -106,12 +107,59 @@ public static class TestSink implements MetricsSink {
|
||||
ms.stop();
|
||||
ms.shutdown();
|
||||
|
||||
verify(sink1, times(2)).putMetrics(r1.capture());
|
||||
//When we call stop, at most two sources will be consumed by each sink thread.
|
||||
verify(sink1, atMost(2)).putMetrics(r1.capture());
|
||||
List<MetricsRecord> mr1 = r1.getAllValues();
|
||||
verify(sink2, atMost(2)).putMetrics(r2.capture());
|
||||
List<MetricsRecord> mr2 = r2.getAllValues();
|
||||
if (mr1.size() != 0 && mr2.size() != 0) {
|
||||
checkMetricsRecords(mr1);
|
||||
assertEquals("output", mr1, mr2);
|
||||
} else if (mr1.size() != 0) {
|
||||
checkMetricsRecords(mr1);
|
||||
} else if (mr2.size() != 0) {
|
||||
checkMetricsRecords(mr2);
|
||||
}
|
||||
}
|
||||
|
||||
@Test public void testInitFirstVerifyCallBacks() throws Exception {
|
||||
DefaultMetricsSystem.shutdown();
|
||||
new ConfigBuilder().add("*.period", 8)
|
||||
//.add("test.sink.plugin.urls", getPluginUrlsAsString())
|
||||
.add("test.sink.test.class", TestSink.class.getName())
|
||||
.add("test.*.source.filter.exclude", "s0")
|
||||
.add("test.source.s1.metric.filter.exclude", "X*")
|
||||
.add("test.sink.sink1.metric.filter.exclude", "Y*")
|
||||
.add("test.sink.sink2.metric.filter.exclude", "Y*")
|
||||
.save(TestMetricsConfig.getTestFilename("hadoop-metrics2-test"));
|
||||
MetricsSystemImpl ms = new MetricsSystemImpl("Test");
|
||||
ms.start();
|
||||
ms.register("s0", "s0 desc", new TestSource("s0rec"));
|
||||
TestSource s1 = ms.register("s1", "s1 desc", new TestSource("s1rec"));
|
||||
s1.c1.incr();
|
||||
s1.xxx.incr();
|
||||
s1.g1.set(2);
|
||||
s1.yyy.incr(2);
|
||||
s1.s1.add(0);
|
||||
MetricsSink sink1 = mock(MetricsSink.class);
|
||||
MetricsSink sink2 = mock(MetricsSink.class);
|
||||
ms.registerSink("sink1", "sink1 desc", sink1);
|
||||
ms.registerSink("sink2", "sink2 desc", sink2);
|
||||
ms.publishMetricsNow(); // publish the metrics
|
||||
|
||||
try {
|
||||
verify(sink1, timeout(200).times(2)).putMetrics(r1.capture());
|
||||
verify(sink2, timeout(200).times(2)).putMetrics(r2.capture());
|
||||
} finally {
|
||||
ms.stop();
|
||||
ms.shutdown();
|
||||
}
|
||||
//When we call stop, at most two sources will be consumed by each sink thread.
|
||||
List<MetricsRecord> mr1 = r1.getAllValues();
|
||||
verify(sink2, times(2)).putMetrics(r2.capture());
|
||||
List<MetricsRecord> mr2 = r2.getAllValues();
|
||||
checkMetricsRecords(mr1);
|
||||
assertEquals("output", mr1, mr2);
|
||||
|
||||
}
|
||||
|
||||
@Test public void testMultiThreadedPublish() throws Exception {
|
||||
|
Loading…
Reference in New Issue
Block a user