f5e0a2731593f0f21da50a62318e8b4d36b3c75a
[oweals/gnunet.git] / src / util / test_crypto_random.c
1 /*
2      This file is part of GNUnet.
3      Copyright (C) 2009 GNUnet e.V.
4
5      GNUnet is free software: you can redistribute it and/or modify it
6      under the terms of the GNU Affero General Public License as published
7      by the Free Software Foundation, either version 3 of the License,
8      or (at your 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      Affero General Public License for more details.
14     
15      You should have received a copy of the GNU Affero General Public License
16      along with this program.  If not, see <http://www.gnu.org/licenses/>.
17
18 */
19
20 /**
21  * @file util/test_crypto_random.c
22  * @brief testcase for crypto_random.c
23  */
24 #include "platform.h"
25 #include "gnunet_util_lib.h"
26
27 static int
28 test (enum GNUNET_CRYPTO_Quality mode)
29 {
30
31   int buf[1024];
32   unsigned int *b2;
33   int i;
34   unsigned long long n;
35
36   for (i = 0; i < 1024; i++)
37     GNUNET_break (1024 > (buf[i] = GNUNET_CRYPTO_random_u32 (mode, 1024)));
38   for (i = 0; i < 10; i++)
39   {
40     b2 = GNUNET_CRYPTO_random_permute (mode, 1024);
41     if (0 == memcmp (b2, buf, sizeof (buf)))
42     {
43       FPRINTF (stderr, "%s",  "!");
44       GNUNET_free (b2);
45       continue;
46     }
47     GNUNET_free (b2);
48     break;
49   }
50   if (i == 10)
51     return 1;                   /* virtually impossible... */
52
53   for (n = 10; n < 1024LL * 1024LL * 1024LL; n *= 10)
54     GNUNET_break (n > GNUNET_CRYPTO_random_u64 (mode, n));
55   return 0;
56 }
57
58 int
59 main (int argc, char *argv[])
60 {
61   GNUNET_log_setup ("test-crypto-random", "WARNING", NULL);
62   if (0 != test (GNUNET_CRYPTO_QUALITY_WEAK))
63     return 1;
64   if (0 != test (GNUNET_CRYPTO_QUALITY_STRONG))
65     return 1;
66
67   return 0;
68 }