/*
This file is part of GNUnet.
- (C) 2012 Christian Grothoff (and other contributing authors)
+ Copyright (C) 2012 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
- by the Free Software Foundation; either version 3, or (at your
- option) any later version.
+ GNUnet is free software: you can redistribute it and/or modify it
+ under the terms of the GNU Affero General Public License as published
+ by the Free Software Foundation, either version 3 of the License,
+ 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.
+ Affero 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.
-*/
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+ SPDX-License-Identifier: AGPL3.0-or-later
+ */
/**
* @file consensus/test_consensus_api.c
static struct GNUNET_HashCode session_id;
+static unsigned int elements_received;
-static int
-conclude_done (void *cls, const struct GNUNET_CONSENSUS_Group *group)
+
+static void
+conclude_done (void *cls)
{
- if (NULL == group)
- {
- GNUNET_log (GNUNET_ERROR_TYPE_INFO, "conclude over\n");
- GNUNET_SCHEDULER_shutdown ();
- return GNUNET_NO;
- }
- GNUNET_log (GNUNET_ERROR_TYPE_INFO, "concluded\n");
- return GNUNET_YES;
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO, "conclude over\n");
+ if (2 != elements_received)
+ GNUNET_assert (0);
+ GNUNET_SCHEDULER_shutdown ();
}
-static int
+
+static void
on_new_element (void *cls,
- struct GNUNET_CONSENSUS_Element *element)
+ const struct GNUNET_SET_Element *element)
{
- GNUNET_assert (0);
- return GNUNET_YES;
+ elements_received++;
}
+
static void
insert_done (void *cls, int success)
{
/* make sure cb is only called once */
static int called = GNUNET_NO;
+
GNUNET_assert (GNUNET_NO == called);
called = GNUNET_YES;
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "insert done\n");
- GNUNET_CONSENSUS_conclude (consensus, GNUNET_TIME_UNIT_SECONDS, 0, &conclude_done, NULL);
+ GNUNET_CONSENSUS_conclude (consensus, &conclude_done, NULL);
}
* Signature of the main function of a task.
*
* @param cls closure
- * @param tc context information (why was this task triggered now)
*/
static void
-on_shutdown (void *cls,
- const struct GNUNET_SCHEDULER_TaskContext *tc)
+on_shutdown (void *cls)
{
if (NULL != consensus)
{
static void
-run (void *cls,
+run (void *cls,
const struct GNUNET_CONFIGURATION_Handle *cfg,
struct GNUNET_TESTING_Peer *peer)
{
char *str = "foo";
- struct GNUNET_CONSENSUS_Element el1 = {"foo", 4, 0};
- struct GNUNET_CONSENSUS_Element el2 = {"bar", 4, 0};
+ struct GNUNET_SET_Element el1 = { 4, 0, "foo" };
+ struct GNUNET_SET_Element el2 = { 5, 0, "quux" };
GNUNET_log_setup ("test_consensus_api",
"INFO",
NULL);
-
- GNUNET_log (GNUNET_ERROR_TYPE_INFO, "testing consensus api\n");
-
- GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_FOREVER_REL, &on_shutdown, NULL);
+ GNUNET_SCHEDULER_add_shutdown (&on_shutdown, NULL);
GNUNET_CRYPTO_hash (str, strlen (str), &session_id);
- consensus = GNUNET_CONSENSUS_create (cfg, 0, NULL, &session_id, on_new_element, &consensus);
+ consensus = GNUNET_CONSENSUS_create (cfg, 0, NULL, &session_id,
+ GNUNET_TIME_relative_to_absolute (
+ GNUNET_TIME_UNIT_SECONDS),
+ GNUNET_TIME_relative_to_absolute (
+ GNUNET_TIME_UNIT_MINUTES),
+ on_new_element, &consensus);
GNUNET_assert (consensus != NULL);
GNUNET_CONSENSUS_insert (consensus, &el1, NULL, &consensus);
int
main (int argc, char **argv)
{
- int ret;
-
- ret = GNUNET_TESTING_peer_run ("test_consensus_api",
- "test_consensus.conf",
- &run, NULL);
- return ret;
+ return GNUNET_TESTING_peer_run ("test_consensus_api",
+ "test_consensus.conf",
+ &run, NULL);
}
-