From e50ec111d37d28a3eb0db2306242252e6f0ac1bd Mon Sep 17 00:00:00 2001
From: Simon Josefsson <simon@josefsson.org>
Date: Thu, 31 Jan 2008 13:59:03 +0100
Subject: [PATCH] Add sha1 self test.

---
 ChangeLog                 |  6 +++++
 modules/crypto/sha1-tests | 10 ++++++++
 tests/test-sha1.c         | 48 +++++++++++++++++++++++++++++++++++++++
 3 files changed, 64 insertions(+)
 create mode 100644 modules/crypto/sha1-tests
 create mode 100644 tests/test-sha1.c

diff --git a/ChangeLog b/ChangeLog
index 77fe4f5e56..23a75e15b2 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+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.
diff --git a/modules/crypto/sha1-tests b/modules/crypto/sha1-tests
new file mode 100644
index 0000000000..6da04d6cbc
--- /dev/null
+++ b/modules/crypto/sha1-tests
@@ -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
index 0000000000..0cfb30947e
--- /dev/null
+++ b/tests/test-sha1.c
@@ -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;
+}
-- 
2.30.2