Add sha1 self test.
authorSimon Josefsson <simon@josefsson.org>
Thu, 31 Jan 2008 12:59:03 +0000 (13:59 +0100)
committerSimon Josefsson <simon@josefsson.org>
Thu, 31 Jan 2008 12:59:03 +0000 (13:59 +0100)
ChangeLog
modules/crypto/sha1-tests [new file with mode: 0644]
tests/test-sha1.c [new file with mode: 0644]

index 77fe4f5..23a75e1 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,11 @@
 2008-01-31  Simon Josefsson  <simon@josefsson.org>
 
+       * tests/test-sha1.c: New file, based on test-md5.c.
+
+       * modules/crypto/sha1-tests: New file.
+
+2008-01-31  Simon Josefsson  <simon@josefsson.org>
+
        * lib/sha1.h (SHA1_DIGEST_SIZE): Add.
 
 2008-01-31  Jim Meyering  <meyering@redhat.com>
diff --git a/modules/crypto/sha1-tests b/modules/crypto/sha1-tests
new file mode 100644 (file)
index 0000000..6da04d6
--- /dev/null
@@ -0,0 +1,10 @@
+Files:
+tests/test-sha1.c
+
+Depends-on:
+
+configure.ac:
+
+Makefile.am:
+TESTS += test-sha1
+check_PROGRAMS += test-sha1
diff --git a/tests/test-sha1.c b/tests/test-sha1.c
new file mode 100644 (file)
index 0000000..0cfb309
--- /dev/null
@@ -0,0 +1,48 @@
+/*
+ * Copyright (C) 2005, 2008 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 3 of the License, 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, see <http://www.gnu.org/licenses/>.  */
+
+#include <config.h>
+
+#include <stdio.h>
+#include <string.h>
+
+#include "sha1.h"
+
+int
+main (int argc, char *argv[])
+{
+  char *in1 = "abcdefgh";
+  char *out1 = "\x42\x5a\xf1\x2a\x07\x43\x50\x2b"
+    "\x32\x2e\x93\xa0\x15\xbc\xf8\x68\xe3\x24\xd5\x6a";
+  char buf[SHA1_DIGEST_SIZE];
+
+  if (memcmp (sha1_buffer (in1, strlen (in1), buf),
+             out1, SHA1_DIGEST_SIZE) != 0)
+    {
+      size_t i;
+      printf ("expected:\n");
+      for (i = 0; i < SHA1_DIGEST_SIZE; i++)
+       printf ("%02x ", out1[i] & 0xFF);
+      printf ("\ncomputed:\n");
+      for (i = 0; i < SHA1_DIGEST_SIZE; i++)
+       printf ("%02x ", buf[i] & 0xFF);
+      printf ("\n");
+      return 1;
+    }
+
+  return 0;
+}