summaryrefslogtreecommitdiffstats
path: root/src/test/test_rewrite_latency.cc
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 18:45:59 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 18:45:59 +0000
commit19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch)
tree42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /src/test/test_rewrite_latency.cc
parentInitial commit. (diff)
downloadceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.tar.xz
ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.zip
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/test_rewrite_latency.cc')
-rw-r--r--src/test/test_rewrite_latency.cc47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/test/test_rewrite_latency.cc b/src/test/test_rewrite_latency.cc
new file mode 100644
index 000000000..348c8dde5
--- /dev/null
+++ b/src/test/test_rewrite_latency.cc
@@ -0,0 +1,47 @@
+
+#include <unistd.h>
+#include <map>
+#include <errno.h>
+
+#include "include/utime.h"
+#include "common/Clock.h"
+#include "common/errno.h"
+
+using namespace std;
+
+int main(int argc, const char **argv)
+{
+ const char *fn = argv[1];
+ multimap<utime_t, utime_t> latency;
+ unsigned max = 10;
+
+ int fd = ::open(fn, O_CREAT|O_RDWR, 0644);
+ if (fd < 1) {
+ int err = errno;
+ cerr << "failed to open " << fn << " with " << cpp_strerror(err) << std::endl;
+ return -1;
+ }
+
+ while (true) {
+ utime_t now = ceph_clock_now();
+ int r = ::pwrite(fd, fn, strlen(fn), 0);
+ ceph_assert(r >= 0);
+ utime_t lat = ceph_clock_now();
+ lat -= now;
+ utime_t oldmin;
+ if (!latency.empty())
+ oldmin = latency.begin()->first;
+ latency.insert(make_pair(lat, now));
+ utime_t newmin = latency.begin()->first;
+ while (latency.size() > max)
+ latency.erase(latency.begin());
+ if (oldmin == newmin) {
+ cout << "latency\tat" << std::endl;
+ for (multimap<utime_t,utime_t>::reverse_iterator p = latency.rbegin();
+ p != latency.rend();
+ ++p) {
+ cout << p->first << "\t" << p->second << std::endl;
+ }
+ }
+ }
+}