2006-08-14 14:56:21 +00:00
/*
Unix SMB / CIFS implementation .
HMAC MD5 tests
Copyright ( C ) Stefan Metzmacher 2006
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
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2006-08-14 14:56:21 +00:00
( 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
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2006-08-14 14:56:21 +00:00
*/
2010-06-15 12:01:09 +02:00
# include "replace.h"
2011-09-20 14:26:36 -07:00
# include "../lib/util/samba_util.h"
2008-09-24 16:10:53 +02:00
# include "../lib/crypto/crypto.h"
2006-08-14 14:56:21 +00:00
struct torture_context ;
2012-02-05 15:31:05 +01:00
bool torture_local_crypto_hmacmd5 ( struct torture_context * torture ) ;
2006-08-14 14:56:21 +00:00
static DATA_BLOB data_blob_repeat_byte ( uint8_t byte , size_t length )
{
DATA_BLOB b = data_blob ( NULL , length ) ;
memset ( b . data , byte , length ) ;
return b ;
}
/*
This uses the test values from rfc 2104 , 2202
*/
2007-10-05 18:03:01 +00:00
bool torture_local_crypto_hmacmd5 ( struct torture_context * torture )
2006-08-14 14:56:21 +00:00
{
2007-10-05 18:03:01 +00:00
bool ret = true ;
2006-08-14 14:56:21 +00:00
uint32_t i ;
struct {
DATA_BLOB key ;
DATA_BLOB data ;
DATA_BLOB md5 ;
2006-09-11 04:18:16 +00:00
} testarray [ 8 ] ;
2008-10-18 21:03:30 +02:00
TALLOC_CTX * tctx = talloc_new ( torture ) ;
if ( ! tctx ) { return false ; } ;
2006-09-11 04:18:16 +00:00
testarray [ 0 ] . key = data_blob_repeat_byte ( 0x0b , 16 ) ;
testarray [ 0 ] . data = data_blob_string_const ( " Hi There " ) ;
2008-10-18 21:03:30 +02:00
testarray [ 0 ] . md5 = strhex_to_data_blob ( tctx , " 9294727a3638bb1c13f48ef8158bfc9d " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 1 ] . key = data_blob_string_const ( " Jefe " ) ;
testarray [ 1 ] . data = data_blob_string_const ( " what do ya want for nothing? " ) ;
2008-10-18 21:03:30 +02:00
testarray [ 1 ] . md5 = strhex_to_data_blob ( tctx , " 750c783e6ab0b503eaa86e310a5db738 " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 2 ] . key = data_blob_repeat_byte ( 0xaa , 16 ) ;
testarray [ 2 ] . data = data_blob_repeat_byte ( 0xdd , 50 ) ;
2008-10-18 21:03:30 +02:00
testarray [ 2 ] . md5 = strhex_to_data_blob ( tctx , " 56be34521d144c88dbb8c733f0e8b3f6 " ) ;
2006-09-11 04:18:16 +00:00
2008-10-18 21:03:30 +02:00
testarray [ 3 ] . key = strhex_to_data_blob ( tctx , " 0102030405060708090a0b0c0d0e0f10111213141516171819 " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 3 ] . data = data_blob_repeat_byte ( 0xcd , 50 ) ;
2008-10-18 21:03:30 +02:00
testarray [ 3 ] . md5 = strhex_to_data_blob ( tctx , " 697eaf0aca3a3aea3a75164746ffaa79 " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 4 ] . key = data_blob_repeat_byte ( 0x0c , 16 ) ;
testarray [ 4 ] . data = data_blob_string_const ( " Test With Truncation " ) ;
2008-10-18 21:03:30 +02:00
testarray [ 4 ] . md5 = strhex_to_data_blob ( tctx , " 56461ef2342edc00f9bab995690efd4c " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 5 ] . key = data_blob_repeat_byte ( 0xaa , 80 ) ;
testarray [ 5 ] . data = data_blob_string_const ( " Test Using Larger Than Block-Size Key - Hash Key First " ) ;
2008-10-18 21:03:30 +02:00
testarray [ 5 ] . md5 = strhex_to_data_blob ( tctx , " 6b1ab7fe4bd7bf8f0b62e6ce61b9d0cd " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 6 ] . key = data_blob_repeat_byte ( 0xaa , 80 ) ;
testarray [ 6 ] . data = data_blob_string_const ( " Test Using Larger Than Block-Size Key "
" and Larger Than One Block-Size Data " ) ;
2008-10-18 21:03:30 +02:00
testarray [ 6 ] . md5 = strhex_to_data_blob ( tctx , " 6f630fad67cda0ee1fb1f562db3aa53e " ) ;
2006-09-11 04:18:16 +00:00
testarray [ 7 ] . key = data_blob ( NULL , 0 ) ;
2006-08-14 14:56:21 +00:00
2006-09-11 04:18:16 +00:00
for ( i = 0 ; testarray [ i ] . key . data ; i + + ) {
2006-08-14 14:56:21 +00:00
HMACMD5Context ctx ;
uint8_t md5 [ 16 ] ;
int e ;
hmac_md5_init_rfc2104 ( testarray [ i ] . key . data , testarray [ i ] . key . length , & ctx ) ;
hmac_md5_update ( testarray [ i ] . data . data , testarray [ i ] . data . length , & ctx ) ;
hmac_md5_final ( md5 , & ctx ) ;
e = memcmp ( testarray [ i ] . md5 . data ,
md5 ,
MIN ( testarray [ i ] . md5 . length , sizeof ( md5 ) ) ) ;
if ( e ! = 0 ) {
printf ( " hmacmd5 test[%u]: failed \n " , i ) ;
dump_data ( 0 , testarray [ i ] . key . data , testarray [ i ] . key . length ) ;
dump_data ( 0 , testarray [ i ] . data . data , testarray [ i ] . data . length ) ;
dump_data ( 0 , testarray [ i ] . md5 . data , testarray [ i ] . md5 . length ) ;
dump_data ( 0 , md5 , sizeof ( md5 ) ) ;
2007-10-05 18:03:01 +00:00
ret = false ;
2006-08-14 14:56:21 +00:00
}
}
2008-10-18 21:03:30 +02:00
talloc_free ( tctx ) ;
2006-08-14 14:56:21 +00:00
return ret ;
}