Blame tests/gpg/t-genkey.c

Packit d7e8d0
/* t-genkey.c - Regression test.
Packit d7e8d0
   Copyright (C) 2000 Werner Koch (dd9jn)
Packit d7e8d0
   Copyright (C) 2001, 2003, 2004 g10 Code GmbH
Packit d7e8d0
Packit d7e8d0
   This file is part of GPGME.
Packit d7e8d0
Packit d7e8d0
   GPGME is free software; you can redistribute it and/or modify it
Packit d7e8d0
   under the terms of the GNU Lesser General Public License as
Packit d7e8d0
   published by the Free Software Foundation; either version 2.1 of
Packit d7e8d0
   the License, or (at your option) any later version.
Packit d7e8d0
Packit d7e8d0
   GPGME is distributed in the hope that it will be useful, but
Packit d7e8d0
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit d7e8d0
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit d7e8d0
   Lesser General Public License for more details.
Packit d7e8d0
Packit d7e8d0
   You should have received a copy of the GNU Lesser General Public
Packit d7e8d0
   License along with this program; if not, write to the Free Software
Packit d7e8d0
   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
Packit d7e8d0
   02111-1307, USA.  */
Packit d7e8d0
Packit d7e8d0
/* We need to include config.h so that we know whether we are building
Packit d7e8d0
   with large file system (LFS) support. */
Packit d7e8d0
#ifdef HAVE_CONFIG_H
Packit d7e8d0
#include <config.h>
Packit d7e8d0
#endif
Packit d7e8d0
Packit d7e8d0
#include <stdlib.h>
Packit d7e8d0
#include <stdio.h>
Packit d7e8d0
#include <string.h>
Packit d7e8d0
Packit d7e8d0
#include <gpgme.h>
Packit d7e8d0
Packit d7e8d0
#include "t-support.h"
Packit d7e8d0
Packit d7e8d0

Packit d7e8d0
/* True if progress function printed something on the screen.  */
Packit d7e8d0
static int progress_called;
Packit d7e8d0
Packit d7e8d0
static void
Packit d7e8d0
progress (void *self, const char *what, int type, int current, int total)
Packit d7e8d0
{
Packit d7e8d0
  (void)self;
Packit d7e8d0
Packit d7e8d0
  if (!strcmp (what, "primegen") && !current && !total
Packit d7e8d0
      && (type == '.' || type == '+' || type == '!'
Packit d7e8d0
	  || type == '^' || type == '<' || type == '>'))
Packit d7e8d0
    {
Packit d7e8d0
      printf ("%c", type);
Packit d7e8d0
      fflush (stdout);
Packit d7e8d0
      progress_called = 1;
Packit d7e8d0
    }
Packit d7e8d0
  else
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "unknown progress `%s' %d %d %d\n", what, type,
Packit d7e8d0
	       current, total);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
int
Packit d7e8d0
main (int argc, char **argv)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_ctx_t ctx;
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
  const char *parms = "<GnupgKeyParms format=\"internal\">\n"
Packit d7e8d0
    "Key-Type: DSA\n"
Packit d7e8d0
    "Key-Length: 1024\n"
Packit d7e8d0
    "Subkey-Type: ELG-E\n"
Packit d7e8d0
    "Subkey-Length: 1024\n"
Packit d7e8d0
    "Name-Real: Joe Tester\n"
Packit d7e8d0
    "Name-Comment: (pp=abc)\n"
Packit d7e8d0
    "Name-Email: joe@foo.bar\n"
Packit d7e8d0
    "Expire-Date: 0\n"
Packit d7e8d0
    "Passphrase: abc\n"
Packit d7e8d0
    "</GnupgKeyParms>\n";
Packit d7e8d0
  gpgme_genkey_result_t result;
Packit d7e8d0
Packit d7e8d0
  (void)argc;
Packit d7e8d0
  (void)argv;
Packit d7e8d0
Packit d7e8d0
  init_gpgme (GPGME_PROTOCOL_OpenPGP);
Packit d7e8d0
Packit d7e8d0
  err = gpgme_new (&ctx;;
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  gpgme_set_progress_cb (ctx, progress, NULL);
Packit d7e8d0
Packit d7e8d0
  err = gpgme_op_genkey (ctx, parms, NULL, NULL);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  result = gpgme_op_genkey_result (ctx);
Packit d7e8d0
  if (!result)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%d: gpgme_op_genkey_result returns NULL\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
  if (progress_called)
Packit d7e8d0
    printf ("\n");
Packit d7e8d0
Packit d7e8d0
  printf ("Generated key: %s (%s)\n", result->fpr ? result->fpr : "none",
Packit d7e8d0
	  result->primary ? (result->sub ? "primary, sub" : "primary")
Packit d7e8d0
	  : (result->sub ? "sub" : "none"));
Packit d7e8d0
Packit d7e8d0
  if (result->fpr && strlen (result->fpr) != 40)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%d: generated key has unexpected fingerprint\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
  if (!result->primary)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%d: primary key was not generated\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
  if (!result->sub)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%d: sub key was not generated\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
  gpgme_release (ctx);
Packit d7e8d0
  return 0;
Packit d7e8d0
}