gnunet-svn
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[GNUnet-SVN] r33538 - gnunet/src/peerstore


From: gnunet
Subject: [GNUnet-SVN] r33538 - gnunet/src/peerstore
Date: Thu, 5 Jun 2014 14:05:14 +0200

Author: otarabai
Date: 2014-06-05 14:05:13 +0200 (Thu, 05 Jun 2014)
New Revision: 33538

Added:
   gnunet/src/peerstore/test_peerstore_stress_store.c
Modified:
   gnunet/src/peerstore/
   gnunet/src/peerstore/Makefile.am
   gnunet/src/peerstore/gnunet-service-peerstore.c
   gnunet/src/peerstore/peerstore_api.c
   gnunet/src/peerstore/peerstore_common.c
Log:
peerstore: stress test + minor fix


Index: gnunet/src/peerstore
===================================================================
--- gnunet/src/peerstore        2014-06-05 10:17:04 UTC (rev 33537)
+++ gnunet/src/peerstore        2014-06-05 12:05:13 UTC (rev 33538)

Property changes on: gnunet/src/peerstore
___________________________________________________________________
Modified: svn:ignore
## -8,3 +8,5 ##
 test_peerstore_api_watch
 test_peerstore_api_store
 test_peerstore_api_iterate
+test_peerstore_stress_store
+
Modified: gnunet/src/peerstore/Makefile.am
===================================================================
--- gnunet/src/peerstore/Makefile.am    2014-06-05 10:17:04 UTC (rev 33537)
+++ gnunet/src/peerstore/Makefile.am    2014-06-05 12:05:13 UTC (rev 33538)
@@ -67,7 +67,8 @@
 check_PROGRAMS = \
  test_peerstore_api_store \
  test_peerstore_api_iterate \
- test_peerstore_api_watch
+ test_peerstore_api_watch \
+ test_peerstore_stress_store
 
 if ENABLE_TEST_RUN
 AM_TESTS_ENVIRONMENT=export 
GNUNET_PREFIX=$${GNUNET_PREFIX:address@hidden@};export 
PATH=$${GNUNET_PREFIX:address@hidden@}/bin:$$PATH;
@@ -94,3 +95,10 @@
   $(top_builddir)/src/peerstore/libgnunetpeerstore.la  \
   $(top_builddir)/src/testing/libgnunettesting.la \
   $(top_builddir)/src/util/libgnunetutil.la
+
+test_peerstore_stress_store_SOURCES = \
+ test_peerstore_stress_store.c
+test_peerstore_stress_store_LDADD = \
+  $(top_builddir)/src/peerstore/libgnunetpeerstore.la  \
+  $(top_builddir)/src/testing/libgnunettesting.la \
+  $(top_builddir)/src/util/libgnunetutil.la

