APITimer: sum should return a value and values are in ns

When removing the pull based timers in the API the sum method in the
APITimer was left stubed by mistake.

This patch take the sum from the histogram as it should be.

Another missed changes are the units, in the yammer library the Timer
does unit conversion before returning the values.

This patch takes the unit conversion from the yammer library to be
compatible.

Signed-off-by: Amnon Heiman <amnon@scylladb.com>
Message-Id: <1464173726-7482-1-git-send-email-amnon@scylladb.com>
This commit is contained in:
Amnon Heiman 2016-05-25 13:55:26 +03:00 committed by Pekka Enberg
parent 12daaf546d
commit 9e97cb530a

View File

@ -25,6 +25,10 @@ public class APITimer extends Timer {
final APIHistogram histogram; final APIHistogram histogram;
APIClient c = new APIClient(); APIClient c = new APIClient();
private double convertFromNS(double ns) {
return ns / TimeUnit.NANOSECONDS.convert(1, durationUnit);
}
String url; String url;
public APITimer(String url, ScheduledExecutorService tickThread, public APITimer(String url, ScheduledExecutorService tickThread,
@ -52,31 +56,31 @@ public class APITimer extends Timer {
@Override @Override
public double max() { public double max() {
update_fields(); update_fields();
return histogram.max(); return convertFromNS(histogram.max());
} }
@Override @Override
public double min() { public double min() {
update_fields(); update_fields();
return histogram.min(); return convertFromNS(histogram.min());
} }
@Override @Override
public double mean() { public double mean() {
update_fields(); update_fields();
return histogram.mean(); return convertFromNS(histogram.mean());
} }
@Override @Override
public double stdDev() { public double stdDev() {
update_fields(); update_fields();
return histogram.stdDev(); return convertFromNS(histogram.stdDev());
} }
@Override @Override
public double sum() { public double sum() {
update_fields(); update_fields();
return 0; return convertFromNS(histogram.sum());
} }
@Override @Override