indentation
[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, "ARM stopped\n");
64   }
65 #if START_ARM
66   GNUNET_ARM_disconnect (arm);
67   arm = NULL;
68 #endif
69 }
70
71 static void
72 hostNameResolveCB (void *cls, const struct sockaddr *addr, socklen_t addrlen)
73 {
74   if ((ret == 0) || (ret == 4))
75     return;
76   if (NULL == addr)
77   {
78     GNUNET_log (GNUNET_ERROR_TYPE_ERROR, "Name not resolved!\n");
79 #if START_ARM
80     GNUNET_ARM_stop_service (arm, "arm", TIMEOUT, &arm_stopped, NULL);
81 #endif
82     ret = 3;
83     return;
84   }
85   GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Resolved hostname, now stopping ARM\n");
86   ret = 0;
87 #if START_ARM
88   GNUNET_ARM_stop_service (arm, "arm", TIMEOUT, &arm_stopped, NULL);
89 #endif
90 }
91
92
93 static void
94 arm_notify (void *cls, int success)
95 {
96   if (success != GNUNET_YES)
97   {
98     GNUNET_break (0);
99     ret = 1;
100     return;
101   }
102   GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Trying to resolve our own hostname!\n");
103   /* connect to the resolver service */
104   if (NULL ==
105       GNUNET_RESOLVER_hostname_resolve (AF_UNSPEC, TIMEOUT, &hostNameResolveCB,
106                                         NULL))
107   {
108     GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
109                 "Unable initiate connection to resolver service\n");
110     ret = 2;
111 #if START_ARM
112     GNUNET_ARM_stop_service (arm, "arm", TIMEOUT, &arm_stopped, NULL);
113 #endif
114   }
115 }
116
117
118 static void
119 run (void *cls, char *const *args, const char *cfgfile,
120      const struct GNUNET_CONFIGURATION_Handle *c)
121 {
122   cfg = c;
123 #if START_ARM
124   arm = GNUNET_ARM_connect (cfg, NULL);
125   GNUNET_ARM_start_service (arm, "arm", START_TIMEOUT, &arm_notify, NULL);
126 #else
127   arm_notify (NULL, GNUNET_YES);
128 #endif
129 }
130
131
132 static void
133 check ()
134 {
135   char *const argv[] = {
136     "test-gnunet-service-manager",
137     "-c", "test_arm_api_data.conf",
138 #if VERBOSE
139     "-L", "DEBUG",
140 #endif
141     NULL
142   };
143   struct GNUNET_GETOPT_CommandLineOption options[] = {
144     GNUNET_GETOPT_OPTION_END
145   };
146   GNUNET_assert (GNUNET_OK ==
147                  GNUNET_PROGRAM_run ((sizeof (argv) / sizeof (char *)) - 1,
148                                      argv, "test-gnunet-service-manager",
149                                      "nohelp", options, &run, NULL));
150 }
151
152
153 int
154 main (int argc, char *argv[])
155 {
156   char hostname[GNUNET_OS_get_hostname_max_length () + 1];
157
158   if (0 != gethostname (hostname, sizeof (hostname) - 1))
159   {
160     GNUNET_log_strerror (GNUNET_ERROR_TYPE_ERROR | GNUNET_ERROR_TYPE_BULK,
161                          "gethostname");
162     fprintf (stderr,
163              "Failed to determine my own hostname, testcase not run.\n");
164     return 0;
165   }
166   if (NULL == gethostbyname (hostname))
167   {
168     fprintf (stderr, "Failed to resolve my hostname `%s', testcase not run.\n",
169              hostname);
170     return 0;
171   }
172
173   GNUNET_log_setup ("test-gnunet-service-manager",
174 #if VERBOSE
175                     "DEBUG",
176 #else
177                     "WARNING",
178 #endif
179                     NULL);
180   check ();
181   return ret;
182 }