2005-10-13 Simon Josefsson <jas@extundo.com>
authorSimon Josefsson <simon@josefsson.org>
Thu, 13 Oct 2005 08:12:04 +0000 (08:12 +0000)
committerSimon Josefsson <simon@josefsson.org>
Thu, 13 Oct 2005 08:12:04 +0000 (08:12 +0000)
* modules/gc-hmac-md5-tests: New file.

* tests/test-gc-hmac-sha1.c: New file.

ChangeLog
modules/gc-hmac-sha1-tests [new file with mode: 0644]
tests/test-gc-hmac-sha1.c [new file with mode: 0644]

index 53919bf..079990c 100644 (file)
--- 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.
diff --git a/modules/gc-hmac-sha1-tests b/modules/gc-hmac-sha1-tests
new file mode 100644 (file)
index 0000000..9e7e18e
--- /dev/null
@@ -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
diff --git a/tests/test-gc-hmac-sha1.c b/tests/test-gc-hmac-sha1.c
new file mode 100644 (file)
index 0000000..bedb961
--- /dev/null
@@ -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;
+}