Mercurial > hg > octave-nkf > gnulib-hg
changeset 9664:24f06624c1ba
Add sha1 self test.
author | Simon Josefsson <simon@josefsson.org> |
---|---|
date | Thu, 31 Jan 2008 13:59:03 +0100 |
parents | 701f448527a4 |
children | 5ffe75d8d438 |
files | ChangeLog modules/crypto/sha1-tests tests/test-sha1.c |
diffstat | 3 files changed, 64 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- 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.
new file mode 100644 --- /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
new file mode 100644 --- /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; +}