aboutsummaryrefslogtreecommitdiff
path: root/src/namestore/test_plugin_namestore.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/namestore/test_plugin_namestore.c')
-rw-r--r--src/namestore/test_plugin_namestore.c248
1 files changed, 248 insertions, 0 deletions
diff --git a/src/namestore/test_plugin_namestore.c b/src/namestore/test_plugin_namestore.c
new file mode 100644
index 0000000..0b0008f
--- /dev/null
+++ b/src/namestore/test_plugin_namestore.c
@@ -0,0 +1,248 @@
+/*
+ This file is part of GNUnet.
+ (C) 2012 Christian Grothoff (and other contributing authors)
+
+ 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 namestore/test_plugin_namestore.c
+ * @brief Test for the namestore plugins
+ * @author Christian Grothoff
+ */
+#include "platform.h"
+#include "gnunet_util_lib.h"
+#include "gnunet_namestore_plugin.h"
+
+#define VERBOSE GNUNET_NO
+
+#define ASSERT(x) do { if (! (x)) { printf("Error at %s:%d\n", __FILE__, __LINE__); goto FAILURE;} } while (0)
+
+static int ok;
+
+/**
+ * Name of plugin under test.
+ */
+static const char *plugin_name;
+
+
+/**
+ * Function called when the service shuts down. Unloads our namestore
+ * plugin.
+ *
+ * @param api api to unload
+ */
+static void
+unload_plugin (struct GNUNET_NAMESTORE_PluginFunctions *api)
+{
+ char *libname;
+
+ GNUNET_asprintf (&libname, "libgnunet_plugin_namestore_%s", plugin_name);
+ GNUNET_break (NULL == GNUNET_PLUGIN_unload (libname, api));
+ GNUNET_free (libname);
+}
+
+
+/**
+ * Load the namestore plugin.
+ *
+ * @param cfg configuration to pass
+ * @return NULL on error
+ */
+static struct GNUNET_NAMESTORE_PluginFunctions *
+load_plugin (const struct GNUNET_CONFIGURATION_Handle *cfg)
+{
+ struct GNUNET_NAMESTORE_PluginFunctions *ret;
+ char *libname;
+
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO, _("Loading `%s' namestore plugin\n"),
+ plugin_name);
+ GNUNET_asprintf (&libname, "libgnunet_plugin_namestore_%s", plugin_name);
+ if (NULL == (ret = GNUNET_PLUGIN_load (libname, (void*) cfg)))
+ {
+ FPRINTF (stderr, "Failed to load plugin `%s'!\n", plugin_name);
+ return NULL;
+ }
+ GNUNET_free (libname);
+ return ret;
+}
+
+
+/**
+ * Function called by for each matching record.
+ *
+ * @param cls closure
+ * @param zone_key public key of the zone
+ * @param expire when does the corresponding block in the DHT expire (until
+ * when should we never do a DHT lookup for the same name again)?
+ * @param name name that is being mapped (at most 255 characters long)
+ * @param rd_count number of entries in 'rd' array
+ * @param rd array of records with data to store
+ * @param signature signature of the record block, NULL if signature is unavailable (i.e.
+ * because the user queried for a particular record type only)
+ */
+static void
+test_record (void *cls,
+ const struct GNUNET_CRYPTO_RsaPublicKeyBinaryEncoded *zone_key,
+ struct GNUNET_TIME_Absolute expire,
+ const char *name,
+ unsigned int rd_count,
+ const struct GNUNET_NAMESTORE_RecordData *rd,
+ const struct GNUNET_CRYPTO_RsaSignature *signature)
+{
+ int *idp = cls;
+ int id = *idp;
+ struct GNUNET_CRYPTO_RsaPublicKeyBinaryEncoded tzone_key;
+ char tname[64];
+ unsigned int trd_count = 1 + (id % 1024);
+ struct GNUNET_CRYPTO_RsaSignature tsignature;
+ unsigned int i;
+
+ GNUNET_snprintf (tname, sizeof (tname),
+ "a%u", (unsigned int ) id);
+ for (i=0;i<trd_count;i++)
+ {
+ GNUNET_assert (rd[i].data_size == id % 10);
+ GNUNET_assert (0 == memcmp ("Hello World", rd[i].data, id % 10));
+ GNUNET_assert (rd[i].record_type == 1 + (id % 13));
+ GNUNET_assert (rd[i].flags == (id % 7));
+ }
+ memset (&tzone_key, (id % 241), sizeof (tzone_key));
+ memset (&tsignature, (id % 243), sizeof (tsignature));
+ GNUNET_assert (0 == strcmp (name, tname));
+ GNUNET_assert (0 == memcmp (&tzone_key, zone_key, sizeof (struct GNUNET_CRYPTO_RsaPublicKeyBinaryEncoded)));
+ GNUNET_assert (0 == memcmp (&tsignature, signature, sizeof (struct GNUNET_CRYPTO_RsaSignature)));
+}
+
+
+static void
+get_record (struct GNUNET_NAMESTORE_PluginFunctions *nsp, int id)
+{
+ GNUNET_assert (1 == nsp->iterate_records (nsp->cls,
+ NULL, NULL, 0,
+ &test_record, &id));
+}
+
+
+static void
+put_record (struct GNUNET_NAMESTORE_PluginFunctions *nsp, int id)
+{
+ struct GNUNET_CRYPTO_RsaPublicKeyBinaryEncoded zone_key;
+ struct GNUNET_TIME_Absolute expire;
+ char name[64];
+ unsigned int rd_count = 1 + (id % 1024);
+ struct GNUNET_NAMESTORE_RecordData rd[rd_count];
+ struct GNUNET_CRYPTO_RsaSignature signature;
+ unsigned int i;
+
+ GNUNET_snprintf (name, sizeof (name),
+ "a%u", (unsigned int ) id);
+ expire = GNUNET_TIME_relative_to_absolute (GNUNET_TIME_UNIT_MINUTES);
+ for (i=0;i<rd_count;i++)
+ {
+ rd[i].data = "Hello World";
+ rd[i].data_size = id % 10;
+ rd[i].expiration = GNUNET_TIME_relative_to_absolute (GNUNET_TIME_UNIT_MINUTES);
+ rd[i].record_type = 1 + (id % 13);
+ rd[i].flags = (id % 7);
+ }
+ memset (&zone_key, (id % 241), sizeof (zone_key));
+ memset (&signature, (id % 243), sizeof (signature));
+ GNUNET_assert (GNUNET_OK == nsp->put_records (nsp->cls,
+ &zone_key,
+ expire,
+ name,
+ rd_count,
+ rd,
+ &signature));
+}
+
+
+static void
+run (void *cls, char *const *args, const char *cfgfile,
+ const struct GNUNET_CONFIGURATION_Handle *cfg)
+{
+ struct GNUNET_NAMESTORE_PluginFunctions *nsp;
+ struct GNUNET_CRYPTO_RsaPublicKeyBinaryEncoded zone_key;
+ GNUNET_HashCode zone;
+
+ ok = 0;
+ nsp = load_plugin (cfg);
+ if (NULL == nsp)
+ {
+ FPRINTF (stderr,
+ "%s",
+ "Failed to initialize namestore. Database likely not setup, skipping test.\n");
+ return;
+ }
+ put_record (nsp, 1);
+ get_record (nsp, 1);
+
+ memset (&zone_key, 1, sizeof (zone_key));
+ GNUNET_CRYPTO_hash (&zone_key, sizeof (zone_key), &zone);
+ nsp->delete_zone (nsp->cls, &zone);
+ unload_plugin (nsp);
+}
+
+
+int
+main (int argc, char *argv[])
+{
+ char *pos;
+ char cfg_name[128];
+
+ char *const xargv[] = {
+ "test-plugin-namestore",
+ "-c",
+ cfg_name,
+#if VERBOSE
+ "-L", "DEBUG",
+#endif
+ NULL
+ };
+ struct GNUNET_GETOPT_CommandLineOption options[] = {
+ GNUNET_GETOPT_OPTION_END
+ };
+
+ GNUNET_DISK_directory_remove ("/tmp/gnunet-test-plugin-namestore-sqlite");
+ GNUNET_log_setup ("test-plugin-namestore",
+#if VERBOSE
+ "DEBUG",
+#else
+ "WARNING",
+#endif
+ NULL);
+ /* determine name of plugin to use */
+ plugin_name = argv[0];
+ while (NULL != (pos = strstr (plugin_name, "_")))
+ plugin_name = pos + 1;
+ if (NULL != (pos = strstr (plugin_name, ".")))
+ pos[0] = 0;
+ else
+ pos = (char *) plugin_name;
+
+ GNUNET_snprintf (cfg_name, sizeof (cfg_name), "test_plugin_namestore_%s.conf",
+ plugin_name);
+ if (pos != plugin_name)
+ pos[0] = '.';
+ GNUNET_PROGRAM_run ((sizeof (xargv) / sizeof (char *)) - 1, xargv,
+ "test-plugin-namestore", "nohelp", options, &run, NULL);
+ if (ok != 0)
+ FPRINTF (stderr, "Missed some testcases: %d\n", ok);
+ GNUNET_DISK_directory_remove ("/tmp/gnunet-test-plugin-namestore-sqlite");
+ return ok;
+}
+
+/* end of test_plugin_namestore.c */