doc/
[gpgme.git] / tests / gpg / 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 #include <stdlib.h>
22 #include <stdio.h>
23 #include <string.h>
24
25 #include <gpgme.h>
26
27 #include "t-support.h"
28
29 \f
30 int 
31 main (int argc, char *argv[])
32 {
33   gpgme_ctx_t ctx;
34   gpgme_error_t err;
35   gpgme_data_t in, out;
36   gpgme_key_t key[3] = { NULL, NULL, NULL };
37   gpgme_encrypt_result_t result;
38
39   gpgme_check_version (0);
40
41   err = gpgme_engine_check_version (GPGME_PROTOCOL_OpenPGP);
42   fail_if_err (err);
43     
44   err = gpgme_new (&ctx);
45   fail_if_err (err);
46   gpgme_set_armor (ctx, 1);
47
48   err = gpgme_data_new_from_mem (&in, "Hallo Leute\n", 12, 0);
49   fail_if_err (err);
50
51   err = gpgme_data_new (&out);
52   fail_if_err (err);
53
54   err = gpgme_get_key (ctx, "A0FF4590BB6122EDEF6E3C542D727CC768697734",
55                        &key[0], 0);
56   fail_if_err (err);
57   err = gpgme_get_key (ctx, "D695676BDCEDCC2CDD6152BCFE180B1DA9E3B0B2",
58                        &key[1], 0);
59   fail_if_err (err);
60
61   err = gpgme_op_encrypt (ctx, key, GPGME_ENCRYPT_ALWAYS_TRUST, 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->id);
68       exit (1);
69     }
70   print_data (out);
71
72   gpgme_key_unref (key[0]);
73   gpgme_key_unref (key[1]);
74   gpgme_data_release (in);
75   gpgme_data_release (out);
76   gpgme_release (ctx);
77   return 0;
78 }