]> git.apps.os.sepia.ceph.com Git - ceph-ci.git/commitdiff
neorados: Op creation benchmark
authorAdam C. Emerson <aemerson@redhat.com>
Tue, 6 Aug 2019 20:18:46 +0000 (16:18 -0400)
committerAdam C. Emerson <aemerson@redhat.com>
Fri, 15 May 2020 14:55:10 +0000 (10:55 -0400)
Signed-off-by: Adam C. Emerson <aemerson@redhat.com>
src/test/neorados/CMakeLists.txt
src/test/neorados/op_speed.cc [new file with mode: 0644]

index c9a506a11602af909b2e07cf67f9e3b8b0526223..14760ab6e8c8d8b1b72b70348811582f493b3572 100644 (file)
@@ -4,3 +4,7 @@ target_link_libraries(ceph_test_neorados_start_stop global libneorados ${unittes
 add_executable(ceph_test_neorados_completions completions.cc)
 target_link_libraries(ceph_test_neorados_completions Boost::system pthread
   ${unittest_libs})
+
+add_executable(ceph_test_neorados_op_speed op_speed.cc)
+target_link_libraries(ceph_test_neorados_op_speed
+  libneorados fmt::fmt ${unittest_libs})
diff --git a/src/test/neorados/op_speed.cc b/src/test/neorados/op_speed.cc
new file mode 100644 (file)
index 0000000..587c345
--- /dev/null
@@ -0,0 +1,34 @@
+// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
+// vim: ts=8 sw=2 smarttab
+/*
+ * Ceph - scalable distributed file system
+ *
+ * Copyright (C) 2019 Red Hat <contact@redhat.com>
+ * Author: Adam C. Emerson <aemerson@redhat.com>
+ *
+ * This is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License version 2.1, as published by the Free Software
+ * Foundation.  See file COPYING.
+ *
+ */
+
+#include "include/neorados/RADOS.hpp"
+
+constexpr int to_create = 10'000'000;
+
+int main() {
+  for (int i = 0; i < to_create; ++i) {
+    neorados::ReadOp op;
+    bufferlist bl;
+    std::uint64_t sz;
+    ceph::real_time tm;
+    boost::container::flat_map<std::string, ceph::buffer::list> xattrs;
+    boost::container::flat_map<std::string, ceph::buffer::list> omap;
+    bool trunc;
+    op.read(0, 0, &bl);
+    op.stat(&sz, &tm);
+    op.get_xattrs(&xattrs);
+    op.get_omap_vals(std::nullopt, std::nullopt, 1000, &omap, &trunc);
+  }
+}