2 This file is part of GNUnet.
3 (C) 2010,2011 Christian Grothoff (and other contributing authors)
5 GNUnet is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published
7 by the Free Software Foundation; either version 3, or (at your
8 option) any later version.
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with GNUnet; see the file COPYING. If not, write to the
17 Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA.
21 * @file ats/test_ats_api_performance_monitor.c
22 * @brief test performance monitoring
23 * @author Christian Grothoff
24 * @author Matthias Wachs
27 #include "gnunet_ats_service.h"
28 #include "gnunet_testing_lib.h"
31 #define TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 20)
32 #define SHUTDOWN_CORRECT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 5)
36 static GNUNET_SCHEDULER_TaskIdentifier die_task;
37 static GNUNET_SCHEDULER_TaskIdentifier stage_task;
39 struct GNUNET_CONFIGURATION_Handle *cfg;
41 static struct GNUNET_ATS_SchedulingHandle *sh;
43 static struct GNUNET_ATS_PerformanceHandle *ph;
45 static struct GNUNET_HELLO_Address addr;
47 static struct GNUNET_ATS_Information atsi[ATS_COUNT];
51 static void cleanup_addresses ()
53 GNUNET_ATS_address_destroyed (sh, &addr, NULL);
56 static void setup_addresses ()
58 memset (&addr.peer,'\0', sizeof (addr.peer));
59 addr.transport_name = "test";
61 addr.address_length = 0;
62 atsi[0].type = htonl(GNUNET_ATS_NETWORK_TYPE);
63 atsi[0].value = htonl(GNUNET_ATS_NET_LAN);
65 atsi[1].type = htonl(GNUNET_ATS_QUALITY_NET_DELAY);
66 atsi[1].value = htonl(100);
68 atsi[2].type = htonl(GNUNET_ATS_QUALITY_NET_DISTANCE);
69 atsi[2].value = htonl(5);
71 GNUNET_ATS_address_add (sh, &addr, NULL, atsi, ATS_COUNT);
78 if (GNUNET_SCHEDULER_NO_TASK != stage_task)
80 GNUNET_SCHEDULER_cancel (stage_task);
81 stage_task = GNUNET_SCHEDULER_NO_TASK;
83 if (GNUNET_SCHEDULER_NO_TASK != die_task)
85 GNUNET_SCHEDULER_cancel (die_task);
86 die_task = GNUNET_SCHEDULER_NO_TASK;
88 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Shutdown\n");
94 GNUNET_ATS_performance_done (ph);
100 GNUNET_ATS_scheduling_done (sh);
107 end_badly (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
109 die_task = GNUNET_SCHEDULER_NO_TASK;
110 GNUNET_log (GNUNET_ERROR_TYPE_ERROR, "Timeout\n");
115 next_stage (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
117 static int stage_counter = 0;
119 stage_task = GNUNET_SCHEDULER_NO_TASK;
120 if (0 == stage_counter)
122 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Stop performance monitoring\n");
124 stage_task = GNUNET_SCHEDULER_add_delayed (SHUTDOWN_CORRECT, &next_stage, NULL);
134 static void end (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
136 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Success\n");
142 perf_mon_cb (void *cls,
143 const struct GNUNET_PeerIdentity *peer,
144 const struct GNUNET_BANDWIDTH_Value32NBO bandwidth_out,
145 const struct GNUNET_BANDWIDTH_Value32NBO bandwidth_in,
146 const struct GNUNET_ATS_Information *ats,
149 static int stage_counter = 0;
154 if (0 == stage_counter)
156 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Received initial callback for peer `%s' with %u information\n",
157 GNUNET_i2s (&addr.peer), ats_count);
158 if ((0 != memcmp (peer, &addr.peer, sizeof (addr.peer))) ||
159 (ats_count < ATS_COUNT))
162 GNUNET_SCHEDULER_add_now (&end_badly, NULL);
166 for (c1 = 0; c1 < ats_count; c1++)
168 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "ATS information [%u] %u : %u \n", c1, ntohl (ats[c1].type), ntohl (ats[c1].value));
169 for (c2 = 0; c2 < ATS_COUNT; c2++)
171 if (ats[c1].type == atsi[c2].type)
173 if (ats[c1].value == atsi[c2].value)
187 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Received only %u correct ATS information \n", c3);
189 GNUNET_SCHEDULER_add_now (&end_badly, NULL);
193 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Received %u correct ATS information \n", c3);
195 atsi[0].type = htonl(GNUNET_ATS_NETWORK_TYPE);
196 atsi[0].value = htonl(GNUNET_ATS_NET_WAN);
198 atsi[1].type = htonl(GNUNET_ATS_QUALITY_NET_DELAY);
199 atsi[1].value = htonl(1000);
201 atsi[2].type = htonl(GNUNET_ATS_QUALITY_NET_DISTANCE);
202 atsi[2].value = htonl(50);
204 GNUNET_ATS_address_update (sh, &addr, NULL, atsi, ATS_COUNT);
206 else if (1 == stage_counter)
208 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Received updated callback for peer `%s' with %u information\n",
209 GNUNET_i2s (&addr.peer), ats_count);
211 if ((0 != memcmp (peer, &addr.peer, sizeof (addr.peer))) ||
212 (ats_count < ATS_COUNT))
215 GNUNET_SCHEDULER_add_now (&end_badly, NULL);
219 for (c1 = 0; c1 < ats_count; c1++)
221 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "ATS information [%u] %u : %u \n", c1, ntohl (ats[c1].type), ntohl (ats[c1].value));
222 for (c2 = 0; c2 < ATS_COUNT; c2++)
224 if (ats[c1].type == atsi[c2].type)
226 if (ats[c1].value == atsi[c2].value)
240 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Received only %u correct ATS information \n", c3);
242 GNUNET_SCHEDULER_add_now (&end_badly, NULL);
246 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Received %u correct ATS information, shutdown... \n", c3);
247 GNUNET_SCHEDULER_add_now (&end, NULL);
255 const struct GNUNET_CONFIGURATION_Handle *mycfg,
256 struct GNUNET_TESTING_Peer *peer)
259 cfg = (struct GNUNET_CONFIGURATION_Handle *) mycfg;
260 die_task = GNUNET_SCHEDULER_add_delayed (TIMEOUT, &end_badly, NULL);
262 sh = GNUNET_ATS_scheduling_init (cfg, NULL, NULL);
263 GNUNET_assert (NULL != sh);
267 ph = GNUNET_ATS_performance_init (cfg, &perf_mon_cb, &ret, NULL, NULL);
268 GNUNET_assert (NULL != ph);
271 stage_task = GNUNET_SCHEDULER_add_delayed (SHUTDOWN_CORRECT, &next_stage, NULL);
276 main (int argc, char *argv[])
278 if (0 != GNUNET_TESTING_peer_run ("test_ats_api_performance_monitor",
285 /* end of file test_ats_api_performance_monitor.c */