2003-05-18 Marcus Brinkmann <marcus@g10code.de>
[gpgme.git] / tests / gpgsm / t-import.c
1 /* t-import.c - Regression test.
2    Copyright (C) 2000 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2003 g10 Code GmbH
4
5    This file is part of GPGME.
6  
7    GPGME is free software; you can redistribute it and/or modify it
8    under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11  
12    GPGME is distributed in the hope that it will be useful, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    General Public License for more details.
16  
17    You should have received a copy of the GNU General Public License
18    along with GPGME; if not, write to the Free Software Foundation,
19    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 #include <stdlib.h>
22 #include <stdio.h>
23 #include <string.h>
24 #include <errno.h>
25
26 #include <gpgme.h>
27
28
29 #define fail_if_err(err)                                        \
30   do                                                            \
31     {                                                           \
32       if (err)                                                  \
33         {                                                       \
34           fprintf (stderr, "%s:%d: gpgme_error_t %s\n",         \
35                    __FILE__, __LINE__, gpgme_strerror (err));   \
36           exit (1);                                             \
37         }                                                       \
38     }                                                           \
39   while (0)
40
41
42 static char *
43 make_filename (const char *fname)
44 {
45   const char *srcdir = getenv ("srcdir");
46   char *buf;
47
48   if (!srcdir)
49     srcdir = ".";
50   buf = malloc (strlen(srcdir) + strlen(fname) + 2);
51   if (!buf)
52     {
53       fprintf (stderr, "%s:%d: could not allocate string: %s\n",
54                __FILE__, __LINE__, strerror (errno));
55       exit (1);
56     }
57   strcpy (buf, srcdir);
58   strcat (buf, "/");
59   strcat (buf, fname);
60   return buf;
61 }
62
63
64 void
65 check_result (gpgme_import_result_t result, char *fpr, int total)
66 {
67   if (result->considered != total)
68     {
69       fprintf (stderr, "Unexpected number of considered keys %i\n",
70                result->considered);
71       exit (1);
72     }
73   if (result->no_user_id != 0)
74     {
75       fprintf (stderr, "Unexpected number of user ids %i\n",
76                result->no_user_id);
77       exit (1);
78     }
79   if (result->imported != 0 && result->imported != 1)
80     {
81       fprintf (stderr, "Unexpected number of imported keys %i\n",
82                result->imported);
83       exit (1);
84     }
85   if (result->imported_rsa != 0)
86     {
87       fprintf (stderr, "Unexpected number of imported RSA keys %i\n",
88                result->imported_rsa);
89       exit (1);
90     }
91   if ((result->imported == 0 && result->unchanged != total)
92       || (result->imported == 1 && result->unchanged != total - 1))
93     {
94       fprintf (stderr, "Unexpected number of unchanged keys %i\n",
95                result->unchanged);
96       exit (1);
97     }
98   if (result->new_user_ids != 0)
99     {
100       fprintf (stderr, "Unexpected number of new user IDs %i\n",
101                result->new_user_ids);
102       exit (1);
103     }
104   if (result->new_sub_keys != 0)
105     {
106       fprintf (stderr, "Unexpected number of new sub keys %i\n",
107                result->new_sub_keys);
108       exit (1);
109     }
110   if (result->new_signatures != 0)
111     {
112       fprintf (stderr, "Unexpected number of new signatures %i\n",
113                result->new_signatures);
114       exit (1);
115     }
116   if (result->new_revocations != 0)
117     {
118       fprintf (stderr, "Unexpected number of new revocations %i\n",
119                result->new_revocations);
120       exit (1);
121     }
122   if (result->secret_read != 0)
123     {
124       fprintf (stderr, "Unexpected number of secret keys read %i\n",
125                result->secret_read);
126       exit (1);
127     }
128   if (result->secret_imported != 0)
129     {
130       fprintf (stderr, "Unexpected number of secret keys imported %i\n",
131                result->secret_imported);
132       exit (1);
133     }
134   if (result->secret_unchanged != 0)
135     {
136       fprintf (stderr, "Unexpected number of secret keys unchanged %i\n",
137                result->secret_unchanged);
138       exit (1);
139     }
140   if (result->not_imported != 0)
141     {
142       fprintf (stderr, "Unexpected number of secret keys not imported %i\n",
143                result->not_imported);
144       exit (1);
145     }
146   if (result->imports)
147     {
148       fprintf (stderr, "Unexpected number of status reports\n");
149       exit (1);
150     }
151 }
152
153
154 int 
155 main (int argc, char **argv)
156 {
157   gpgme_ctx_t ctx;
158   gpgme_error_t err;
159   gpgme_data_t in;
160   gpgme_import_result_t result;
161   const char *cert_1 = make_filename ("cert_dfn_pca01.der");
162   const char *cert_2 = make_filename ("cert_dfn_pca15.der");
163
164   err = gpgme_engine_check_version (GPGME_PROTOCOL_CMS);
165   fail_if_err (err);
166
167   err = gpgme_new (&ctx);
168   fail_if_err (err);
169   
170   gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
171
172   err = gpgme_data_new_from_file (&in, cert_1, 1);
173   fail_if_err (err);
174
175   err = gpgme_op_import (ctx, in);
176   fail_if_err (err);
177   result = gpgme_op_import_result (ctx);
178   check_result (result, "DFA56FB5FC41E3A8921F77AD1622EEFD9152A5AD", 1);
179   gpgme_data_release (in);
180
181   err = gpgme_data_new_from_file (&in, cert_2, 1);
182   fail_if_err (err);
183
184   err = gpgme_op_import (ctx, in);
185   fail_if_err (err);
186   result = gpgme_op_import_result (ctx);
187   check_result (result, "2C8F3C356AB761CB3674835B792CDA52937F9285", 2);
188   gpgme_data_release (in);
189
190   gpgme_release (ctx);
191   return 0;
192 }