1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-11 05:18:09 +03:00
samba-mirror/lib/crypto/md5test.c
Andrew Bartlett fc13489c91 build: Build with system md5.h on OpenIndiana
This changes (again...) our system md5 detection to cope with how
OpenIndiana does md5.  I'm becoming increasingly convinced this isn't
worth our while (we should have just done samba_md5...), but for now
this change seems to work on FreeBSD, OpenIndiana and Linux with
libbsd.

This needs us to rename struct MD5Context -> MD5_CTX, but we provide a
config.h define to rename the type bad if MD5_CTX does not exist (it does
however exist in the md5.h from libbsd).

Andrew Bartlett

Signed-off-by: Andrew Bartlett <abartlet@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>

Autobuild-User(master): Jeremy Allison <jra@samba.org>
Autobuild-Date(master): Wed Jun 19 21:32:36 CEST 2013 on sn-devel-104
2013-06-19 21:32:36 +02:00

97 lines
2.4 KiB
C

/*
Unix SMB/CIFS implementation.
MD5 tests
Copyright (C) Stefan Metzmacher
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 "replace.h"
#include "../lib/util/samba_util.h"
#include "../lib/crypto/crypto.h"
struct torture_context;
bool torture_local_crypto_md5(struct torture_context *torture);
/*
This uses the test values from rfc1321
*/
bool torture_local_crypto_md5(struct torture_context *torture)
{
bool ret = true;
uint32_t i;
struct {
const char *data;
const char *md5;
} testarray[] = {
{
.data = "",
.md5 = "d41d8cd98f00b204e9800998ecf8427e"
},{
.data = "a",
.md5 = "0cc175b9c0f1b6a831c399e269772661"
},{
.data = "abc",
.md5 = "900150983cd24fb0d6963f7d28e17f72"
},{
.data = "message digest",
.md5 = "f96b697d7cb7938d525a2f31aaf161d0"
},{
.data = "abcdefghijklmnopqrstuvwxyz",
.md5 = "c3fcd3d76192e4007dfb496cca67e13b"
},{
.data = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789",
.md5 = "d174ab98d277d9f5a5611c2c9f419d9f"
},{
.data = "123456789012345678901234567890"
"123456789012345678901234567890"
"12345678901234567890",
.md5 = "57edf4a22be3c955ac49da2e2107b67a"
}
};
for (i=0; i < ARRAY_SIZE(testarray); i++) {
MD5_CTX ctx;
uint8_t md5[16];
int e;
DATA_BLOB data;
DATA_BLOB md5blob;
data = data_blob_string_const(testarray[i].data);
md5blob = strhex_to_data_blob(NULL, testarray[i].md5);
MD5Init(&ctx);
MD5Update(&ctx, data.data, data.length);
MD5Final(md5, &ctx);
e = memcmp(md5blob.data,
md5,
MIN(md5blob.length, sizeof(md5)));
if (e != 0) {
printf("md5 test[%u]: failed\n", i);
dump_data(0, data.data, data.length);
dump_data(0, md5blob.data, md5blob.length);
dump_data(0, md5, sizeof(md5));
ret = false;
}
talloc_free(md5blob.data);
}
return ret;
}