Modified: gnunet/src/peerstore/gnunet-service-peerstore.c
===================================================================
--- gnunet/src/peerstore/gnunet-service-peerstore.c     2014-06-05 10:17:04 UTC 
(rev 33537)
+++ gnunet/src/peerstore/gnunet-service-peerstore.c     2014-06-05 12:05:13 UTC 
(rev 33538)
@@ -202,7 +202,6 @@
 {
   struct GNUNET_HashCode keyhash;
 
-  GNUNET_log(GNUNET_ERROR_TYPE_DEBUG, "Sending update to any watchers.\n");
   PEERSTORE_hash_key(record->sub_system,
       record->peer,
       record->key,

Modified: gnunet/src/peerstore/peerstore_api.c
===================================================================
--- gnunet/src/peerstore/peerstore_api.c        2014-06-05 10:17:04 UTC (rev 
33537)
+++ gnunet/src/peerstore/peerstore_api.c        2014-06-05 12:05:13 UTC (rev 
33538)
@@ -387,8 +387,6 @@
 void
 GNUNET_PEERSTORE_store_cancel (struct GNUNET_PEERSTORE_StoreContext *sc)
 {
-  LOG(GNUNET_ERROR_TYPE_DEBUG,
-          "Canceling store request.\n");
   if(NULL != sc->ev)
   {
     GNUNET_MQ_send_cancel(sc->ev);
@@ -548,7 +546,6 @@
 void
 GNUNET_PEERSTORE_iterate_cancel (struct GNUNET_PEERSTORE_IterateContext *ic)
 {
-  LOG(GNUNET_ERROR_TYPE_DEBUG, "Canceling iterate request.\n");
   if(GNUNET_SCHEDULER_NO_TASK != ic->timeout_task)
   {
     GNUNET_SCHEDULER_cancel(ic->timeout_task);
@@ -728,7 +725,8 @@
   GNUNET_CONTAINER_multihashmap_put(h->watches, &wc->keyhash,
       wc, GNUNET_CONTAINER_MULTIHASHMAPOPTION_REPLACE);
   LOG(GNUNET_ERROR_TYPE_DEBUG,
-      "Sending a watch request for sub system `%s'.\n", sub_system);
+      "Sending a watch request for ss `%s', peer `%s', key `%s'.\n",
+      sub_system, GNUNET_i2s(peer), key);
   GNUNET_MQ_notify_sent(ev, &watch_request_sent, wc);
   GNUNET_MQ_send(h->mq, ev);
   return wc;

Modified: gnunet/src/peerstore/peerstore_common.c
===================================================================
--- gnunet/src/peerstore/peerstore_common.c     2014-06-05 10:17:04 UTC (rev 
33537)
+++ gnunet/src/peerstore/peerstore_common.c     2014-06-05 12:05:13 UTC (rev 
33538)
@@ -44,7 +44,7 @@
 
   sssize = strlen(sub_system) + 1;
   psize = sizeof(struct GNUNET_PeerIdentity);
-  ksize = strlen(sub_system) + 1;
+  ksize = strlen(key) + 1;
   totalsize = sssize + psize + ksize;
   block = GNUNET_malloc(totalsize);
   blockptr = block;

Added: gnunet/src/peerstore/test_peerstore_stress_store.c
===================================================================
--- gnunet/src/peerstore/test_peerstore_stress_store.c                          
(rev 0)
+++ gnunet/src/peerstore/test_peerstore_stress_store.c  2014-06-05 12:05:13 UTC 
(rev 33538)
@@ -0,0 +1,120 @@
+/*
+     This file is part of GNUnet.
+     (C)
+
+     GNUnet is free software; you can redistribute it and/or modify
+     it under the terms of the GNU General Public License as published
+     by the Free Software Foundation; either version 3, or (at your
+     option) any later version.
+
+     GNUnet is distributed in the hope that it will be useful, but
+     WITHOUT ANY WARRANTY; without even the implied warranty of
+     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+     General Public License for more details.
+
+     You should have received a copy of the GNU General Public License
+     along with GNUnet; see the file COPYING.  If not, write to the
+     Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+     Boston, MA 02111-1307, USA.
+*/
+/**
+ * @file peerstore/test_peerstore_stress_store.c
+ * @brief stress test for peerstore store operation
+ */
+#include "platform.h"
+#include "gnunet_util_lib.h"
+#include "gnunet_testing_lib.h"
+#include "gnunet_peerstore_service.h"
+
+#define STORES 100
+
+static int ok = 1;
+
+struct GNUNET_PEERSTORE_Handle *h;
+
+char *ss = "test_peerstore_stress";
+struct GNUNET_PeerIdentity p;
+char *k = "test_peerstore_stress_key";
+char *v = "test_peerstore_stress_val";
+
+int count = 0;
+
+void
+disconnect()
+{
+  if(NULL != h)
+    GNUNET_PEERSTORE_disconnect(h);
+  GNUNET_SCHEDULER_shutdown();
+}
+
+void
+store()
+{
+  GNUNET_PEERSTORE_store(h,
+      ss,
+      &p,
+      k,
+      v,
+      strlen(v) + 1,
+      GNUNET_TIME_UNIT_FOREVER_ABS,
+      (count == 0) ? GNUNET_PEERSTORE_STOREOPTION_REPLACE : 
GNUNET_PEERSTORE_STOREOPTION_MULTIPLE,
+      NULL,
+      NULL);
+  count++;
+}
+
+static int
+watch_cb(void *cls,
+    struct GNUNET_PEERSTORE_Record *record,
+    char *emsg)
+{
+  GNUNET_assert(NULL == emsg);
+  if(STORES == count)
+  {
+    ok = 0;
+    disconnect();
+  }
+  else
+    store();
+  return GNUNET_YES;
+}
+
+static void
+run (void *cls,
+    const struct GNUNET_CONFIGURATION_Handle *cfg,
+    struct GNUNET_TESTING_Peer *peer)
+{
+  memset (&p, 5, sizeof (p));
+  h = GNUNET_PEERSTORE_connect(cfg);
+  GNUNET_assert(NULL != h);
+  GNUNET_PEERSTORE_watch(h,
+      ss,
+      &p,
+      k,
+      &watch_cb,
+      NULL);
+  store();
+}
+
+int
+main (int argc, char *argv[])
+{
+  struct GNUNET_TIME_Absolute start;
+  struct GNUNET_TIME_Absolute end;
+  struct GNUNET_TIME_Relative diff;
+
+  start = GNUNET_TIME_absolute_get();
+  if (0 != GNUNET_TESTING_service_run ("test-gnunet-peerstore",
+                 "peerstore",
+                 "test_peerstore_api_data.conf",
+                 &run, NULL))
+    return 1;
+  end = GNUNET_TIME_absolute_get();
+  diff = GNUNET_TIME_absolute_get_difference(start, end);
+  printf("Stored and retrieved %d records in %s (%s).\n",
+      STORES, GNUNET_STRINGS_relative_time_to_string(diff, GNUNET_YES),
+      GNUNET_STRINGS_relative_time_to_string(diff, GNUNET_NO));
+  return ok;
+}
+
+/* end of test_peerstore_stress.c */




reply via email to

[Prev in Thread] Current Thread [Next in Thread]