diff options
author | David Benjamin <davidben@chromium.org> | 2014-11-05 05:23:33 +0300 |
---|---|---|
committer | Adam Langley <agl@google.com> | 2014-11-06 04:49:03 +0300 |
commit | 9da9035b50e8eb149a9cb25cc6bf6a1690d61e07 (patch) | |
tree | 30092fcccf0663a799e117805af6c7b8b2a7fda9 /crypto/md5 | |
parent | 23586e1e0ef247d5ac89ef075114129326cd01a5 (diff) |
Add digest_test with tests for all existing EVP_MDs.
Remove the existing md5_test and sha1_test. They now are all covered by
digest_test. For good measure, test the one-shot functions too.
Change-Id: I8e144cc563fb8817144e26cbd2e10c15642464ba
Reviewed-on: https://boringssl-review.googlesource.com/2211
Reviewed-by: Adam Langley <agl@google.com>
Diffstat (limited to 'crypto/md5')
-rw-r--r-- | crypto/md5/CMakeLists.txt | 8 | ||||
-rw-r--r-- | crypto/md5/md5_test.c | 103 |
2 files changed, 0 insertions, 111 deletions
diff --git a/crypto/md5/CMakeLists.txt b/crypto/md5/CMakeLists.txt index ce2f8dc1..256588c7 100644 --- a/crypto/md5/CMakeLists.txt +++ b/crypto/md5/CMakeLists.txt @@ -28,11 +28,3 @@ add_library( perlasm(md5-x86_64.${ASM_EXT} asm/md5-x86_64.pl) perlasm(md5-586.${ASM_EXT} asm/md5-586.pl) - -add_executable( - md5_test - - md5_test.c -) - -target_link_libraries(md5_test crypto) diff --git a/crypto/md5/md5_test.c b/crypto/md5/md5_test.c deleted file mode 100644 index fd243414..00000000 --- a/crypto/md5/md5_test.c +++ /dev/null @@ -1,103 +0,0 @@ -/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) * All rights reserved. - * - * This package is an SSL implementation written - * by Eric Young (eay@cryptsoft.com). - * The implementation was written so as to conform with Netscapes SSL. - * - * This library is free for commercial and non-commercial use as long as - * the following conditions are aheared to. The following conditions - * apply to all code found in this distribution, be it the RC4, RSA, - * lhash, DES, etc., code; not just the SSL code. The SSL documentation - * included with this distribution is covered by the same copyright terms - * except that the holder is Tim Hudson (tjh@cryptsoft.com). - * - * Copyright remains Eric Young's, and as such any Copyright notices in - * the code are not to be removed. - * If this package is used in a product, Eric Young should be given attribution - * as the author of the parts of the library used. - * This can be in the form of a textual message at program startup or - * in documentation (online or textual) provided with the package. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * "This product includes cryptographic software written by - * Eric Young (eay@cryptsoft.com)" - * The word 'cryptographic' can be left out if the rouines from the library - * being used are not cryptographic related :-). - * 4. If you include any Windows specific code (or a derivative thereof) from - * the apps directory (application code) you must include an acknowledgement: - * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" - * - * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * - * The licence and distribution terms for any publically available version or - * derivative of this code cannot be changed. i.e. this code cannot simply be - * copied and put under another distribution licence - * [including the GNU Public Licence.] */ - -#include <stdio.h> - -#include <openssl/crypto.h> -#include <openssl/digest.h> -#include <openssl/md5.h> - - -static const char *const test[] = { - "", "a", "abc", "message digest", "abcdefghijklmnopqrstuvwxyz", - "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", - "12345678901234567890123456789012345678901234567890123456789012345678901234" - "567890", - NULL, }; - -static const char *const expected[] = { - "d41d8cd98f00b204e9800998ecf8427e", "0cc175b9c0f1b6a831c399e269772661", - "900150983cd24fb0d6963f7d28e17f72", "f96b697d7cb7938d525a2f31aaf161d0", - "c3fcd3d76192e4007dfb496cca67e13b", "d174ab98d277d9f5a5611c2c9f419d9f", - "57edf4a22be3c955ac49da2e2107b67a", }; - -int main(int argc, char **argv) { - size_t i, j; - uint8_t md[MD5_DIGEST_LENGTH]; - char md_hex[sizeof(md) * 2 + 1]; - int ok = 1; - - CRYPTO_library_init(); - - for (i = 0; test[i] != NULL; i++) { - EVP_Digest(test[i], strlen(test[i]), md, NULL, EVP_md5(), NULL); - for (j = 0; j < sizeof(md); j++) { - sprintf(&md_hex[j * 2], "%02x", md[j]); - } - md_hex[MD5_DIGEST_LENGTH * 2] = 0; - - if (strcmp(md_hex, expected[i]) != 0) { - fprintf(stderr, "#%u: got %s, wanted %s\n", (unsigned)i, md_hex, - expected[i]); - ok = 0; - } - } - - if (ok) { - printf("PASS\n"); - } - - return ok ? 0 : 1; -} |