From 19fcec84d8d7d21e796c7624e521b60d28ee21ed Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 20:45:59 +0200 Subject: Adding upstream version 16.2.11+ds. Signed-off-by: Daniel Baumann --- src/test/osd/TestOpStat.cc | 58 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 src/test/osd/TestOpStat.cc (limited to 'src/test/osd/TestOpStat.cc') diff --git a/src/test/osd/TestOpStat.cc b/src/test/osd/TestOpStat.cc new file mode 100644 index 000000000..48b87b885 --- /dev/null +++ b/src/test/osd/TestOpStat.cc @@ -0,0 +1,58 @@ +// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- +#include "include/interval_set.h" +#include "include/buffer.h" +#include +#include +#include +#include "RadosModel.h" +#include "TestOpStat.h" + +void TestOpStat::begin(TestOp *in) { + std::lock_guard l{stat_lock}; + stats[in->getType()].begin(in); +} + +void TestOpStat::end(TestOp *in) { + std::lock_guard l{stat_lock}; + stats[in->getType()].end(in); +} + +void TestOpStat::TypeStatus::export_latencies(map &in) const +{ + map::iterator i = in.begin(); + multiset::iterator j = latencies.begin(); + int count = 0; + while (j != latencies.end() && i != in.end()) { + count++; + if ((((double)count)/((double)latencies.size())) * 100 >= i->first) { + i->second = *j; + ++i; + } + ++j; + } +} + +std::ostream & operator<<(std::ostream &out, const TestOpStat &rhs) +{ + std::lock_guard l{rhs.stat_lock}; + for (auto i = rhs.stats.begin(); + i != rhs.stats.end(); + ++i) { + map latency; + latency[10] = 0; + latency[50] = 0; + latency[90] = 0; + latency[99] = 0; + i->second.export_latencies(latency); + + out << i->first << " latency: " << std::endl; + for (map::iterator j = latency.begin(); + j != latency.end(); + ++j) { + if (j->second == 0) break; + out << "\t" << j->first << "th percentile: " + << j->second / 1000 << "ms" << std::endl; + } + } + return out; +} -- cgit v1.2.3