1*00b67f09SDavid van Moolenbroek /* $NetBSD: dh_test.c,v 1.1.1.1 2015/07/08 15:38:04 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2014 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek *
6*00b67f09SDavid van Moolenbroek * Permission to use, copy, modify, and/or distribute this software for any
7*00b67f09SDavid van Moolenbroek * purpose with or without fee is hereby granted, provided that the above
8*00b67f09SDavid van Moolenbroek * copyright notice and this permission notice appear in all copies.
9*00b67f09SDavid van Moolenbroek *
10*00b67f09SDavid van Moolenbroek * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
11*00b67f09SDavid van Moolenbroek * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
12*00b67f09SDavid van Moolenbroek * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
13*00b67f09SDavid van Moolenbroek * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
14*00b67f09SDavid van Moolenbroek * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
15*00b67f09SDavid van Moolenbroek * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
16*00b67f09SDavid van Moolenbroek * PERFORMANCE OF THIS SOFTWARE.
17*00b67f09SDavid van Moolenbroek */
18*00b67f09SDavid van Moolenbroek
19*00b67f09SDavid van Moolenbroek /* Id */
20*00b67f09SDavid van Moolenbroek
21*00b67f09SDavid van Moolenbroek /* ! \file */
22*00b67f09SDavid van Moolenbroek
23*00b67f09SDavid van Moolenbroek #include <config.h>
24*00b67f09SDavid van Moolenbroek
25*00b67f09SDavid van Moolenbroek #include <atf-c.h>
26*00b67f09SDavid van Moolenbroek
27*00b67f09SDavid van Moolenbroek #include <unistd.h>
28*00b67f09SDavid van Moolenbroek
29*00b67f09SDavid van Moolenbroek #include <isc/util.h>
30*00b67f09SDavid van Moolenbroek #include <isc/string.h>
31*00b67f09SDavid van Moolenbroek
32*00b67f09SDavid van Moolenbroek #include <dns/name.h>
33*00b67f09SDavid van Moolenbroek #include <dst/result.h>
34*00b67f09SDavid van Moolenbroek
35*00b67f09SDavid van Moolenbroek #include "../dst_internal.h"
36*00b67f09SDavid van Moolenbroek
37*00b67f09SDavid van Moolenbroek #include "dnstest.h"
38*00b67f09SDavid van Moolenbroek
39*00b67f09SDavid van Moolenbroek #ifdef OPENSSL
40*00b67f09SDavid van Moolenbroek
41*00b67f09SDavid van Moolenbroek ATF_TC(isc_dh_computesecret);
ATF_TC_HEAD(isc_dh_computesecret,tc)42*00b67f09SDavid van Moolenbroek ATF_TC_HEAD(isc_dh_computesecret, tc) {
43*00b67f09SDavid van Moolenbroek atf_tc_set_md_var(tc, "descr", "OpenSSL DH_compute_key() failure");
44*00b67f09SDavid van Moolenbroek }
ATF_TC_BODY(isc_dh_computesecret,tc)45*00b67f09SDavid van Moolenbroek ATF_TC_BODY(isc_dh_computesecret, tc) {
46*00b67f09SDavid van Moolenbroek dst_key_t *key = NULL;
47*00b67f09SDavid van Moolenbroek isc_buffer_t buf;
48*00b67f09SDavid van Moolenbroek unsigned char array[1024];
49*00b67f09SDavid van Moolenbroek isc_result_t ret;
50*00b67f09SDavid van Moolenbroek dns_fixedname_t fname;
51*00b67f09SDavid van Moolenbroek dns_name_t *name;
52*00b67f09SDavid van Moolenbroek
53*00b67f09SDavid van Moolenbroek UNUSED(tc);
54*00b67f09SDavid van Moolenbroek
55*00b67f09SDavid van Moolenbroek ret = dns_test_begin(NULL, ISC_FALSE);
56*00b67f09SDavid van Moolenbroek ATF_REQUIRE_EQ(ret, ISC_R_SUCCESS);
57*00b67f09SDavid van Moolenbroek
58*00b67f09SDavid van Moolenbroek dns_fixedname_init(&fname);
59*00b67f09SDavid van Moolenbroek name = dns_fixedname_name(&fname);
60*00b67f09SDavid van Moolenbroek isc_buffer_constinit(&buf, "dh.", 3);
61*00b67f09SDavid van Moolenbroek isc_buffer_add(&buf, 3);
62*00b67f09SDavid van Moolenbroek ret = dns_name_fromtext(name, &buf, NULL, 0, NULL);
63*00b67f09SDavid van Moolenbroek ATF_REQUIRE_EQ(ret, ISC_R_SUCCESS);
64*00b67f09SDavid van Moolenbroek
65*00b67f09SDavid van Moolenbroek ret = dst_key_fromfile(name, 18602, DST_ALG_DH,
66*00b67f09SDavid van Moolenbroek DST_TYPE_PUBLIC | DST_TYPE_KEY,
67*00b67f09SDavid van Moolenbroek "./", mctx, &key);
68*00b67f09SDavid van Moolenbroek ATF_REQUIRE_EQ(ret, ISC_R_SUCCESS);
69*00b67f09SDavid van Moolenbroek
70*00b67f09SDavid van Moolenbroek isc_buffer_init(&buf, array, sizeof(array));
71*00b67f09SDavid van Moolenbroek ret = dst_key_computesecret(key, key, &buf);
72*00b67f09SDavid van Moolenbroek ATF_REQUIRE_EQ(ret, DST_R_NOTPRIVATEKEY);
73*00b67f09SDavid van Moolenbroek ret = key->func->computesecret(key, key, &buf);
74*00b67f09SDavid van Moolenbroek ATF_REQUIRE_EQ(ret, DST_R_COMPUTESECRETFAILURE);
75*00b67f09SDavid van Moolenbroek
76*00b67f09SDavid van Moolenbroek dst_key_free(&key);
77*00b67f09SDavid van Moolenbroek dns_test_end();
78*00b67f09SDavid van Moolenbroek }
79*00b67f09SDavid van Moolenbroek #else
80*00b67f09SDavid van Moolenbroek ATF_TC(untested);
ATF_TC_HEAD(untested,tc)81*00b67f09SDavid van Moolenbroek ATF_TC_HEAD(untested, tc) {
82*00b67f09SDavid van Moolenbroek atf_tc_set_md_var(tc, "descr", "skipping OpenSSL DH test");
83*00b67f09SDavid van Moolenbroek }
ATF_TC_BODY(untested,tc)84*00b67f09SDavid van Moolenbroek ATF_TC_BODY(untested, tc) {
85*00b67f09SDavid van Moolenbroek UNUSED(tc);
86*00b67f09SDavid van Moolenbroek atf_tc_skip("OpenSSL DH not compiled in");
87*00b67f09SDavid van Moolenbroek }
88*00b67f09SDavid van Moolenbroek #endif
89*00b67f09SDavid van Moolenbroek /*
90*00b67f09SDavid van Moolenbroek * Main
91*00b67f09SDavid van Moolenbroek */
ATF_TP_ADD_TCS(tp)92*00b67f09SDavid van Moolenbroek ATF_TP_ADD_TCS(tp) {
93*00b67f09SDavid van Moolenbroek #ifdef OPENSSL
94*00b67f09SDavid van Moolenbroek ATF_TP_ADD_TC(tp, isc_dh_computesecret);
95*00b67f09SDavid van Moolenbroek #else
96*00b67f09SDavid van Moolenbroek ATF_TP_ADD_TC(tp, untested);
97*00b67f09SDavid van Moolenbroek #endif
98*00b67f09SDavid van Moolenbroek return (atf_no_error());
99*00b67f09SDavid van Moolenbroek }
100