xref: /netbsd-src/crypto/external/bsd/libsaslc/dist/test/t_crypto.c (revision beea8b97d4a59f9d0f17f6dc5a9e6bda59e0bc43)
1*beea8b97Schristos /* $NetBSD: t_crypto.c,v 1.4 2011/02/12 23:21:33 christos Exp $ */
2231558cbSagc 
3231558cbSagc /* Copyright (c) 2010 The NetBSD Foundation, Inc.
4231558cbSagc  * All rights reserved.
5231558cbSagc  *
6231558cbSagc  * This code is derived from software contributed to The NetBSD Foundation
7231558cbSagc  * by Mateusz Kocielski.
8231558cbSagc  *
9231558cbSagc  * Redistribution and use in source and binary forms, with or without
10231558cbSagc  * modification, are permitted provided that the following conditions
11231558cbSagc  * are met:
12231558cbSagc  * 1. Redistributions of source code must retain the above copyright
13231558cbSagc  *    notice, this list of conditions and the following disclaimer.
14231558cbSagc  * 2. Redistributions in binary form must reproduce the above copyright
15231558cbSagc  *    notice, this list of conditions and the following disclaimer in the
16231558cbSagc  *    documentation and/or other materials provided with the distribution.
17231558cbSagc  * 3. All advertising materials mentioning features or use of this software
18231558cbSagc  *    must display the following acknowledgement:
19231558cbSagc  *  	  This product includes software developed by the NetBSD
20231558cbSagc  *  	  Foundation, Inc. and its contributors.
21231558cbSagc  * 4. Neither the name of The NetBSD Foundation nor the names of its
22231558cbSagc  *    contributors may be used to endorse or promote products derived
23231558cbSagc  *    from this software without specific prior written permission.
24231558cbSagc  *
25231558cbSagc  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
26231558cbSagc  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27231558cbSagc  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28231558cbSagc  * PURPOSE ARE DISCLAIMED.	IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
29231558cbSagc  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30231558cbSagc  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31231558cbSagc  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32231558cbSagc  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33231558cbSagc  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34231558cbSagc  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35231558cbSagc  * POSSIBILITY OF SUCH DAMAGE.
36231558cbSagc  */
3719c14409Schristos #include <sys/cdefs.h>
38*beea8b97Schristos __RCSID("$NetBSD: t_crypto.c,v 1.4 2011/02/12 23:21:33 christos Exp $");
39231558cbSagc 
40231558cbSagc #include <atf-c.h>
41231558cbSagc #include <saslc.h>
42*beea8b97Schristos #include <stdio.h>
43231558cbSagc #include <string.h>
4419c14409Schristos 
45231558cbSagc #include "crypto.h"
46231558cbSagc 
4719c14409Schristos 
48231558cbSagc typedef struct {
49231558cbSagc 	char *in;
50231558cbSagc 	char *key;
51231558cbSagc 	char *out;
52231558cbSagc } hmac_md5_test_case_t;
53231558cbSagc 
54231558cbSagc #define HMAC_MD5_TEST_CASES 5
55231558cbSagc hmac_md5_test_case_t hmac_md5_test_cases[HMAC_MD5_TEST_CASES] = {
5619c14409Schristos 	{ /* taken from the RFC2195 */
57231558cbSagc 		"<1896.697170952@postoffice.reston.mci.net>" /* in */,
58231558cbSagc 		"tanstaaftanstaaf" /* key */,
59231558cbSagc 		"b913a602c7eda7a495b4e6e7334d3890" /* out */
60231558cbSagc 	},
6119c14409Schristos 	{ /* taken from the draft-ietf-sasl-crammd5 */
62231558cbSagc 		"<1896.697170952@postoffice.example.net>" /* in */,
63231558cbSagc 		"tanstaaftanstaaf" /* key */,
64231558cbSagc 		"3dbc88f0624776a737b39093f6eb6427" /* out */
65231558cbSagc 	},
66231558cbSagc 	{
67231558cbSagc 		"<68451038525716401353.0@localhost>" /* in */,
68231558cbSagc 		"Open, Sesame" /* key */,
69231558cbSagc 		"6fa32b6e768f073132588e3418e00f71" /* out */
70231558cbSagc 	},
7119c14409Schristos 	{ /* taken from RFC2104 */
72231558cbSagc 		"what do ya want for nothing?" /* in */,
73231558cbSagc 		"Jefe" /* key */,
74231558cbSagc 		"750c783e6ab0b503eaa86e310a5db738" /* out */
75231558cbSagc 	},
7619c14409Schristos 	{ /* taken from RFC2202 */
77231558cbSagc 		"Test Using Larger Than Block-Size Key - Hash Key First" /* in */,
7819c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
7919c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
8019c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
8119c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
8219c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
8319c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
8419c14409Schristos 		"\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA" /* key */,
85231558cbSagc 		"6b1ab7fe4bd7bf8f0b62e6ce61b9d0cd" /* out */
86231558cbSagc 	}
87231558cbSagc };
88231558cbSagc 
89231558cbSagc typedef struct {
90231558cbSagc 	char *in;
91231558cbSagc 	char *out;
92231558cbSagc } md5_test_case_t;
93231558cbSagc 
94231558cbSagc #define MD5_TEST_CASES 4
95231558cbSagc md5_test_case_t md5_test_cases[HMAC_MD5_TEST_CASES] = {
96231558cbSagc 	{
97231558cbSagc 		"this is very hard test" /* in */,
98231558cbSagc 		"c9145ff35600132e4c9b821e19c27783" /* out */
99231558cbSagc 	},
100231558cbSagc 	{
101231558cbSagc 		"shm" /* in */,
102231558cbSagc 		"99ebb038380e15bc896c3a17733ab484" /* out */
103231558cbSagc 	},
104231558cbSagc 	{
105231558cbSagc 		"this is a bit longer test, isn't it?" /* in */,
106231558cbSagc 		"b69f7a5e9c1f701ed90033b87ccca94c" /* out */
107231558cbSagc 	},
108231558cbSagc 	{
109231558cbSagc 		"OK, enough",
110231558cbSagc 		"fecb46e815d0ba4b7c89d050e30124ea" /* out */
111231558cbSagc 	}
112231558cbSagc };
113231558cbSagc 
114231558cbSagc typedef struct {
115231558cbSagc 	char *in;
116231558cbSagc 	char *out;
117231558cbSagc 	size_t len;
118231558cbSagc } base64_test_case_t;
119231558cbSagc 
120231558cbSagc #define BASE64_TEST_CASES 4
121231558cbSagc base64_test_case_t base64_test_cases[BASE64_TEST_CASES] = {
122231558cbSagc 	{
123231558cbSagc 		"this is very hard test" /* in */,
124231558cbSagc 		"dGhpcyBpcyB2ZXJ5IGhhcmQgdGVzdA==" /* out */,
125231558cbSagc 		22 /* len */
126231558cbSagc 	},
127231558cbSagc 	{
128231558cbSagc 		"shm" /* in */,
129231558cbSagc 		"c2ht" /* out */,
130231558cbSagc 		3 /* len */
131231558cbSagc 	},
132231558cbSagc 	{
133231558cbSagc 		"this is a bit longer test, isn't it?" /* in */,
134231558cbSagc 		"dGhpcyBpcyBhIGJpdCBsb25nZXIgdGVzdCwgaXNuJ3QgaXQ/" /* out */,
135231558cbSagc 		36 /* len */
136231558cbSagc 	},
137231558cbSagc 	{
138231558cbSagc 		"OK, enough",
139231558cbSagc 		"T0ssIGVub3VnaA==" /* out */,
140231558cbSagc 		10 /* len */
141231558cbSagc 	}
142231558cbSagc };
143231558cbSagc 
144231558cbSagc ATF_TC(t_crypto_hmac_md5);
ATF_TC_HEAD(t_crypto_hmac_md5,tc)145231558cbSagc ATF_TC_HEAD(t_crypto_hmac_md5, tc)
146231558cbSagc {
147231558cbSagc 	atf_tc_set_md_var(tc, "descr", "saslc__crypto_hmac_md5() tests");
148231558cbSagc }
ATF_TC_BODY(t_crypto_hmac_md5,tc)149231558cbSagc ATF_TC_BODY(t_crypto_hmac_md5, tc)
150231558cbSagc {
151231558cbSagc 	const char *digest;
152231558cbSagc 	int i;
15319c14409Schristos 
154231558cbSagc 	for (i = 0; i < HMAC_MD5_TEST_CASES; i++) {
15519c14409Schristos 		digest = saslc__crypto_hmac_md5_hex(hmac_md5_test_cases[i].key,
156231558cbSagc 		    strlen(hmac_md5_test_cases[i].key), hmac_md5_test_cases[i].in,
157231558cbSagc 		    strlen(hmac_md5_test_cases[i].in));
158231558cbSagc 		ATF_CHECK_STREQ_MSG(digest, hmac_md5_test_cases[i].out,
15919c14409Schristos 		    "saslc__crypto_hmac_md5_hex() failed on %s %s got %s should be: %s",
160231558cbSagc 		    hmac_md5_test_cases[i].in, hmac_md5_test_cases[i].key, digest,
161231558cbSagc 		    hmac_md5_test_cases[i].out);
162231558cbSagc 		free((void *)digest);
163231558cbSagc 	}
164231558cbSagc }
165231558cbSagc 
166231558cbSagc ATF_TC(t_crypto_md5);
ATF_TC_HEAD(t_crypto_md5,tc)167231558cbSagc ATF_TC_HEAD(t_crypto_md5, tc)
168231558cbSagc {
16919c14409Schristos 
17019c14409Schristos 	atf_tc_set_md_var(tc, "descr", "saslc__hmac_md5_hex() tests");
171231558cbSagc }
ATF_TC_BODY(t_crypto_md5,tc)172231558cbSagc ATF_TC_BODY(t_crypto_md5, tc)
173231558cbSagc {
174231558cbSagc 	const char *digest;
175231558cbSagc 	int i;
17619c14409Schristos 
177231558cbSagc 	for (i = 0; i < MD5_TEST_CASES; i++) {
17819c14409Schristos 		digest = saslc__crypto_md5_hex(md5_test_cases[i].in,
1796b638291Sagc 		    strlen(md5_test_cases[i].in));
180231558cbSagc 		ATF_CHECK_STREQ_MSG(digest, md5_test_cases[i].out,
18119c14409Schristos 		    "saslc__crypto_md5_hex() failed on %s got %s should be: %s",
182231558cbSagc 		    md5_test_cases[i].in, digest, md5_test_cases[i].out);
183231558cbSagc 		free((void *)digest);
184231558cbSagc 	}
185231558cbSagc }
186231558cbSagc 
187231558cbSagc ATF_TC(t_crypto_base64);
ATF_TC_HEAD(t_crypto_base64,tc)188231558cbSagc ATF_TC_HEAD(t_crypto_base64, tc)
189231558cbSagc {
190231558cbSagc 	atf_tc_set_md_var(tc, "descr", "saslc__crypto_nonce() tests");
191231558cbSagc }
ATF_TC_BODY(t_crypto_base64,tc)192231558cbSagc ATF_TC_BODY(t_crypto_base64, tc)
193231558cbSagc {
19419c14409Schristos 	char *enc;
19519c14409Schristos 	size_t enclen;
196231558cbSagc 	int i;
19719c14409Schristos 
198231558cbSagc 	for (i = 0; i < BASE64_TEST_CASES; i++) {
19919c14409Schristos 		saslc__crypto_encode_base64(base64_test_cases[i].in,
20019c14409Schristos 		    base64_test_cases[i].len, &enc, &enclen);
201231558cbSagc 		ATF_CHECK_STREQ_MSG(enc, base64_test_cases[i].out,
20219c14409Schristos 		    "saslc__crypto_encode_base64() failed on %s got %s should be: %s",
203231558cbSagc 		    base64_test_cases[i].in, enc, base64_test_cases[i].out);
204231558cbSagc 		free((void *)enc);
205231558cbSagc 	}
206231558cbSagc }
207231558cbSagc 
208231558cbSagc ATF_TC(t_crypto_nonce);
ATF_TC_HEAD(t_crypto_nonce,tc)209231558cbSagc ATF_TC_HEAD(t_crypto_nonce, tc)
210231558cbSagc {
21119c14409Schristos 
212231558cbSagc 	atf_tc_set_md_var(tc, "descr", "saslc__crypto_nonce() tests");
213231558cbSagc }
ATF_TC_BODY(t_crypto_nonce,tc)214231558cbSagc ATF_TC_BODY(t_crypto_nonce, tc)
215231558cbSagc {
216231558cbSagc 	unsigned char *x, *y;
217231558cbSagc 
21819c14409Schristos 	/* Any better ideas how to test that? ... */
21919c14409Schristos 
220231558cbSagc 	x = saslc__crypto_nonce(1024);
221231558cbSagc 	y = saslc__crypto_nonce(1024);
222231558cbSagc 
223231558cbSagc 	ATF_CHECK_EQ(((strncmp(x, y, 1024) == 0) ? 1 : 0), 0);
224231558cbSagc 
225231558cbSagc 	free(x);
226231558cbSagc 	free(y);
227231558cbSagc }
228231558cbSagc 
ATF_TP_ADD_TCS(tp)229231558cbSagc ATF_TP_ADD_TCS(tp)
230231558cbSagc {
23119c14409Schristos 
232231558cbSagc 	ATF_TP_ADD_TC(tp, t_crypto_hmac_md5);
233231558cbSagc 	ATF_TP_ADD_TC(tp, t_crypto_md5);
234231558cbSagc 	ATF_TP_ADD_TC(tp, t_crypto_base64);
235231558cbSagc 	ATF_TP_ADD_TC(tp, t_crypto_nonce);
236231558cbSagc 	return atf_no_error();
237231558cbSagc }
238