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