#include "platform.h"
#include "gnunet_util_lib.h"
#include "gnunet_namestore_plugin.h"
+#include "gnunet_testing_lib.h"
-#define VERBOSE GNUNET_EXTRA_LOGGING
-
-#define ASSERT(x) do { if (! (x)) { printf("Error at %s:%d\n", __FILE__, __LINE__); goto FAILURE;} } while (0)
static int ok;
if (NULL == (ret = GNUNET_PLUGIN_load (libname, (void*) cfg)))
{
FPRINTF (stderr, "Failed to load plugin `%s'!\n", plugin_name);
+ GNUNET_free (libname);
return NULL;
}
GNUNET_free (libname);
}
+static void
+test_record (void *cls,
+ const struct GNUNET_CRYPTO_EcdsaPrivateKey *private_key,
+ const char *label,
+ unsigned int rd_count,
+ const struct GNUNET_GNSRECORD_Data *rd)
+{
+ int *idp = cls;
+ int id = *idp;
+ struct GNUNET_CRYPTO_EcdsaPrivateKey tzone_private_key;
+ char tname[64];
+ unsigned int trd_count = 1 + (id % 1024);
+ 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 == 0);
+ }
+ memset (&tzone_private_key, (id % 241), sizeof (tzone_private_key));
+ GNUNET_assert (0 == strcmp (label, tname));
+ GNUNET_assert (0 == memcmp (&tzone_private_key, private_key, sizeof (struct GNUNET_CRYPTO_EcdsaPrivateKey)));
+}
+
+
+static void
+get_record (struct GNUNET_NAMESTORE_PluginFunctions *nsp, int id)
+{
+ GNUNET_assert (GNUNET_OK == nsp->iterate_records (nsp->cls,
+ NULL, 0, &test_record, &id));
+}
+
+
+static void
+put_record (struct GNUNET_NAMESTORE_PluginFunctions *nsp, int id)
+{
+ struct GNUNET_CRYPTO_EcdsaPrivateKey zone_private_key;
+ char label[64];
+ unsigned int rd_count = 1 + (id % 1024);
+ struct GNUNET_GNSRECORD_Data rd[rd_count];
+ struct GNUNET_CRYPTO_EcdsaSignature signature;
+ unsigned int i;
+
+ GNUNET_snprintf (label, sizeof (label),
+ "a%u", (unsigned int ) id);
+ for (i=0;i<rd_count;i++)
+ {
+ rd[i].data = "Hello World";
+ rd[i].data_size = id % 10;
+ rd[i].expiration_time = GNUNET_TIME_relative_to_absolute (GNUNET_TIME_UNIT_MINUTES).abs_value_us;
+ rd[i].record_type = 1 + (id % 13);
+ rd[i].flags = 0;
+ }
+ memset (&zone_private_key, (id % 241), sizeof (zone_private_key));
+ memset (&signature, (id % 243), sizeof (signature));
+ GNUNET_assert (GNUNET_OK == nsp->store_records (nsp->cls,
+ &zone_private_key,
+ label,
+ rd_count,
+ rd));
+}
+
+
static void
run (void *cls, char *const *args, const char *cfgfile,
const struct GNUNET_CONFIGURATION_Handle *cfg)
if (NULL == nsp)
{
FPRINTF (stderr,
- "%s",
+ "%s",
"Failed to initialize namestore. Database likely not setup, skipping test.\n");
return;
}
-
+ put_record (nsp, 1);
+ get_record (nsp, 1);
+
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;
-
+ plugin_name = GNUNET_TESTING_get_testname_from_underscore (argv[0]);
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;
}