/* 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 */