/**
* Number of peers we want to start
*/
-#define NUM_PEERS 100
+#define NUM_PEERS 50
/**
* Array of peers
*/
static struct GNUNET_TESTBED_Operation *op;
+/**
+ * Shutdown task
+ */
+static GNUNET_SCHEDULER_TaskIdentifier shutdown_task;
+
/**
* Testing result
*/
static void
do_shutdown (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
{
+ shutdown_task = GNUNET_SCHEDULER_NO_TASK;
if (NULL != op)
{
GNUNET_TESTBED_operation_done (op);
GNUNET_SCHEDULER_add_now (&do_shutdown, NULL);
}
break;
+ case GNUNET_TESTBED_ET_OPERATION_FINISHED:
+ GNUNET_assert (NULL != event->details.operation_finished.emsg);
+ break;
default:
GNUNET_break (0);
if ((GNUNET_TESTBED_ET_OPERATION_FINISHED == event->type) &&
"An operation failed with error: %s\n",
event->details.operation_finished.emsg);
result = GNUNET_SYSERR;
- GNUNET_SCHEDULER_add_now (&do_shutdown, NULL);
+ GNUNET_SCHEDULER_cancel (shutdown_task);
+ shutdown_task = GNUNET_SCHEDULER_add_now (&do_shutdown, NULL);
}
}
overlay_connects = 0;
op = GNUNET_TESTBED_overlay_configure_topology (NULL, NUM_PEERS, peers,
GNUNET_TESTBED_TOPOLOGY_ERDOS_RENYI,
- NUM_PEERS);
+ NUM_PEERS, GNUNET_TESTBED_TOPOLOGY_OPTION_END);
GNUNET_assert (NULL != op);
+ shutdown_task = GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_relative_multiply
+ (GNUNET_TIME_UNIT_SECONDS, 120),
+ do_shutdown, NULL);
}