1251876Speter/* Licensed to the Apache Software Foundation (ASF) under one or more 2251876Speter * contributor license agreements. See the NOTICE file distributed with 3251876Speter * this work for additional information regarding copyright ownership. 4251876Speter * The ASF licenses this file to You under the Apache License, Version 2.0 5251876Speter * (the "License"); you may not use this file except in compliance with 6251876Speter * the License. You may obtain a copy of the License at 7251876Speter * 8251876Speter * http://www.apache.org/licenses/LICENSE-2.0 9251876Speter * 10251876Speter * Unless required by applicable law or agreed to in writing, software 11251876Speter * distributed under the License is distributed on an "AS IS" BASIS, 12251876Speter * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13251876Speter * See the License for the specific language governing permissions and 14251876Speter * limitations under the License. 15251876Speter */ 16251876Speter 17251876Speter#include <assert.h> 18251876Speter#include <stdio.h> 19251876Speter#include <stdlib.h> 20251876Speter 21251876Speter#include "apr_md5.h" 22251876Speter#include "apr_xlate.h" 23251876Speter#include "apr_general.h" 24251876Speter 25251876Speter#include "abts.h" 26251876Speter#include "testutil.h" 27251876Speter 28251876Speterstatic struct { 29251876Speter const char *string; 30251876Speter const char *digest; 31251876Speter} md5sums[] = 32251876Speter{ 33251876Speter {"Jeff was here!", 34251876Speter "\xa5\x25\x8a\x89\x11\xb2\x9d\x1f\x81\x75\x96\x3b\x60\x94\x49\xc0"}, 35251876Speter {"01234567890aBcDeFASDFGHJKLPOIUYTR" 36251876Speter "POIUYTREWQZXCVBN LLLLLLLLLLLLLLL", 37251876Speter "\xd4\x1a\x06\x2c\xc5\xfd\x6f\x24\x67\x68\x56\x7c\x40\x8a\xd5\x69"}, 38251876Speter {"111111118888888888888888*******%%%%%%%%%%#####" 39251876Speter "142134u8097289720432098409289nkjlfkjlmn,m.. ", 40251876Speter "\xb6\xea\x5b\xe8\xca\x45\x8a\x33\xf0\xf1\x84\x6f\xf9\x65\xa8\xe1"}, 41251876Speter {"01234567890aBcDeFASDFGHJKLPOIUYTR" 42251876Speter "POIUYTREWQZXCVBN LLLLLLLLLLLLLLL" 43251876Speter "01234567890aBcDeFASDFGHJKLPOIUYTR" 44251876Speter "POIUYTREWQZXCVBN LLLLLLLLLLLLLLL" 45251876Speter "1", 46251876Speter "\xd1\xa1\xc0\x97\x8a\x60\xbb\xfb\x2a\x25\x46\x9d\xa5\xae\xd0\xb0"} 47251876Speter}; 48251876Speter 49251876Speterstatic int num_sums = sizeof(md5sums) / sizeof(md5sums[0]); 50251876Speterstatic int count; 51251876Speter 52251876Speterstatic void test_md5sum(abts_case *tc, void *data) 53251876Speter{ 54251876Speter apr_md5_ctx_t context; 55251876Speter unsigned char digest[APR_MD5_DIGESTSIZE]; 56251876Speter const void *string = md5sums[count].string; 57251876Speter const void *sum = md5sums[count].digest; 58251876Speter unsigned int len = strlen(string); 59251876Speter 60251876Speter ABTS_ASSERT(tc, "apr_md5_init", (apr_md5_init(&context) == 0)); 61251876Speter ABTS_ASSERT(tc, "apr_md5_update", 62251876Speter (apr_md5_update(&context, string, len) == 0)); 63251876Speter ABTS_ASSERT(tc, "apr_md5_final", (apr_md5_final(digest, &context) 64251876Speter == 0)); 65251876Speter ABTS_ASSERT(tc, "check for correct md5 digest", 66251876Speter (memcmp(digest, sum, APR_MD5_DIGESTSIZE) == 0)); 67251876Speter} 68251876Speter 69253734Speterstatic void test_md5sum_unaligned(abts_case *tc, void *data) 70253734Speter{ 71253734Speter apr_md5_ctx_t context; 72253734Speter const char *string = "abcdefghijklmnopqrstuvwxyz01234" 73253734Speter "abcdefghijklmnopqrstuvwxyz01234" 74253734Speter "abcdefghijklmnopqrstuvwxyz01234" 75253734Speter "abcdefghijklmnopqrstuvwxyz01234_"; 76253734Speter const char *sum = 77253734Speter "\x93\x17\x22\x78\xee\x30\x82\xb3\xeb\x95\x33\xec\xea\x78\xb7\x89"; 78253734Speter unsigned char digest[APR_MD5_DIGESTSIZE]; 79253734Speter unsigned int i; 80253734Speter 81253734Speter ABTS_ASSERT(tc, "apr_md5_init", (apr_md5_init(&context) == 0)); 82253734Speter for (i = 0; i < 10; i++) { 83253734Speter ABTS_ASSERT(tc, "apr_md5_update", 84253734Speter (apr_md5_update(&context, string, strlen(string)) == 0)); 85253734Speter string++; 86253734Speter } 87253734Speter ABTS_ASSERT(tc, "apr_md5_final", (apr_md5_final(digest, &context) 88253734Speter == 0)); 89253734Speter ABTS_ASSERT(tc, "check for correct md5 digest of unaligned data", 90253734Speter (memcmp(digest, sum, APR_MD5_DIGESTSIZE) == 0)); 91253734Speter} 92253734Speter 93251876Speterabts_suite *testmd5(abts_suite *suite) 94251876Speter{ 95251876Speter suite = ADD_SUITE(suite); 96251876Speter 97251876Speter for (count=0; count < num_sums; count++) { 98251876Speter abts_run_test(suite, test_md5sum, NULL); 99251876Speter } 100253734Speter abts_run_test(suite, test_md5sum_unaligned, NULL); 101251876Speter 102251876Speter return suite; 103251876Speter} 104