/*
This file is part of GNUnet
- (C) 2008--2012 Christian Grothoff (and other contributing authors)
+ Copyright (C) 2008--2013 GNUnet e.V.
GNUnet is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published
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.
+ Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA.
*/
/**
#define TIME_REL_SECS(sec) \
GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, sec)
+/**
+ * configuration handle to use as template configuration while creating hosts
+ */
+static struct GNUNET_CONFIGURATION_Handle *cfg;
+
/**
* Host we are creating and using
*/
static struct GNUNET_TESTBED_Host *host;
/**
- * The host helper handle
+ * An array of hosts which are loaded from a file
*/
-static struct GNUNET_TESTBED_HelperHandle *helper_handle;
+static struct GNUNET_TESTBED_Host **hosts;
/**
- * Global test status
+ * Number of hosts in the above list
*/
-static int status;
+static unsigned int num_hosts;
/**
- * Shutdown task identifier
+ * Global test status
*/
-GNUNET_SCHEDULER_TaskIdentifier shutdown_id;
+static int status;
+
/**
* The shutdown task
*
* @param cls NULL
- * @param tc the task context
*/
static void
-do_shutdown (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
+do_shutdown (void *cls)
{
- GNUNET_TESTBED_host_stop_ (helper_handle);
GNUNET_TESTBED_host_destroy (host);
+ while (0 != num_hosts)
+ {
+ GNUNET_TESTBED_host_destroy (hosts[num_hosts - 1]);
+ num_hosts--;
+ }
+ GNUNET_free (hosts);
+ if (NULL != cfg)
+ {
+ GNUNET_CONFIGURATION_destroy (cfg);
+ cfg = NULL;
+ }
}
/**
- * Callback that will be called when the helper process dies. This is not called
- * when the helper process is stoped using GNUNET_HELPER_stop()
- *
- * @param cls the closure from GNUNET_HELPER_start()
- */
-static void
-exp_cb (void *cls)
-{
- status = GNUNET_SYSERR;
- GNUNET_SCHEDULER_cancel (shutdown_id);
- GNUNET_SCHEDULER_add_now (&do_shutdown, NULL);
-}
-
-
-/**
- * Main run function.
+ * Main run function.
*
* @param cls NULL
* @param args arguments passed to GNUNET_PROGRAM_run
*/
static void
run (void *cls, char *const *args, const char *cfgfile,
- const struct GNUNET_CONFIGURATION_Handle *cfg)
+ const struct GNUNET_CONFIGURATION_Handle *config)
{
- host = GNUNET_TESTBED_host_create ("localhost", NULL, 0);
+ unsigned int cnt;
+
+ cfg = GNUNET_CONFIGURATION_dup (config);
+ host = GNUNET_TESTBED_host_create ("localhost", NULL, cfg, 0);
GNUNET_assert (NULL != host);
GNUNET_assert (0 != GNUNET_TESTBED_host_get_id_ (host));
GNUNET_TESTBED_host_destroy (host);
- host = GNUNET_TESTBED_host_create (NULL, NULL, 0);
+ host = GNUNET_TESTBED_host_create (NULL, NULL, cfg, 0);
GNUNET_assert (NULL != host);
GNUNET_assert (0 == GNUNET_TESTBED_host_get_id_ (host));
GNUNET_assert (host == GNUNET_TESTBED_host_lookup_by_id_ (0));
- helper_handle = GNUNET_TESTBED_host_run_ ("127.0.0.1", host, cfg, &exp_cb, NULL);
- GNUNET_assert (NULL != helper_handle);
- shutdown_id =
- GNUNET_SCHEDULER_add_delayed (TIME_REL_SECS (2), &do_shutdown, NULL);
+ hosts = NULL;
+ num_hosts = GNUNET_TESTBED_hosts_load_from_file ("sample_hosts.txt", cfg, &hosts);
+ GNUNET_assert (7 == num_hosts);
+ GNUNET_assert (NULL != hosts);
+ for (cnt = 0; cnt < num_hosts; cnt++)
+ {
+ if (cnt < 3)
+ {
+ GNUNET_assert (0 == strcmp ("totakura",
+ GNUNET_TESTBED_host_get_username_
+ (hosts[cnt])));
+ GNUNET_assert (NULL != GNUNET_TESTBED_host_get_hostname (hosts[cnt]));
+ GNUNET_assert (22 == GNUNET_TESTBED_host_get_ssh_port_ (hosts[cnt]));
+ }
+ if (3 == cnt)
+ {
+ GNUNET_assert (0 == strcmp ("totakura",
+ GNUNET_TESTBED_host_get_username_
+ (hosts[cnt])));
+ GNUNET_assert (NULL != GNUNET_TESTBED_host_get_hostname (hosts[cnt]));
+ GNUNET_assert (2022 == GNUNET_TESTBED_host_get_ssh_port_ (hosts[cnt]));
+ }
+ if (4 == cnt)
+ {
+ GNUNET_assert (0 == strcmp ("totakura",
+ GNUNET_TESTBED_host_get_username_
+ (hosts[cnt])));
+ GNUNET_assert (0 == strcmp ("asgard.realm",
+ GNUNET_TESTBED_host_get_hostname
+ (hosts[cnt])));
+ GNUNET_assert (22 == GNUNET_TESTBED_host_get_ssh_port_ (hosts[cnt]));
+ }
+ if (5 == cnt)
+ {
+ GNUNET_assert (NULL == GNUNET_TESTBED_host_get_username_ (hosts[cnt]));
+ GNUNET_assert (0 == strcmp ("rivendal",
+ GNUNET_TESTBED_host_get_hostname
+ (hosts[cnt])));
+ GNUNET_assert (22 == GNUNET_TESTBED_host_get_ssh_port_ (hosts[cnt]));
+ }
+ if (6 == cnt)
+ {
+ GNUNET_assert (NULL == GNUNET_TESTBED_host_get_username_ (hosts[cnt]));
+ GNUNET_assert (0 == strcmp ("rohan",
+ GNUNET_TESTBED_host_get_hostname
+ (hosts[cnt])));
+ GNUNET_assert (561 == GNUNET_TESTBED_host_get_ssh_port_ (hosts[cnt]));
+ }
+ }
+ status = GNUNET_YES;
+ GNUNET_SCHEDULER_add_now (&do_shutdown, NULL);
}
-int main (int argc, char **argv)
+int
+main (int argc, char **argv)
{
char *const argv2[] = { "test_testbed_api_hosts",
- "-c", "test_testbed_api.conf",
- NULL
+ "-c", "test_testbed_api.conf",
+ NULL
};
struct GNUNET_GETOPT_CommandLineOption options[] = {
GNUNET_GETOPT_OPTION_END
};
- status = GNUNET_YES;
- if (GNUNET_OK !=
+ status = GNUNET_SYSERR;
+ if (GNUNET_OK !=
GNUNET_PROGRAM_run ((sizeof (argv2) / sizeof (char *)) - 1, argv2,
- "test_testbed_api_hosts", "nohelp",
- options, &run, NULL))
+ "test_testbed_api_hosts", "nohelp", options, &run,
+ NULL))
return 1;
return (GNUNET_OK == status) ? 0 : 1;
}
+
+/* end of test_testbed_api_hosts.c */