changeset 6373:45937732b5dd

2005-10-13 Simon Josefsson <jas@extundo.com> * modules/gc-hmac-md5-tests: New file. * tests/test-gc-hmac-sha1.c: New file.
author Simon Josefsson <simon@josefsson.org>
date Thu, 13 Oct 2005 08:12:04 +0000
parents f94a5f07ce6c
children 7398c10d65f5
files ChangeLog modules/gc-hmac-sha1-tests tests/test-gc-hmac-sha1.c
diffstat 3 files changed, 89 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
 2005-10-13  Simon Josefsson  <jas@extundo.com>
 
+	* modules/gc-hmac-md5-tests: New file.
+
+	* tests/test-gc-hmac-sha1.c: New file.
+
 	* tests/test-gc.c (main): Remove MD5 and HMAC-MD5 tests.
 
 	* modules/gc-hmac-md5-tests: New file.
new file mode 100644
--- /dev/null
+++ b/modules/gc-hmac-sha1-tests
@@ -0,0 +1,11 @@
+Files:
+tests/test-gc-hmac-sha1.c
+
+Depends-on:
+
+configure.ac:
+
+Makefile.am:
+TESTS += test-gc-hmac-sha1
+noinst_PROGRAMS += test-gc-hmac-sha1
+test_gc_hmac_sha1_SOURCES = test-gc-hmac-sha1.c
new file mode 100644
--- /dev/null
+++ b/tests/test-gc-hmac-sha1.c
@@ -0,0 +1,74 @@
+/*
+ * Copyright (C) 2005 Free Software Foundation
+ * Written by Simon Josefsson
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301, USA.  */
+
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#include <stdio.h>
+#include <string.h>
+#include "gc.h"
+
+int
+main (int argc, char *argv[])
+{
+  Gc_rc rc;
+
+  rc = gc_init ();
+  if (rc != GC_OK)
+    {
+      printf ("gc_init() failed\n");
+      return 1;
+    }
+
+  {
+    char *key =
+      "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b";
+    size_t key_len = 16;
+    char *data = "Hi There";
+    size_t data_len = 8;
+    char *digest =
+      "\x67\x5b\x0b\x3a\x1b\x4d\xdf\x4e\x12\x48"
+      "\x72\xda\x6c\x2f\x63\x2b\xfe\xd9\x57\xe9";
+    char out[GC_SHA1_DIGEST_SIZE];
+
+    if (gc_hmac_sha1 (key, key_len, data, data_len, out) != 0)
+      {
+	printf ("call failure\n");
+	return 1;
+      }
+
+    if (memcmp (digest, out, GC_SHA1_DIGEST_SIZE) != 0)
+      {
+	size_t i;
+	printf ("hash 1 missmatch. expected:\n");
+	for (i = 0; i < 16; i++)
+	  printf ("%02x ", digest[i] & 0xFF);
+	printf ("\ncomputed:\n");
+	for (i = 0; i < 16; i++)
+	  printf ("%02x ", out[i] & 0xFF);
+	printf ("\n");
+	return 1;
+      }
+  }
+
+  gc_done ();
+
+  return 0;
+}