Blame tests/gpg/t-keylist-sig.c

Packit d7e8d0
/* t-keylist-sig.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
struct
Packit d7e8d0
{
Packit d7e8d0
  const char *fpr;
Packit d7e8d0
  const char *sec_keyid;
Packit d7e8d0
  struct
Packit d7e8d0
  {
Packit d7e8d0
    const char *name;
Packit d7e8d0
    const char *comment;
Packit d7e8d0
    const char *email;
Packit d7e8d0
    struct
Packit d7e8d0
    {
Packit d7e8d0
      gpgme_pubkey_algo_t algo;
Packit d7e8d0
      const char *keyid;
Packit d7e8d0
      const char *name;
Packit d7e8d0
      const char *comment;
Packit d7e8d0
      const char *email;
Packit d7e8d0
      unsigned int sig_class;
Packit d7e8d0
      int exportable;
Packit d7e8d0
    } sig;
Packit d7e8d0
  } uid[3];
Packit d7e8d0
}
Packit d7e8d0
keys[] =
Packit d7e8d0
  {
Packit d7e8d0
    { "A0FF4590BB6122EDEF6E3C542D727CC768697734", "6AE6D7EE46A871F8",
Packit d7e8d0
      { { "Alfa Test", "demo key", "alfa@example.net",
Packit d7e8d0
          { GPGME_PK_DSA, "2D727CC768697734",
Packit d7e8d0
	    "Alfa Test", "demo key", "alfa@example.net", 19, 1 } },
Packit d7e8d0
	{ "Alpha Test", "demo key", "alpha@example.net",
Packit d7e8d0
          { GPGME_PK_DSA, "2D727CC768697734",
Packit d7e8d0
	    "Alfa Test", "demo key", "alfa@example.net", 19, 1 } },
Packit d7e8d0
	{ "Alice", "demo key", NULL,
Packit d7e8d0
          { GPGME_PK_DSA, "2D727CC768697734",
Packit d7e8d0
	    "Alfa Test", "demo key", "alfa@example.net", 19, 1 } } } },
Packit d7e8d0
    { NULL }
Packit d7e8d0
  };
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
int
Packit d7e8d0
main (void)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
  gpgme_ctx_t ctx;
Packit d7e8d0
  gpgme_key_t key;
Packit d7e8d0
  gpgme_keylist_result_t result;
Packit d7e8d0
  int mode;
Packit d7e8d0
  int i = 0;
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
  mode  = gpgme_get_keylist_mode (ctx);
Packit d7e8d0
  mode |= GPGME_KEYLIST_MODE_SIGS;
Packit d7e8d0
  err = gpgme_set_keylist_mode (ctx, mode);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  err = gpgme_op_keylist_start (ctx, "Alpha", 0);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  while (!(err = gpgme_op_keylist_next (ctx, &key)))
Packit d7e8d0
    {
Packit d7e8d0
      if (!keys[i].fpr)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "More keys returned than expected\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      /* Global key flags.  */
Packit d7e8d0
      if (key->revoked)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly revoked\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->expired)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly expired\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->disabled)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly disabled\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->invalid)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly invalid\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->can_encrypt)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly unusable for encryption\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->can_sign)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly unusable for signing\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->can_certify)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly unusable for certifications\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->secret)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly secret\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->protocol != GPGME_PROTOCOL_OpenPGP)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key has unexpected protocol: %s\n",
Packit d7e8d0
		   gpgme_get_protocol_name (key->protocol));
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->issuer_serial)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly carries issuer serial: %s\n",
Packit d7e8d0
		   key->issuer_serial);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->issuer_name)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly carries issuer name: %s\n",
Packit d7e8d0
		   key->issuer_name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->chain_id)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key unexpectedly carries chain ID: %s\n",
Packit d7e8d0
		   key->chain_id);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->owner_trust != GPGME_VALIDITY_UNKNOWN)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key has unexpected owner trust: %i\n",
