initialize response_code, always
[oweals/gnunet.git] / src / nat / test_nat_test.c
1 /*
2      This file is part of GNUnet.
3      Copyright (C) 2009, 2011, 2014 GNUnet e.V.
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., 51 Franklin Street, Fifth Floor,
18      Boston, MA 02110-1301, USA.
19 */
20 /**
21  * @file nat/test_nat_test.c
22  * @brief Testcase for NAT testing functions
23  * @author Christian Grothoff
24  */
25 #include "platform.h"
26 #include "gnunet_util_lib.h"
27 #include "gnunet_nat_lib.h"
28
29 /**
30  * Time to wait before stopping NAT test, in seconds
31  */
32 #define TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 15)
33
34
35 static int ret = 1;
36
37 static struct GNUNET_NAT_Test *tst;
38
39 static struct GNUNET_SCHEDULER_Task * tsk;
40
41
42 static void
43 report_result (void *cls,
44                 enum GNUNET_NAT_StatusCode aret)
45 {
46   if (GNUNET_NAT_ERROR_TIMEOUT == aret)
47     fprintf (stderr,
48              "NAT test timed out\n");
49   else if (GNUNET_NAT_ERROR_SUCCESS != aret)
50     fprintf (stderr,
51              "NAT test reported error %d\n", aret);
52   else
53     ret = 0;
54   GNUNET_NAT_test_stop (tst);
55   tst = NULL;
56   GNUNET_SCHEDULER_cancel (tsk);
57   tsk = NULL;
58 }
59
60
61 static void
62 failed_timeout (void *cls)
63 {
64   tsk = NULL;
65   fprintf (stderr,
66            "NAT test failed to terminate on timeout\n");
67   ret = 2;
68   GNUNET_NAT_test_stop (tst);
69   tst = NULL;
70 }
71
72
73 /**
74  * Main function run with scheduler.
75  */
76 static void
77 run (void *cls, char *const *args, const char *cfgfile,
78      const struct GNUNET_CONFIGURATION_Handle *cfg)
79 {
80   tst =
81       GNUNET_NAT_test_start (cfg, GNUNET_YES, 1285, 1285, TIMEOUT,
82                              &report_result,
83                              NULL);
84   tsk = GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_relative_multiply (TIMEOUT,
85                                                                      2),
86                                       &failed_timeout,
87                                       NULL);
88
89 }
90
91
92 int
93 main (int argc, char *const argv[])
94 {
95   struct GNUNET_GETOPT_CommandLineOption options[] = {
96     GNUNET_GETOPT_OPTION_END
97   };
98   struct GNUNET_OS_Process *gns;
99   int nat_res;
100   char *const argv_prog[] = {
101     "test-nat-test",
102     "-c",
103     "test_nat_test_data.conf",
104     NULL
105   };
106
107   GNUNET_log_setup ("test-nat-test",
108                     "WARNING",
109                     NULL);
110
111   nat_res = GNUNET_OS_check_helper_binary ("gnunet-nat-server", GNUNET_NO, NULL);
112   if (GNUNET_SYSERR == nat_res)
113   {
114     GNUNET_log (GNUNET_ERROR_TYPE_WARNING,
115                 "Cannot run NAT test: `%s' file not found\n",
116                 "gnunet-nat-server");
117     return 0;
118   }
119
120   gns = GNUNET_OS_start_process (GNUNET_YES,
121                                  GNUNET_OS_INHERIT_STD_OUT_AND_ERR,
122                                  NULL, NULL, NULL,
123                                  "gnunet-nat-server",
124                                  "gnunet-nat-server",
125                                  "-c", "test_nat_test_data.conf",
126                                  "12345", NULL);
127   GNUNET_assert (NULL != gns);
128   GNUNET_PROGRAM_run (3, argv_prog,
129                       "test-nat-test", "nohelp",
130                       options, &run,
131                       NULL);
132   GNUNET_break (0 == GNUNET_OS_process_kill (gns, GNUNET_TERM_SIG));
133   GNUNET_break (GNUNET_OK == GNUNET_OS_process_wait (gns));
134   GNUNET_OS_process_destroy (gns);
135   if (0 != ret)
136     fprintf (stderr,
137              "NAT test failed to report success\n");
138   return ret;
139 }
140
141 /* end of test_nat_test.c */