]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
systest: add st_rados_notify building block for watch/notify tests
authorJosh Durgin <josh.durgin@dreamhost.com>
Fri, 29 Jul 2011 22:25:53 +0000 (15:25 -0700)
committerJosh Durgin <josh.durgin@dreamhost.com>
Tue, 2 Aug 2011 21:17:15 +0000 (14:17 -0700)
Signed-off-by: Josh Durgin <josh.durgin@dreamhost.com>
src/test/system/st_rados_notify.cc [new file with mode: 0644]
src/test/system/st_rados_notify.h [new file with mode: 0644]

diff --git a/src/test/system/st_rados_notify.cc b/src/test/system/st_rados_notify.cc
new file mode 100644 (file)
index 0000000..10e3e4b
--- /dev/null
@@ -0,0 +1,72 @@
+// -*- 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) 2011 New Dream Network
+*
+* 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 "cross_process_sem.h"
+#include "include/rados/librados.h"
+#include "st_rados_notify.h"
+#include "systest_runnable.h"
+
+StRadosNotify::StRadosNotify(int argc, const char **argv,
+                            CrossProcessSem *setup_sem,
+                            CrossProcessSem *notify_sem,
+                            CrossProcessSem *notified_sem,
+                            int notify_retcode,
+                            const std::string &pool_name,
+                            const std::string &obj_name)
+  : SysTestRunnable(argc, argv),
+    m_setup_sem(setup_sem),
+    m_notify_sem(notify_sem),
+    m_notified_sem(notified_sem),
+    m_notify_retcode(notify_retcode),
+    m_pool_name(pool_name),
+    m_obj_name(obj_name)
+{
+}
+
+StRadosNotify::~StRadosNotify()
+{
+}
+
+int StRadosNotify::run()
+{
+  rados_t cl;
+  RETURN1_IF_NONZERO(rados_create(&cl, NULL));
+  rados_conf_parse_argv(cl, m_argc, m_argv);
+  RETURN1_IF_NONZERO(rados_conf_read_file(cl, NULL));
+  if (m_setup_sem) {
+    m_setup_sem->wait();
+    m_setup_sem->post();
+  }
+
+  rados_ioctx_t io_ctx;
+  RETURN1_IF_NONZERO(rados_connect(cl));
+  RETURN1_IF_NONZERO(rados_ioctx_create(cl, m_pool_name.c_str(), &io_ctx));
+
+  if (m_notify_sem) {
+    m_notify_sem->wait();
+    m_notify_sem->post();
+  }
+
+  printf("%s: notifying object %s\n", get_id_str(), m_obj_name.c_str());
+  RETURN1_IF_NOT_VAL(m_notify_retcode,
+                    rados_notify(io_ctx, m_obj_name.c_str(), 0, NULL, 0));
+  if (m_notified_sem) {
+    m_notified_sem->post();
+  }
+
+  rados_ioctx_destroy(io_ctx);
+  rados_shutdown(cl);
+
+  return 0;
+}
diff --git a/src/test/system/st_rados_notify.h b/src/test/system/st_rados_notify.h
new file mode 100644 (file)
index 0000000..7c65efb
--- /dev/null
@@ -0,0 +1,52 @@
+// -*- 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) 2011 New Dream Network
+*
+* 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.
+*
+*/
+
+#ifndef TEST_SYSTEM_ST_RADOS_NOTIFY_H
+#define TEST_SYSTEM_ST_RADOS_NOTIFY_H
+
+#include "systest_runnable.h"
+
+class CrossProcessSem;
+
+/*
+ * st_rados_notify
+ *
+ * 1. waits on and then posts to setup_sem
+ * 2. connects and opens the pool
+ * 3. waits on and then posts to notify_sem
+ * 4. notifies on the object
+ * 5. posts to notified_sem
+ */
+class StRadosNotify : public SysTestRunnable
+{
+public:
+  StRadosNotify(int argc, const char **argv,
+               CrossProcessSem *setup_sem,
+               CrossProcessSem *notify_sem,
+               CrossProcessSem *notified_sem,
+               int notify_retcode,
+               const std::string &pool_name,
+               const std::string &obj_name);
+  ~StRadosNotify();
+  virtual int run();
+private:
+  CrossProcessSem *m_setup_sem;
+  CrossProcessSem *m_notify_sem;
+  CrossProcessSem *m_notified_sem;
+  int m_notify_retcode;
+  std::string m_pool_name;
+  std::string m_obj_name;
+};
+
+#endif