handle nat_register fail
[oweals/gnunet.git] / src / nat / test_nat_test.c
1 /*
2      This file is part of GNUnet.
3      (C) 2009, 2011 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 /**
22  * Testcase for the NAT testing code.
23  *
24  * @file nat/test_nat_test.c
25  * @brief Testcase for NAT testing functions
26  * @author Christian Grothoff
27  */
28 #include "platform.h"
29 #include "gnunet_util_lib.h"
30 #include "gnunet_nat_lib.h"
31
32 /**
33  * Time to wait before stopping NAT test, in seconds
34  */
35 #define TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 15)
36
37
38 static int ret = 1;
39
40 static struct GNUNET_NAT_Test *tst;
41
42 static GNUNET_SCHEDULER_TaskIdentifier end;
43
44 static void
45 end_test (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
46 {
47   GNUNET_NAT_test_stop (tst);
48 }
49
50
51 static void
52 report_success (void *cls,
53                 int success,
54                 const char *emsg)
55 {
56   GNUNET_assert (GNUNET_OK == success);
57   ret = 0;
58   GNUNET_SCHEDULER_cancel (end);
59   end = GNUNET_SCHEDULER_add_now (&end_test, NULL);
60 }
61
62
63 /**
64  * Main function run with scheduler.
65  */
66 static void
67 run (void *cls, char *const *args, const char *cfgfile,
68      const struct GNUNET_CONFIGURATION_Handle *cfg)
69 {
70   tst =
71       GNUNET_NAT_test_start (cfg, GNUNET_YES, 1285, 1285,
72                              &report_success,
73                              NULL);
74   if (NULL == tst)
75     return;
76   end = GNUNET_SCHEDULER_add_delayed (TIMEOUT, &end_test, NULL);
77 }
78
79
80 int
81 main (int argc, char *const argv[])
82 {
83   struct GNUNET_GETOPT_CommandLineOption options[] = {
84     GNUNET_GETOPT_OPTION_END
85   };
86   struct GNUNET_OS_Process *gns;
87   int nat_res;
88   char *const argv_prog[] = {
89     "test-nat-test",
90     "-c",
91     "test_nat_test_data.conf",
92     NULL
93   };
94
95   GNUNET_log_setup ("test-nat-test",
96                     "WARNING",
97                     NULL);
98
99   nat_res = GNUNET_OS_check_helper_binary ("gnunet-nat-server", GNUNET_NO, NULL);
100   if (GNUNET_SYSERR == nat_res)
101   {
102     GNUNET_log (GNUNET_ERROR_TYPE_WARNING,
103                 "Cannot run NAT test: `%s' file not found\n",
104                 "gnunet-nat-server");
105     return 0;
106   }
107
108   gns = GNUNET_OS_start_process (GNUNET_YES,
109                                  GNUNET_OS_INHERIT_STD_OUT_AND_ERR,
110                                  NULL, NULL, NULL,
111                                  "gnunet-nat-server",
112                                  "gnunet-nat-server",
113                                  "-c", "test_nat_test_data.conf",
114                                  "12345", NULL);
115   GNUNET_assert (NULL != gns);
116   GNUNET_PROGRAM_run (3, argv_prog, "test-nat-test", "nohelp", options, &run,
117                       NULL);
118   GNUNET_break (0 == GNUNET_OS_process_kill (gns, GNUNET_TERM_SIG));
119   GNUNET_break (GNUNET_OK == GNUNET_OS_process_wait (gns));
120   GNUNET_OS_process_destroy (gns);
121   if (0 != ret)
122     fprintf (stderr,
123              "NAT test failed to report success\n");
124   return ret;
125 }
126
127 /* end of test_nat_test.c */