/*
This file is part of GNUnet.
Copyright (C)
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
Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see .
SPDX-License-Identifier: AGPL3.0-or-later
*/
/**
* @file rps/test_service_rps_custommap.c
* @brief testcase for gnunet-service-rps_peers.c
*/
#include
#include "gnunet-service-rps_custommap.h"
#define ABORT() { fprintf(stderr, "Error at %s:%d\n", __FILE__, __LINE__); if (NULL != c_m) CustomPeerMap_destroy (c_m); return 1; }
#define CHECK(c) { if (!(c)) ABORT (); }
static int
check()
{
struct CustomPeerMap *c_m;
struct GNUNET_PeerIdentity k1;
struct GNUNET_PeerIdentity k2;
int j;
CHECK(NULL != (c_m = CustomPeerMap_create(4)));
memset(&k1, 0, sizeof(k1));
memset(&k2, 1, sizeof(k2));
CHECK(GNUNET_NO == CustomPeerMap_contains_peer(c_m, &k1));
CHECK(GNUNET_NO == CustomPeerMap_contains_peer(c_m, &k2));
CHECK(GNUNET_NO == CustomPeerMap_remove_peer(c_m, &k1));
CHECK(GNUNET_NO == CustomPeerMap_remove_peer(c_m, &k2));
CHECK(GNUNET_NO == CustomPeerMap_remove_peer_by_index(c_m, 0));
CHECK(GNUNET_NO == CustomPeerMap_remove_peer_by_index(c_m, 0));
CHECK(GNUNET_NO == CustomPeerMap_remove_peer_by_index(c_m, 1));
CHECK(GNUNET_NO == CustomPeerMap_remove_peer_by_index(c_m, 1));
CHECK(NULL == CustomPeerMap_get_peer_by_index(c_m, 0));
CHECK(NULL == CustomPeerMap_get_peer_by_index(c_m, 0));
CHECK(NULL == CustomPeerMap_get_peer_by_index(c_m, 1));
CHECK(NULL == CustomPeerMap_get_peer_by_index(c_m, 1));
CustomPeerMap_clear(c_m); /* See if assertions trigger */
CHECK(0 == CustomPeerMap_size(c_m));
CHECK(GNUNET_OK == CustomPeerMap_put(c_m, &k1));
CHECK(1 == CustomPeerMap_size(c_m));
CHECK(GNUNET_NO == CustomPeerMap_put(c_m, &k1));
CHECK(1 == CustomPeerMap_size(c_m));
CHECK(GNUNET_YES == CustomPeerMap_contains_peer(c_m, &k1));
CHECK(GNUNET_OK == CustomPeerMap_remove_peer(c_m, &k1));
CHECK(0 == CustomPeerMap_size(c_m));
CHECK(GNUNET_NO == CustomPeerMap_contains_peer(c_m, &k1));
CHECK(GNUNET_NO == CustomPeerMap_contains_peer(c_m, &k2));
CHECK(GNUNET_OK == CustomPeerMap_put(c_m, &k1));
CHECK(1 == CustomPeerMap_size(c_m));
for (j = 0; j < 16; j++)
{
CHECK(GNUNET_NO == CustomPeerMap_put(c_m, &k1));
}
CHECK(1 == CustomPeerMap_size(c_m));
CHECK(GNUNET_OK == CustomPeerMap_put(c_m, &k2));
CHECK(2 == CustomPeerMap_size(c_m));
for (j = 0; j < 16; j++)
{
CHECK(GNUNET_NO == CustomPeerMap_put(c_m, &k2));
}
CHECK(2 == CustomPeerMap_size(c_m));
/* iterate */
for (j = 0; j < CustomPeerMap_size(c_m); j++)
{
CHECK(NULL != CustomPeerMap_get_peer_by_index(c_m, j));
}
CHECK((0 == memcmp(CustomPeerMap_get_peer_by_index(c_m, 0),
&k1, sizeof(k1))));
CHECK((0 == memcmp(CustomPeerMap_get_peer_by_index(c_m, 1),
&k2, sizeof(k2))));
CHECK(GNUNET_OK == CustomPeerMap_remove_peer(c_m, &k1));
CHECK(1 == CustomPeerMap_size(c_m));
CHECK(GNUNET_NO == CustomPeerMap_contains_peer(c_m, &k1));
CHECK(GNUNET_YES == CustomPeerMap_contains_peer(c_m, &k2));
CHECK(NULL != CustomPeerMap_get_peer_by_index(c_m, 0));
CustomPeerMap_clear(c_m);
CHECK(0 == CustomPeerMap_size(c_m));
CHECK(GNUNET_OK == CustomPeerMap_put(c_m, &k1));
CHECK(1 == CustomPeerMap_size(c_m));
CHECK(GNUNET_OK == CustomPeerMap_put(c_m, &k2));
CHECK(2 == CustomPeerMap_size(c_m));
CustomPeerMap_clear(c_m);
CHECK(0 == CustomPeerMap_size(c_m));
CustomPeerMap_destroy(c_m);
return 0;
}
int
main(int argc, char *argv[])
{
(void)argc;
(void)argv;
GNUNET_log_setup("test_service_rps_peers",
"WARNING",
NULL);
return check();
}
/* end of test_service_rps_custommap.c */