use NULL value in load_path_suffix to NOT load any files
[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      SPDX-License-Identifier: AGPL3.0-or-later
19
20  */
21
22 /**
23  * @file util/test_crypto_random.c
24  * @brief testcase for crypto_random.c
25  */
26 #include "platform.h"
27 #include "gnunet_util_lib.h"
28
29 static int
30 test (enum GNUNET_CRYPTO_Quality mode)
31 {
32   int buf[1024];
33   unsigned int *b2;
34   int i;
35   unsigned long long n;
36
37   for (i = 0; i < 1024; i++)
38     GNUNET_break (1024 > (buf[i] = GNUNET_CRYPTO_random_u32 (mode, 1024)));
39   for (i = 0; i < 10; i++)
40   {
41     b2 = GNUNET_CRYPTO_random_permute (mode, 1024);
42     if (0 == memcmp (b2, buf, sizeof(buf)))
43     {
44       fprintf (stderr, "%s", "!");
45       GNUNET_free (b2);
46       continue;
47     }
48     GNUNET_free (b2);
49     break;
50   }
51   if (i == 10)
52     return 1;                   /* virtually impossible... */
53
54   for (n = 10; n < 1024LL * 1024LL * 1024LL; n *= 10)
55     GNUNET_break (n > GNUNET_CRYPTO_random_u64 (mode, n));
56   return 0;
57 }
58
59
60 int
61 main (int argc, char *argv[])
62 {
63   GNUNET_log_setup ("test-crypto-random", "WARNING", NULL);
64   if (0 != test (GNUNET_CRYPTO_QUALITY_WEAK))
65     return 1;
66   if (0 != test (GNUNET_CRYPTO_QUALITY_STRONG))
67     return 1;
68
69   return 0;
70 }