mirror of
git://git.gnupg.org/gnupg.git
synced 2025-05-14 08:13:25 +02:00
Use separate test module for dns-cert.c.
* dns-cert.c (get_dns_cert): Factor test code out to ... * t-dns-cert.c: new file.
This commit is contained in:
parent
93db5ed4e6
commit
8993b45c74
@ -1,3 +1,8 @@
|
|||||||
|
2011-11-28 Werner Koch <wk@g10code.com>
|
||||||
|
|
||||||
|
* dns-cert.c (get_dns_cert): Factor test code out to ...
|
||||||
|
* t-dns-cert.c: new file.
|
||||||
|
|
||||||
2011-10-24 Werner Koch <wk@g10code.com>
|
2011-10-24 Werner Koch <wk@g10code.com>
|
||||||
|
|
||||||
* dotlock.h, dotlock.c: Add alternative to allow distribution of
|
* dotlock.h, dotlock.c: Add alternative to allow distribution of
|
||||||
|
@ -162,7 +162,7 @@ if HAVE_W32_SYSTEM
|
|||||||
jnlib_tests += t-w32-reg
|
jnlib_tests += t-w32-reg
|
||||||
endif
|
endif
|
||||||
module_tests = t-convert t-percent t-gettime t-sysutils t-sexputil \
|
module_tests = t-convert t-percent t-gettime t-sysutils t-sexputil \
|
||||||
t-session-env t-openpgp-oid t-ssh-utils
|
t-session-env t-openpgp-oid t-ssh-utils t-dns-cert
|
||||||
if !HAVE_W32CE_SYSTEM
|
if !HAVE_W32CE_SYSTEM
|
||||||
module_tests += t-exechelp
|
module_tests += t-exechelp
|
||||||
endif
|
endif
|
||||||
@ -196,3 +196,4 @@ t_exechelp_LDADD = $(t_common_ldadd)
|
|||||||
t_session_env_LDADD = $(t_common_ldadd)
|
t_session_env_LDADD = $(t_common_ldadd)
|
||||||
t_openpgp_oid_LDADD = $(t_common_ldadd)
|
t_openpgp_oid_LDADD = $(t_common_ldadd)
|
||||||
t_ssh_utils_LDADD = $(t_common_ldadd)
|
t_ssh_utils_LDADD = $(t_common_ldadd)
|
||||||
|
t_dns_cert_LDADD = $(t_common_ldadd) $(DNSLIBS)
|
||||||
|
@ -46,13 +46,13 @@
|
|||||||
#define T_CERT 37
|
#define T_CERT 37
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* ADNS has no support for CERT yes. */
|
/* ADNS has no support for CERT yet. */
|
||||||
#define my_adns_r_cert 37
|
#define my_adns_r_cert 37
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Returns -1 on error, 0 for no answer, 1 for PGP provided and 2 for
|
/* Returns -1 on error, 0 for no answer, 1 for PGP provided and 2 for
|
||||||
IPGP provided. Note that this fucntion retruns the first CERT
|
IPGP provided. Note that this function retruns the first CERT
|
||||||
found with a supported type; it is expected that only one CERT
|
found with a supported type; it is expected that only one CERT
|
||||||
record is used. */
|
record is used. */
|
||||||
int
|
int
|
||||||
@ -289,61 +289,3 @@ get_dns_cert (const char *name, size_t max_size, IOBUF *iobuf,
|
|||||||
return -1;
|
return -1;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Test with simon.josefsson.org */
|
|
||||||
|
|
||||||
#ifdef TEST
|
|
||||||
int
|
|
||||||
main(int argc,char *argv[])
|
|
||||||
{
|
|
||||||
unsigned char *fpr;
|
|
||||||
size_t fpr_len;
|
|
||||||
char *url;
|
|
||||||
int rc;
|
|
||||||
IOBUF iobuf;
|
|
||||||
|
|
||||||
if(argc!=2)
|
|
||||||
{
|
|
||||||
printf("cert-test [name]\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("CERT lookup on %s\n",argv[1]);
|
|
||||||
|
|
||||||
rc=get_dns_cert (argv[1],16384,&iobuf,&fpr,&fpr_len,&url);
|
|
||||||
if(rc==-1)
|
|
||||||
printf("error\n");
|
|
||||||
else if(rc==0)
|
|
||||||
printf("no answer\n");
|
|
||||||
else if(rc==1)
|
|
||||||
{
|
|
||||||
printf("key found: %d bytes\n",(int)iobuf_get_temp_length(iobuf));
|
|
||||||
iobuf_close(iobuf);
|
|
||||||
}
|
|
||||||
else if(rc==2)
|
|
||||||
{
|
|
||||||
if(fpr)
|
|
||||||
{
|
|
||||||
size_t i;
|
|
||||||
printf("Fingerprint found (%d bytes): ",(int)fpr_len);
|
|
||||||
for(i=0;i<fpr_len;i++)
|
|
||||||
printf("%02X",fpr[i]);
|
|
||||||
printf("\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
printf("No fingerprint found\n");
|
|
||||||
|
|
||||||
if(url)
|
|
||||||
printf("URL found: %s\n",url);
|
|
||||||
else
|
|
||||||
printf("No URL found\n");
|
|
||||||
|
|
||||||
xfree(fpr);
|
|
||||||
xfree(url);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif /* TEST */
|
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
#ifndef GNUPG_COMMON_DNS_CERT_H
|
#ifndef GNUPG_COMMON_DNS_CERT_H
|
||||||
#define GNUPG_COMMON_DNS_CERT_H
|
#define GNUPG_COMMON_DNS_CERT_H
|
||||||
|
|
||||||
int get_dns_cert (const char *name, size_t max_size, IOBUF *iobuf,
|
int get_dns_cert (const char *name, size_t max_size, iobuf_t *iobuf,
|
||||||
unsigned char **fpr, size_t *fpr_len, char **url);
|
unsigned char **fpr, size_t *fpr_len, char **url);
|
||||||
|
|
||||||
|
|
||||||
|
93
common/t-dns-cert.c
Normal file
93
common/t-dns-cert.c
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
/* t-dns-cert.c - Module test for dns-cert.c
|
||||||
|
* Copyright (C) 2011 Free Software Foundation, Inc.
|
||||||
|
*
|
||||||
|
* This file is part of GnuPG.
|
||||||
|
*
|
||||||
|
* GnuPG is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* GnuPG is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "util.h"
|
||||||
|
#include "iobuf.h"
|
||||||
|
#include "dns-cert.h"
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
main (int argc, char **argv)
|
||||||
|
{
|
||||||
|
unsigned char *fpr;
|
||||||
|
size_t fpr_len;
|
||||||
|
char *url;
|
||||||
|
int rc;
|
||||||
|
iobuf_t iobuf;
|
||||||
|
char const *name;
|
||||||
|
|
||||||
|
if (argc)
|
||||||
|
{
|
||||||
|
argc--;
|
||||||
|
argv++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!argc)
|
||||||
|
name = "simon.josefsson.org";
|
||||||
|
else if (argc == 1)
|
||||||
|
name = *argv;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fputs ("usage: t-dns-cert [name]\n", stderr);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf ("CERT lookup on `%s'\n", name);
|
||||||
|
|
||||||
|
rc = get_dns_cert (name, 16384, &iobuf, &fpr, &fpr_len, &url);
|
||||||
|
if (rc == -1)
|
||||||
|
fputs ("lookup result: error\n", stdout);
|
||||||
|
else if (!rc)
|
||||||
|
fputs ("lookup result: no answer\n", stdout);
|
||||||
|
else if (rc == 1)
|
||||||
|
{
|
||||||
|
printf ("lookup result: %d bytes\n",
|
||||||
|
(int)iobuf_get_temp_length(iobuf));
|
||||||
|
iobuf_close (iobuf);
|
||||||
|
}
|
||||||
|
else if (rc == 2)
|
||||||
|
{
|
||||||
|
if (fpr)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
printf ("Fingerprint found (%d bytes): ", (int)fpr_len);
|
||||||
|
for (i = 0; i < fpr_len; i++)
|
||||||
|
printf ("%02X", fpr[i]);
|
||||||
|
putchar ('\n');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf ("No fingerprint found\n");
|
||||||
|
|
||||||
|
if (url)
|
||||||
|
printf ("URL found: %s\n", url);
|
||||||
|
else
|
||||||
|
printf ("No URL found\n");
|
||||||
|
|
||||||
|
xfree (fpr);
|
||||||
|
xfree (url);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user