Packit d7e8d0
		   key->owner_trust);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->subkeys || !key->subkeys->next || key->subkeys->next->next)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key has unexpected number of subkeys\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      /* Primary key.  */
Packit d7e8d0
      if (key->subkeys->revoked)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly revoked\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->expired)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly expired\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->disabled)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly disabled\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->invalid)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly invalid\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->can_encrypt)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly usable for encryption\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->subkeys->can_sign)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly unusable for signing\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->subkeys->can_certify)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly unusable for certifications\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->secret)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly secret\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->pubkey_algo != GPGME_PK_DSA)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key has unexpected public key algo: %s\n",
Packit d7e8d0
		   gpgme_pubkey_algo_name (key->subkeys->pubkey_algo));
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->length != 1024)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key has unexpected length: %i\n",
Packit d7e8d0
		   key->subkeys->length);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (key->subkeys->keyid, &keys[i].fpr[40 - 16]))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key has unexpected key ID: %s\n",
Packit d7e8d0
		   key->subkeys->keyid);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (key->subkeys->fpr, keys[i].fpr))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key has unexpected fingerprint: %s\n",
Packit d7e8d0
		   key->subkeys->fpr);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->expires)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Primary key unexpectedly expires: %lu\n",
Packit d7e8d0
		   key->subkeys->expires);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      /* Secondary key.  */
Packit d7e8d0
      if (key->subkeys->next->revoked)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly revoked\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->expired)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly expired\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->disabled)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly disabled\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->invalid)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly invalid\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->subkeys->next->can_encrypt)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly unusable for encryption\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->can_sign)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly usable for signing\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->can_certify)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly usable for certifications\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->secret)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly secret\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->pubkey_algo != GPGME_PK_ELG_E)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key has unexpected public key algo: %s\n",
Packit d7e8d0
		   gpgme_pubkey_algo_name (key->subkeys->next->pubkey_algo));
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->length != 1024)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key has unexpected length: %i\n",
Packit d7e8d0
		   key->subkeys->next->length);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (key->subkeys->next->keyid, keys[i].sec_keyid))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key has unexpected key ID: %s\n",
Packit d7e8d0
		   key->subkeys->next->keyid);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (!key->subkeys->next->fpr)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key has unexpectedly no fingerprint\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->expires)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary key unexpectedly expires: %lu\n",
Packit d7e8d0
		   key->subkeys->next->expires);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      /* FIXME: The below test will crash if we want to check for a
Packit d7e8d0
	 name, comment or email that doesn't exist in the key's user
Packit d7e8d0
	 IDs.  */
Packit d7e8d0
      if (!((!keys[i].uid[0].name && !key->uids)
Packit d7e8d0
	    || (keys[i].uid[0].name && !keys[i].uid[1].name
Packit d7e8d0
		&& key->uids && !key->uids->next)
Packit d7e8d0
	    || (keys[i].uid[0].name && keys[i].uid[1].name
Packit d7e8d0
		&& !keys[i].uid[2].name
Packit d7e8d0
		&& key->uids && key->uids->next && !key->uids->next->next)
Packit d7e8d0
	    || (keys[i].uid[0].name && keys[i].uid[1].name
Packit d7e8d0
		&& keys[i].uid[2].name
Packit d7e8d0
		&& key->uids && key->uids->next && key->uids->next->next
Packit d7e8d0
		&& !key->uids->next->next->next)))
Packit d7e8d0
	  {
Packit d7e8d0
	    fprintf (stderr, "Key has unexpected number of user IDs\n");
Packit d7e8d0
	    exit (1);
Packit d7e8d0
	  }
Packit d7e8d0
      if (key->uids && key->uids->revoked)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "First user ID unexpectedly revoked\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && key->uids->invalid)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "First user ID unexpectedly invalid\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && key->uids->validity != GPGME_VALIDITY_UNKNOWN)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "First user ID has unexpectedly validity: %i\n",
