0aadc82afb
components: apr-1.4.6 -> 1.4.8 and apr-util-1.4.1 -> 1.5.2. This is a post point-zero bug-fix / fix-sharp-edges release, including some workarounds for UTF-8 for people who haven't yet turned on WITH_ICONV.
104 lines
3.8 KiB
C
104 lines
3.8 KiB
C
/* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership.
|
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
* (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include <assert.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
#include "apr_md5.h"
|
|
#include "apr_xlate.h"
|
|
#include "apr_general.h"
|
|
|
|
#include "abts.h"
|
|
#include "testutil.h"
|
|
|
|
static struct {
|
|
const char *string;
|
|
const char *digest;
|
|
} md5sums[] =
|
|
{
|
|
{"Jeff was here!",
|
|
"\xa5\x25\x8a\x89\x11\xb2\x9d\x1f\x81\x75\x96\x3b\x60\x94\x49\xc0"},
|
|
{"01234567890aBcDeFASDFGHJKLPOIUYTR"
|
|
"POIUYTREWQZXCVBN LLLLLLLLLLLLLLL",
|
|
"\xd4\x1a\x06\x2c\xc5\xfd\x6f\x24\x67\x68\x56\x7c\x40\x8a\xd5\x69"},
|
|
{"111111118888888888888888*******%%%%%%%%%%#####"
|
|
"142134u8097289720432098409289nkjlfkjlmn,m.. ",
|
|
"\xb6\xea\x5b\xe8\xca\x45\x8a\x33\xf0\xf1\x84\x6f\xf9\x65\xa8\xe1"},
|
|
{"01234567890aBcDeFASDFGHJKLPOIUYTR"
|
|
"POIUYTREWQZXCVBN LLLLLLLLLLLLLLL"
|
|
"01234567890aBcDeFASDFGHJKLPOIUYTR"
|
|
"POIUYTREWQZXCVBN LLLLLLLLLLLLLLL"
|
|
"1",
|
|
"\xd1\xa1\xc0\x97\x8a\x60\xbb\xfb\x2a\x25\x46\x9d\xa5\xae\xd0\xb0"}
|
|
};
|
|
|
|
static int num_sums = sizeof(md5sums) / sizeof(md5sums[0]);
|
|
static int count;
|
|
|
|
static void test_md5sum(abts_case *tc, void *data)
|
|
{
|
|
apr_md5_ctx_t context;
|
|
unsigned char digest[APR_MD5_DIGESTSIZE];
|
|
const void *string = md5sums[count].string;
|
|
const void *sum = md5sums[count].digest;
|
|
unsigned int len = strlen(string);
|
|
|
|
ABTS_ASSERT(tc, "apr_md5_init", (apr_md5_init(&context) == 0));
|
|
ABTS_ASSERT(tc, "apr_md5_update",
|
|
(apr_md5_update(&context, string, len) == 0));
|
|
ABTS_ASSERT(tc, "apr_md5_final", (apr_md5_final(digest, &context)
|
|
== 0));
|
|
ABTS_ASSERT(tc, "check for correct md5 digest",
|
|
(memcmp(digest, sum, APR_MD5_DIGESTSIZE) == 0));
|
|
}
|
|
|
|
static void test_md5sum_unaligned(abts_case *tc, void *data)
|
|
{
|
|
apr_md5_ctx_t context;
|
|
const char *string = "abcdefghijklmnopqrstuvwxyz01234"
|
|
"abcdefghijklmnopqrstuvwxyz01234"
|
|
"abcdefghijklmnopqrstuvwxyz01234"
|
|
"abcdefghijklmnopqrstuvwxyz01234_";
|
|
const char *sum =
|
|
"\x93\x17\x22\x78\xee\x30\x82\xb3\xeb\x95\x33\xec\xea\x78\xb7\x89";
|
|
unsigned char digest[APR_MD5_DIGESTSIZE];
|
|
unsigned int i;
|
|
|
|
ABTS_ASSERT(tc, "apr_md5_init", (apr_md5_init(&context) == 0));
|
|
for (i = 0; i < 10; i++) {
|
|
ABTS_ASSERT(tc, "apr_md5_update",
|
|
(apr_md5_update(&context, string, strlen(string)) == 0));
|
|
string++;
|
|
}
|
|
ABTS_ASSERT(tc, "apr_md5_final", (apr_md5_final(digest, &context)
|
|
== 0));
|
|
ABTS_ASSERT(tc, "check for correct md5 digest of unaligned data",
|
|
(memcmp(digest, sum, APR_MD5_DIGESTSIZE) == 0));
|
|
}
|
|
|
|
abts_suite *testmd5(abts_suite *suite)
|
|
{
|
|
suite = ADD_SUITE(suite);
|
|
|
|
for (count=0; count < num_sums; count++) {
|
|
abts_run_test(suite, test_md5sum, NULL);
|
|
}
|
|
abts_run_test(suite, test_md5sum_unaligned, NULL);
|
|
|
|
return suite;
|
|
}
|