tiger instead. Also kill bogus NULL pointer handling in both algorithms: passing null pointers as buffers (when len != 0) or context is a serious programming error and should result in a segfault. Bump version to 20060826. OK agc@
96 lines
4 KiB
Bash
96 lines
4 KiB
Bash
#! /bin/sh
|
|
#
|
|
# From
|
|
# $NetBSD: regress.sh,v 1.4 2006/08/29 13:43:11 joerg Exp $
|
|
|
|
# one can do, for example to test with openssl:
|
|
# DIGESTDIR=/path/to DIGESTCMD=openssl sh regress.sh
|
|
DIGESTDIR=${DIGESTDIR:-.}
|
|
DIGESTCMD=${DIGESTCMD:-digest}
|
|
DIGEST=${DIGESTDIR}/${DIGESTCMD}
|
|
|
|
# grabbed from GNU autoconf
|
|
case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in
|
|
*c*,-n*) ECHO_N= ECHO_C='
|
|
' ;;
|
|
*c*,* ) ECHO_N=-n ECHO_C= ;;
|
|
*) ECHO_N= ECHO_C='\c' ;;
|
|
esac
|
|
|
|
|
|
cat > expected1 << EOF
|
|
ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad
|
|
cb00753f45a35e8bb5a03d699ac65007272c32ab0eded1631a8b605a43ff5bed8086072ba1e7cc2358baeca134c825a7
|
|
ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f
|
|
EOF
|
|
echo $ECHO_N "abc$ECHO_C" | ${DIGEST} sha256 > output1
|
|
echo $ECHO_N "abc$ECHO_C" | ${DIGEST} sha384 >> output1
|
|
echo $ECHO_N "abc$ECHO_C" | ${DIGEST} sha512 >> output1
|
|
diff expected1 output1 || echo "*** WARNING: output differs in test 1 (sha256, sha384, sha512) ***"
|
|
|
|
rm -f expected1 output1
|
|
|
|
cat > expected2 << EOF
|
|
248d6a61d20638b8e5c026930c3e6039a33ce45964ff2167f6ecedd419db06c1
|
|
3391fdddfc8dc7393707a65b1b4709397cf8b1d162af05abfe8f450de5f36bc6b0455a8520bc4e6f5fe95b1fe3c8452b
|
|
204a8fc6dda82f0a0ced7beb8e08a41657c16ef468b228a8279be331a703c33596fd15c13b1b07f9aa1d3bea57789ca031ad85c7a71dd70354ec631238ca3445
|
|
EOF
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} sha256 > output2
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} sha384 >> output2
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} sha512 >> output2
|
|
diff expected2 output2 || echo "*** WARNING: output differs in test 2 (sha256, sha384, sha512) ***"
|
|
|
|
rm -f expected2 output2
|
|
|
|
|
|
cat > expected3 << EOF
|
|
8215ef0796a20bcaaae116d3876c664a
|
|
EOF
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} md5 > output3
|
|
diff expected3 output3 || echo "*** WARNING: output differs in test 3 (md5) ***"
|
|
|
|
rm -f expected3 output3
|
|
|
|
cat > expected4 << EOF
|
|
12a053384a9c0c88e405a06c27dcf49ada62eb2b
|
|
EOF
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} rmd160 > output4
|
|
diff expected4 output4 || echo "*** WARNING: output differs in test 4 (rmd160) ***"
|
|
|
|
rm -f expected4 output4
|
|
|
|
cat > expected5 << EOF
|
|
84983e441c3bd26ebaae4aa1f95129e5e54670f1
|
|
EOF
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} sha1 > output5
|
|
diff expected5 output5 || echo "*** WARNING: output differs in test 5 (sha1) ***"
|
|
|
|
rm -f expected5 output5
|
|
|
|
cat > expected6 << EOF
|
|
f258c1e88414ab2a527ab541ffc5b8bf935f7b951c132951
|
|
f2589c9ba1f97b0fc30a4fe8f70d61b78ef7537b1e631ca7
|
|
3d9aeb03d1bd1a6357b2774dfd6d5b24dd68151d503974fc
|
|
EOF
|
|
echo $ECHO_N "abc$ECHO_C" | ${DIGEST} tiger > output6
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} tiger >> output6
|
|
echo $ECHO_N "Tiger - A Fast New Hash Function, by Ross Anderson and Eli Biham, proceedings of Fast Software Encryption 3, Cambridge, 1996.$ECHO_C" | ${DIGEST} tiger >> output6
|
|
diff expected6 output6 || echo "*** WARNING: output differs in test 6 (tiger) ***"
|
|
|
|
rm -f expected6 output6
|
|
|
|
cat > expected7 << EOF
|
|
4e2448a4c6f486bb16b6562c73b4020bf3043e3a731bce721ae1b303d97e6d4c7181eebdb6c57e277d0e34957114cbd6c797fc9d95d8b582d225292076d4eef5
|
|
526b2394d85683e24b29acd0fd37f7d5027f61366a1407262dc2a6a345d9e240c017c1833db1e6db6a46bd444b0c69520c856e7c6e9c366d150a7da3aeb160d1
|
|
b37cde686c51c3970a1fb22959b6e5fe4bef90a5262e63126fabaddd0d0969783e1969459078fe7fcf7fdaa9ffbf6db80963296596169274c4a236bafeb95e7e
|
|
EOF
|
|
echo $ECHO_N "abc$ECHO_C" | ${DIGEST} whirlpool > output7
|
|
echo $ECHO_N "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq$ECHO_C" | ${DIGEST} whirlpool >> output7
|
|
echo $ECHO_N "Whirlpool - The Whirlpool hashing function.$ECHO_C" | ${DIGEST} whirlpool >> output7
|
|
diff expected7 output7 || echo "*** WARNING: output differs in test 7 (whirlpool) ***"
|
|
|
|
rm -f expected7 output7
|
|
|
|
|
|
|
|
exit 0
|