2004-08-17 Marcus Brinkmann <marcus@g10code.de>
[gpgme.git] / tests / gpgsm / t-encrypt.c
1 /* t-encrypt.c - Regression test.
2    Copyright (C) 2000 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2002, 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 /* We need to include config.h so that we know whether we are building
22    with large file system (LFS) support. */
23 #ifdef HAVE_CONFIG_H
24 #include <config.h>
25 #endif
26
27 #include <stdlib.h>
28 #include <stdio.h>
29 #include <string.h>
30
31 #include <gpgme.h>
32
33 #include "t-support.h"
34
35 int 
36 main (int argc, char **argv)
37 {
38   gpgme_ctx_t ctx;
39   gpgme_error_t err;
40   gpgme_data_t in, out;
41   gpgme_key_t key[] = { NULL, NULL };
42   gpgme_encrypt_result_t result;
43
44   init_gpgme (GPGME_PROTOCOL_CMS);
45
46   err = gpgme_new (&ctx);
47   fail_if_err (err);
48   gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
49   gpgme_set_armor (ctx, 1);
50
51   err = gpgme_data_new_from_mem (&in, "Hallo Leute\n", 12, 0);
52   fail_if_err (err);
53
54   err = gpgme_data_new (&out);
55   fail_if_err (err);
56     
57   err = gpgme_get_key (ctx, "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
58                        &key[0], 0);
59   fail_if_err (err);
60
61   err = gpgme_op_encrypt (ctx, key, 0, in, out);
62   fail_if_err (err);
63   result = gpgme_op_encrypt_result (ctx);
64   if (result->invalid_recipients)
65     {
66       fprintf (stderr, "Invalid recipient encountered: %s\n",
67                result->invalid_recipients->fpr);
68       exit (1);
69     }
70   print_data (out);
71
72   gpgme_key_unref (key[0]);
73   gpgme_data_release (in);
74   gpgme_data_release (out);
75   gpgme_release (ctx);
76   return 0;
77 }