Packit d7e8d0
		   key->uids->validity);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[0].name
Packit d7e8d0
	  && strcmp (keys[i].uid[0].name, key->uids->name))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected name in first user ID: %s\n",
Packit d7e8d0
		   key->uids->name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[0].comment
Packit d7e8d0
	  && strcmp (keys[i].uid[0].comment, key->uids->comment))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected comment in first user ID: %s\n",
Packit d7e8d0
		   key->uids->comment);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[0].email
Packit d7e8d0
	  && strcmp (keys[i].uid[0].email, key->uids->email))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected email in first user ID: %s\n",
Packit d7e8d0
		   key->uids->email);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && (!key->uids->signatures || key->uids->signatures->next))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "First user ID unexpected number of signatures\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[0].sig.algo != key->uids->signatures->pubkey_algo)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected algorithm in first user ID sig: %s\n",
Packit d7e8d0
		   gpgme_pubkey_algo_name (key->uids->signatures->pubkey_algo));
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[0].sig.keyid, key->uids->signatures->keyid))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected key ID in first user ID sig: %s\n",
Packit d7e8d0
		   key->uids->signatures->keyid);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[0].sig.name, key->uids->signatures->name))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected name in first user ID sig: %s\n",
Packit d7e8d0
		   key->uids->signatures->name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[0].sig.comment, key->uids->signatures->comment))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected comment in first user ID sig: %s\n",
Packit d7e8d0
		   key->uids->signatures->comment);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[0].sig.email, key->uids->signatures->email))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected email in first user ID sig: %s\n",
Packit d7e8d0
		   key->uids->signatures->email);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[0].sig.sig_class != key->uids->signatures->sig_class)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected class in first user ID sig: %i\n",
Packit d7e8d0
		   key->uids->signatures->sig_class);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[0].sig.exportable != key->uids->signatures->exportable)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected exportable stat in first user ID sig: %i\n",
Packit d7e8d0
		   key->uids->signatures->exportable);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      if (key->uids && key->uids->next && key->uids->next->revoked)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Second user ID unexpectedly revoked\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && key->uids->next && key->uids->next->invalid)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Second user ID unexpectedly invalid\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && key->uids->next
Packit d7e8d0
	  && key->uids->next->validity != GPGME_VALIDITY_UNKNOWN)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Second user ID has unexpectedly validity: %i\n",
Packit d7e8d0
		   key->uids->next->validity);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[1].name
Packit d7e8d0
	  && strcmp (keys[i].uid[1].name, key->uids->next->name))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected name in second user ID: %s\n",
Packit d7e8d0
		   key->uids->next->name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[1].comment
Packit d7e8d0
	  && strcmp (keys[i].uid[1].comment, key->uids->next->comment))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected comment in second user ID: %s\n",
Packit d7e8d0
		   key->uids->next->comment);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[1].email
Packit d7e8d0
	  && strcmp (keys[i].uid[1].email, key->uids->next->email))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected email in second user ID: %s\n",
Packit d7e8d0
		   key->uids->next->email);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      /* Note: There is a bug in gpg 1.3.4 which duplicates a
Packit d7e8d0
         signature after importing the secret key.  Thus we disable
Packit d7e8d0
         the second part of the check. */
Packit d7e8d0
      if (key->uids && (!key->uids->next->signatures /*|| key->uids->next->signatures->next*/))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Second user ID unexpected number of signatures\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[1].sig.algo != key->uids->next->signatures->pubkey_algo)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected algorithm in second user ID sig: %s\n",
