6393
|
1 /* |
|
2 * Copyright (C) 2005 Free Software Foundation |
|
3 * Written by Simon Josefsson |
|
4 * |
|
5 * This program is free software; you can redistribute it and/or modify |
|
6 * it under the terms of the GNU General Public License as published by |
|
7 * the Free Software Foundation; either version 2, or (at your option) |
|
8 * any later version. |
|
9 * |
|
10 * This program is distributed in the hope that it will be useful, |
|
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
13 * GNU General Public License for more details. |
|
14 * |
|
15 * You should have received a copy of the GNU General Public License |
|
16 * along with this program; if not, write to the Free Software |
|
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA |
|
18 * 02110-1301, USA. */ |
|
19 |
|
20 /* Written by Simon Josefsson. */ |
|
21 |
|
22 #ifdef HAVE_CONFIG_H |
|
23 # include <config.h> |
|
24 #endif |
|
25 |
|
26 #include <stdio.h> |
|
27 #include <string.h> |
|
28 |
|
29 #include "md4.h" |
|
30 |
|
31 int |
|
32 main (int argc, char *argv[]) |
|
33 { |
|
34 const char *in1 = "abc"; |
|
35 const char *out1 = |
|
36 "\xa4\x48\x01\x7a\xaf\x21\xd8\x52\x5f\xc1\x0a\xe8\x7a\xa6\x72\x9d"; |
|
37 const char *in2 = "abcdefghijklmnopqrstuvwxyz"; |
|
38 const char *out2 = |
|
39 "\xd7\x9e\x1c\x30\x8a\xa5\xbb\xcd\xee\xa8\xed\x63\xdf\x41\x2d\xa9"; |
|
40 char buf[MD4_DIGEST_SIZE]; |
|
41 |
|
42 if (memcmp (md4_buffer (in1, strlen (in1), buf), out1, MD4_DIGEST_SIZE) != |
|
43 0) |
|
44 { |
|
45 size_t i; |
|
46 printf ("expected:\n"); |
|
47 for (i = 0; i < MD4_DIGEST_SIZE; i++) |
|
48 printf ("%02x ", out1[i] & 0xFF); |
|
49 printf ("\ncomputed:\n"); |
|
50 for (i = 0; i < MD4_DIGEST_SIZE; i++) |
|
51 printf ("%02x ", buf[i] & 0xFF); |
|
52 printf ("\n"); |
|
53 return 1; |
|
54 } |
|
55 |
|
56 if (memcmp (md4_buffer (in2, strlen (in2), buf), out2, MD4_DIGEST_SIZE) != |
|
57 0) |
|
58 { |
|
59 size_t i; |
|
60 printf ("expected:\n"); |
|
61 for (i = 0; i < MD4_DIGEST_SIZE; i++) |
|
62 printf ("%02x ", out2[i] & 0xFF); |
|
63 printf ("\ncomputed:\n"); |
|
64 for (i = 0; i < MD4_DIGEST_SIZE; i++) |
|
65 printf ("%02x ", buf[i] & 0xFF); |
|
66 printf ("\n"); |
|
67 return 1; |
|
68 } |
|
69 |
|
70 return 0; |
|
71 } |