diff options
Diffstat (limited to '')
| -rw-r--r-- | tests/gpg/t-file-name.c | 99 | 
1 files changed, 99 insertions, 0 deletions
| diff --git a/tests/gpg/t-file-name.c b/tests/gpg/t-file-name.c new file mode 100644 index 00000000..eb20fc03 --- /dev/null +++ b/tests/gpg/t-file-name.c @@ -0,0 +1,99 @@ +/* t-file-name.c - Regression test. +   Copyright (C) 2000 Werner Koch (dd9jn) +   Copyright (C) 2001, 2002, 2003, 2004 g10 Code GmbH + +   This file is part of GPGME. +  +   GPGME is free software; you can redistribute it and/or modify it +   under the terms of the GNU Lesser General Public License as +   published by the Free Software Foundation; either version 2.1 of +   the License, or (at your option) any later version. +    +   GPGME 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 +   Lesser General Public License for more details. +    +   You should have received a copy of the GNU Lesser General Public +   License along with this program; if not, write to the Free Software +   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA +   02111-1307, USA.  */ + +/* We need to include config.h so that we know whether we are building +   with large file system (LFS) support. */ +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include <stdlib.h> +#include <stdio.h> +#include <string.h> + +#include <gpgme.h> + +#include "t-support.h" + +#define TESTNAME "abcde12345" + + +int  +main (int argc, char *argv[]) +{ +  gpgme_ctx_t ctx; +  gpgme_error_t err; +  gpgme_data_t in, out; +  gpgme_key_t key[2] = { NULL, NULL }; +  gpgme_decrypt_result_t result; +  char *agent_info; + +  init_gpgme (GPGME_PROTOCOL_OpenPGP); +     +  err = gpgme_new (&ctx); +  fail_if_err (err); +  gpgme_set_armor (ctx, 1); + +  agent_info = getenv("GPG_AGENT_INFO"); +  if (!(agent_info && strchr (agent_info, ':'))) +    gpgme_set_passphrase_cb (ctx, passphrase_cb, NULL); + +  err = gpgme_data_new_from_mem (&in, "Hallo Leute\n", 12, 0); +  fail_if_err (err); + +  err = gpgme_data_set_file_name (in, TESTNAME); +  fail_if_err (err); + +  err = gpgme_data_new (&out); +  fail_if_err (err); + +  err = gpgme_get_key (ctx, "A0FF4590BB6122EDEF6E3C542D727CC768697734", +		       &key[0], 0); +  fail_if_err (err); + +  err = gpgme_op_encrypt (ctx, key, GPGME_ENCRYPT_ALWAYS_TRUST, in, out); +  fail_if_err (err); + +  gpgme_data_release (in); +  err = gpgme_data_new (&in); +  fail_if_err (err); + +  err = gpgme_data_seek (out, 0, SEEK_SET); +  fail_if_err (err); + +  err = gpgme_op_decrypt (ctx, out, in); +  fail_if_err (err); +  result = gpgme_op_decrypt_result (ctx); + +  if (strcmp (TESTNAME, result->file_name)) +    { +      fprintf (stderr, "%s:%i: Unexpected result file name: %s\n", +               __FILE__, __LINE__, +	       result->file_name ? "(null)" : result->file_name); +      exit (1); +    } + +  gpgme_key_unref (key[0]); +  gpgme_data_release (in); +  gpgme_data_release (out); +  gpgme_release (ctx); +  return 0; +} | 