Packit d7e8d0
		   gpgme_pubkey_algo_name (key->uids->next->signatures->pubkey_algo));
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[1].sig.keyid, key->uids->next->signatures->keyid))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected key ID in second user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->signatures->keyid);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[1].sig.name, key->uids->next->signatures->name))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected name in second user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->signatures->name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[1].sig.comment, key->uids->next->signatures->comment))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected comment in second user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->signatures->comment);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[1].sig.email, key->uids->next->signatures->email))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected email in second user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->signatures->email);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[1].sig.sig_class != key->uids->next->signatures->sig_class)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected class in second user ID sig: %i\n",
Packit d7e8d0
		   key->uids->next->signatures->sig_class);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[1].sig.exportable != key->uids->next->signatures->exportable)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected exportable stat in second user ID sig: %i\n",
Packit d7e8d0
		   key->uids->next->signatures->exportable);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      if (key->uids && key->uids->next && key->uids->next->next
Packit d7e8d0
	  && key->uids->next->next->revoked)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Third user ID unexpectedly revoked\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && key->uids->next && key->uids->next->next
Packit d7e8d0
	  && key->uids->next->next->invalid)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Third user ID unexpectedly invalid\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && key->uids->next && key->uids->next->next
Packit d7e8d0
	  && key->uids->next->next->validity != GPGME_VALIDITY_UNKNOWN)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Third user ID has unexpectedly validity: %i\n",
Packit d7e8d0
		   key->uids->next->next->validity);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[2].name
Packit d7e8d0
	  && strcmp (keys[i].uid[2].name, key->uids->next->next->name))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected name in third user ID: %s\n",
Packit d7e8d0
		   key->uids->next->next->name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[2].comment
Packit d7e8d0
	  && strcmp (keys[i].uid[2].comment, key->uids->next->next->comment))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected comment in third user ID: %s\n",
Packit d7e8d0
		   key->uids->next->next->comment);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[2].email
Packit d7e8d0
	  && strcmp (keys[i].uid[2].email, key->uids->next->next->email))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected email in third user ID: %s\n",
Packit d7e8d0
		   key->uids->next->next->email);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->uids && (!key->uids->next->next->signatures
Packit d7e8d0
			|| key->uids->next->next->signatures->next))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Third user ID unexpected number of signatures\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[2].sig.algo != key->uids->next->next->signatures->pubkey_algo)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected algorithm in third user ID sig: %s\n",
Packit d7e8d0
		   gpgme_pubkey_algo_name (key->uids->next->next->signatures->pubkey_algo));
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[2].sig.keyid, key->uids->next->next->signatures->keyid))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected key ID in third user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->next->signatures->keyid);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[2].sig.name, key->uids->next->next->signatures->name))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected name in third user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->next->signatures->name);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[2].sig.comment, key->uids->next->next->signatures->comment))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected comment in third user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->next->signatures->comment);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (strcmp (keys[i].uid[2].sig.email, key->uids->next->next->signatures->email))
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected email in third user ID sig: %s\n",
Packit d7e8d0
		   key->uids->next->next->signatures->email);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[2].sig.sig_class != key->uids->next->next->signatures->sig_class)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected class in third user ID sig: %i\n",
Packit d7e8d0
		   key->uids->next->next->signatures->sig_class);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (keys[i].uid[2].sig.exportable != key->uids->next->next->signatures->exportable)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Unexpected exportable stat in third user ID sig: %i\n",
Packit d7e8d0
		   key->uids->next->next->signatures->exportable);
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
Packit d7e8d0
      gpgme_key_unref (key);
Packit d7e8d0
      i++;
Packit d7e8d0
    }
Packit d7e8d0
  if (gpgme_err_code (err) != GPG_ERR_EOF)
Packit d7e8d0
    fail_if_err (err);
Packit d7e8d0
  err = gpgme_op_keylist_end (ctx);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  result = gpgme_op_keylist_result (ctx);
Packit d7e8d0
  if (result->truncated)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "Key listing unexpectedly truncated\n");
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  if (keys[i].fpr)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "Less keys returned than expected\n");
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  gpgme_release (ctx);
Packit d7e8d0
  return 0;
Packit d7e8d0
}