Mercurial > hg > octave-shane > gnulib-hg
annotate tests/test-gc-hmac-sha256.c @ 17632:86af85d364e1 default tip
unistd: port readlink to Mac OS X 10.3.9
* lib/unistd.in.h (_GL_INCLUDING_UNISTD_H): New macro, to work
around self-include problem in Mac OS X 10.3.9 when combined with
readlink module. Problem reported by Klaus Zietler in
<http://bugs.gnu.org/16825>.
author | Paul Eggert <eggert@penguin.cs.ucla.edu> |
---|---|
date | Tue, 25 Feb 2014 11:16:27 -0800 (2014-02-25) |
parents | 344018b6e5d7 |
children |
rev | line source |
---|---|
17482
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
1 /* |
17587 | 2 * Copyright (C) 2005, 2010-2014 Free Software Foundation, Inc. |
17482
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
3 * Written by Simon Josefsson |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
4 * |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
5 * This program is free software; you can redistribute it and/or modify |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
6 * it under the terms of the GNU General Public License as published by |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
7 * the Free Software Foundation; either version 3, or (at your option) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
8 * any later version. |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
9 * |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
10 * This program is distributed in the hope that it will be useful, |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
13 * GNU General Public License for more details. |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
14 * |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
15 * You should have received a copy of the GNU General Public License |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
16 * along with this program; if not, see <http://www.gnu.org/licenses/>. */ |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
17 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
18 #include <config.h> |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
19 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
20 #include <stdio.h> |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
21 #include <string.h> |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
22 #include "gc.h" |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
23 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
24 int |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
25 main (int argc, char *argv[]) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
26 { |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
27 Gc_rc rc; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
28 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
29 rc = gc_init (); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
30 if (rc != GC_OK) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
31 { |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
32 printf ("gc_init() failed\n"); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
33 return 1; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
34 } |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
35 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
36 { |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
37 char *key = |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
38 "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b"; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
39 size_t key_len = 20; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
40 char *data = "Hi There"; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
41 size_t data_len = 8; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
42 char *digest = |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
43 "\xb0\x34\x4c\x61\xd8\xdb\x38\x53\x5c\xa8\xaf\xce\xaf\x0b\xf1\x2b\x88\x1d\xc2\x00\xc9\x83\x3d\xa7\x26\xe9\x37\x6c\x2e\x32\xcf\xf7"; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
44 char out[GC_SHA256_DIGEST_SIZE]; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
45 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
46 if (gc_hmac_sha256 (key, key_len, data, data_len, out) != 0) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
47 { |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
48 printf ("call failure\n"); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
49 return 1; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
50 } |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
51 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
52 if (memcmp (digest, out, GC_SHA256_DIGEST_SIZE) != 0) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
53 { |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
54 size_t i; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
55 printf ("hash 1 mismatch. expected:\n"); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
56 for (i = 0; i < GC_SHA256_DIGEST_SIZE; i++) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
57 printf ("%02x ", digest[i] & 0xFF); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
58 printf ("\ncomputed:\n"); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
59 for (i = 0; i < GC_SHA256_DIGEST_SIZE; i++) |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
60 printf ("%02x ", out[i] & 0xFF); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
61 printf ("\n"); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
62 return 1; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
63 } |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
64 } |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
65 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
66 gc_done (); |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
67 |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
68 return 0; |
b1c70949ba69
gc: support HMAC-SHA256 and HMAC-SHA512.
Simon Josefsson <simon@josefsson.org>
parents:
diff
changeset
|
69 } |