fix resolver api
[oweals/gnunet.git] / src / arm / test_gnunet_service_manager.c
1 /*
2      This file is part of GNUnet.
3      (C) 2009 Christian Grothoff (and other contributing authors)
4
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.
9
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.
14
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.
19 */
20 /**
21  * @file arm/test_gnunet_service_manager.c (A mockup testcase, not functionally complete)
22  * @brief testcase for gnunet-service-manager.c
23  */
24
25 #include "platform.h"
26 #include "gnunet_arm_service.h"
27 #include "gnunet_resolver_service.h"
28 #include "gnunet_os_lib.h"
29 #include "gnunet_program_lib.h"
30
31 /**
32  * Timeout for starting services, very short because of the strange way start works
33  * (by checking if running before starting, so really this time is always waited on
34  * startup (annoying)).
35  */
36 #define START_TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_MILLISECONDS, 50)
37
38 #define TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 10)
39
40 #define START_ARM GNUNET_YES
41
42 #define VERBOSE GNUNET_NO
43
44 static int ret = 1;
45
46
47 static const struct GNUNET_CONFIGURATION_Handle *cfg;
48
49 #if START_ARM
50 static struct GNUNET_ARM_Handle *arm;
51 #endif
52
53 static void
54 arm_stopped (void *cls, int success)
55 {
56   if (success != GNUNET_NO)       
57     {
58       GNUNET_break (0);
59       ret = 4;
60     }
61   else
62     {
63       GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, 
64                   "ARM stopped\n");
65     }
66 #if START_ARM
67   GNUNET_ARM_disconnect (arm);
68   arm = NULL;
69 #endif
70 }
71
72 static void 
73 hostNameResolveCB(void *cls, 
74                   const struct sockaddr *addr, 
75                   socklen_t addrlen)
76 {
77   if ( (ret == 0) || (ret == 4) )
78     return;
79   if (NULL == addr)
80     {
81       GNUNET_log (GNUNET_ERROR_TYPE_ERROR, 
82                   "Name not resolved!\n");
83 #if START_ARM
84       GNUNET_ARM_stop_service (arm, "arm", TIMEOUT, &arm_stopped, NULL);
85 #endif
86       ret = 3;
87       return;
88     }  
89   GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, 
90               "Resolved hostname, now stopping ARM\n");
91   ret = 0;
92 #if START_ARM
93   GNUNET_ARM_stop_service (arm, "arm", TIMEOUT, &arm_stopped, NULL);
94 #endif
95 }
96
97
98 static void
99 arm_notify (void *cls, int success)
100 {
101   if (success != GNUNET_YES)
102     {
103       GNUNET_break (0);
104       ret = 1;
105       return;
106     }
107   GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, 
108               "Trying to resolve our own hostname!\n");
109   /* connect to the resolver service */
110   if (NULL == GNUNET_RESOLVER_hostname_resolve (AF_UNSPEC,
111                                                 TIMEOUT,
112                                                 &hostNameResolveCB,
113                                                 NULL))
114     {
115       GNUNET_log (GNUNET_ERROR_TYPE_ERROR, 
116                   "Unable initiate connection to resolver service\n");
117       ret = 2;
118 #if START_ARM
119       GNUNET_ARM_stop_service (arm, "arm", TIMEOUT, &arm_stopped, NULL);
120 #endif
121     }
122 }
123
124
125 static void
126 run(void *cls,
127     char * const *args,
128     const char *cfgfile, 
129     const struct GNUNET_CONFIGURATION_Handle *c)
130 {
131   cfg = c;
132 #if START_ARM
133   arm = GNUNET_ARM_connect (cfg, NULL);
134   GNUNET_ARM_start_service (arm, "arm", START_TIMEOUT, &arm_notify, NULL);
135 #else
136   arm_notify (NULL, GNUNET_YES);
137 #endif
138 }
139
140
141 static void
142 check()
143 {
144   char *const argv[] = {
145     "test-gnunet-service-manager",
146     "-c", "test_arm_api_data.conf",
147 #if VERBOSE
148     "-L", "DEBUG",
149 #endif
150     NULL
151   };
152   struct GNUNET_GETOPT_CommandLineOption options[] = {
153     GNUNET_GETOPT_OPTION_END
154   };
155   GNUNET_assert (GNUNET_OK ==
156                  GNUNET_PROGRAM_run ((sizeof (argv) / sizeof (char *)) - 1,
157                                      argv,
158                                      "test-gnunet-service-manager",
159                                      "nohelp", options, &run, NULL));
160 }
161
162
163 int
164 main (int argc, char *argv[])
165 {
166   char hostname[GNUNET_OS_get_hostname_max_length() + 1];
167
168   if (0 != gethostname (hostname, sizeof (hostname) - 1))
169     {
170       GNUNET_log_strerror (GNUNET_ERROR_TYPE_ERROR |
171                            GNUNET_ERROR_TYPE_BULK, "gethostname");
172       fprintf (stderr, "Failed to determine my own hostname, testcase not run.\n");
173       return 0;
174     }
175   if (NULL == gethostbyname (hostname))
176     {
177       fprintf (stderr, "Failed to resolve my hostname `%s', testcase not run.\n",
178                hostname);
179       return 0;
180     }
181
182   GNUNET_log_setup("test-gnunet-service-manager",
183 #if VERBOSE
184                    "DEBUG",
185 #else
186                    "WARNING",
187 #endif
188                    NULL);
189   check();
190   return ret;
191 }