Blame tests/gpg/t-keylist.c

Packit d7e8d0
/* t-keylist.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 key_info_s
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
  } uid[3];
Packit d7e8d0
  int n_subkeys;
Packit d7e8d0
  void (*misc_check)(struct key_info_s *keyinfo, gpgme_key_t key);
Packit d7e8d0
};
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
static void check_whisky (struct key_info_s *keyinfo, gpgme_key_t key);
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0

Packit d7e8d0
struct key_info_s keys[] =
Packit d7e8d0
  {
Packit d7e8d0
    { "A0FF4590BB6122EDEF6E3C542D727CC768697734", "6AE6D7EE46A871F8",
Packit d7e8d0
      { { "Alfa Test", "demo key", "alfa@example.net" },
Packit d7e8d0
        { "Alpha Test", "demo key", "alpha@example.net" },
Packit d7e8d0
	{ "Alice", "demo key", NULL } }, 1 },
Packit d7e8d0
    { "D695676BDCEDCC2CDD6152BCFE180B1DA9E3B0B2", "5381EA4EE29BA37F",
Packit d7e8d0
      { { "Bob", "demo key", NULL },
Packit d7e8d0
	{ "Bravo Test", "demo key", "bravo@example.net" } }, 1 },
Packit d7e8d0
    { "61EE841A2A27EB983B3B3C26413F4AF31AFDAB6C", "E71E72ACBC43DA60",
Packit d7e8d0
      { { "Charlie Test", "demo key", "charlie@example.net" } }, 1 },
Packit d7e8d0
    { "6560C59C43D031C54D7C588EEBA9F240EB9DC9E6", "06F22880B0C45424",
Packit d7e8d0
      { { "Delta Test", "demo key", "delta@example.net" } }, 1 },
Packit d7e8d0
    { "3531152DE293E26A07F504BC318C1FAEFAEF6D1B", "B5C79E1A7272144D",
Packit d7e8d0
      { { "Echelon", "demo key", NULL },
Packit d7e8d0
	{ "Echo Test", "demo key", "echo@example.net" },
Packit d7e8d0
	{ "Eve", "demo key", NULL } }, 1 },
Packit d7e8d0
    { "56D33268F7FE693FBB594762D4BF57F37372E243", "0A32EE79EE45198E",
Packit d7e8d0
      { { "Foxtrot Test", "demo key", "foxtrot@example.net" } }, 1 },
Packit d7e8d0
    { "C9C07DCC6621B9FB8D071B1D168410A48FC282E6", "247491CC9DCAD354",
Packit d7e8d0
      { { "Golf Test", "demo key", "golf@example.net" } }, 1 },
Packit d7e8d0
    { "9E91CBB11E4D4135583EF90513DB965534C6E3F1", "76E26537D622AD0A",
Packit d7e8d0
      { { "Hotel Test", "demo key", "hotel@example.net" } }, 1 },
Packit d7e8d0
    { "CD538D6CC9FB3D745ECDA5201FE8FC6F04259677", "C1C8EFDE61F76C73",
Packit d7e8d0
      { { "India Test", "demo key", "india@example.net" } }, 1 },
Packit d7e8d0
    { "F8F1EDC73995AB739AD54B380C820C71D2699313", "BD0B108735F8F136",
Packit d7e8d0
      { { "Juliet Test", "demo key", "juliet@example.net" } }, 1 },
Packit d7e8d0
    { "3FD11083779196C2ECDD9594AD1B0FAD43C2D0C7", "86CBB34A9AF64D02",
Packit d7e8d0
      { { "Kilo Test", "demo key", "kilo@example.net" } }, 1 },
Packit d7e8d0
    { "1DDD28CEF714F5B03B8C246937CAB51FB79103F8", "0363B449FE56350C",
Packit d7e8d0
      { { "Lima Test", "demo key", "lima@example.net" } }, 1 },
Packit d7e8d0
    { "2686AA191A278013992C72EBBE794852BE5CF886", "5F600A834F31EAE8",
Packit d7e8d0
      { { "Mallory", "demo key", NULL },
Packit d7e8d0
	{ "Mike Test", "demo key", "mike@example.net" } }, 1 },
Packit d7e8d0
    { "5AB9D6D7BAA1C95B3BAA3D9425B00FD430CEC684", "4C1D63308B70E472",
Packit d7e8d0
      { { "November Test", "demo key", "november@example.net" } }, 1 },
Packit d7e8d0
    { "43929E89F8F79381678CAE515F6356BA6D9732AC", "FF0785712681619F",
Packit d7e8d0
      { { "Oscar Test", "demo key", "oscar@example.net" } }, 1 },
Packit d7e8d0
    { "6FAA9C201E5E26DCBAEC39FD5D15E01D3FF13206", "2764E18263330D9C",
Packit d7e8d0
      { { "Papa test", "demo key", "papa@example.net" } }, 1 },
Packit d7e8d0
    { "A7969DA1C3297AA96D49843F1C67EC133C661C84", "6CDCFC44A029ACF4",
Packit d7e8d0
      { { "Quebec Test", "demo key", "quebec@example.net" } }, 1 },
Packit d7e8d0
    { "38FBE1E4BF6A5E1242C8F6A13BDBEDB1777FBED3", "9FAB805A11D102EA",
Packit d7e8d0
      { { "Romeo Test", "demo key", "romeo@example.net" } }, 1 },
Packit d7e8d0
    { "045B2334ADD69FC221076841A5E67F7FA3AE3EA1", "93B88B0F0F1B50B4",
Packit d7e8d0
      { { "Sierra Test", "demo key", "sierra@example.net" } }, 1 },
Packit d7e8d0
    { "ECAC774F4EEEB0620767044A58CB9A4C85A81F38", "97B60E01101C0402",
Packit d7e8d0
      { { "Tango Test", "demo key", "tango@example.net" } }, 1 },
Packit d7e8d0
    { "0DBCAD3F08843B9557C6C4D4A94C0F75653244D6", "93079B915522BDB9",
Packit d7e8d0
      { { "Uniform Test", "demo key", "uniform@example.net" } }, 1 },
Packit d7e8d0
    { "E8143C489C8D41124DC40D0B47AF4B6961F04784", "04071FB807287134",
Packit d7e8d0
      { { "Victor Test", "demo key", "victor@example.org" } }, 1 },
Packit d7e8d0
    { "E8D6C90B683B0982BD557A99DEF0F7B8EC67DBDE", "D7FBB421FD6E27F6",
Packit d7e8d0
      { { "Whisky Test", "demo key", "whisky@example.net" } }, 3,
Packit d7e8d0
          check_whisky },
Packit d7e8d0
    { "04C1DF62EFA0EBB00519B06A8979A6C5567FB34A", "5CC6F87F41E408BE",
Packit d7e8d0
      { { "XRay Test", "demo key", "xray@example.net" } }, 1 },
Packit d7e8d0
    { "ED9B316F78644A58D042655A9EEF34CD4B11B25F", "5ADFD255F7B080AD",
Packit d7e8d0
      { { "Yankee Test", "demo key", "yankee@example.net" } }, 1 },
Packit d7e8d0
    { "23FD347A419429BACCD5E72D6BC4778054ACD246", "EF9DC276A172C881",
Packit d7e8d0
      { { "Zulu Test", "demo key", "zulu@example.net" } }, 1 },
Packit d7e8d0
    { "ADAB7FCC1F4DE2616ECFA402AF82244F9CD9FD55", "087DD7E0381701C4",
Packit d7e8d0
      { { "Joe Random Hacker", "test key with passphrase \"abc\"",
Packit d7e8d0
	  "joe@example.com" } }, 1 },
Packit d7e8d0
    { NULL }
Packit d7e8d0
  };
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
int
Packit d7e8d0
main (int argc, char **argv)
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 i = 0;
Packit d7e8d0
  int n;
Packit d7e8d0
  gpgme_subkey_t subkey;
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
  err = gpgme_op_keylist_start (ctx, NULL, 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 0
Packit d7e8d0
      /* GnuPG 2.1+ have a different subkey for encryption.  */
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
#endif
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
Packit d7e8d0
      for (n=0, subkey = key->subkeys; subkey; subkey = subkey->next)
Packit d7e8d0
        n++;
Packit d7e8d0
      if (!n || n-1 != keys[i].n_subkeys)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Key `%s' has unexpected number of subkeys\n",
Packit d7e8d0
                   keys[i].uid[0].name);
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->is_cardkey)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Public key marked as card key\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->card_number)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Public key with card number set\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 `%s' has unexpected key ID: %s\n",
Packit d7e8d0
		   keys[i].uid[0].name, 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 `%s' unexpectedly expires: %lu\n",
Packit d7e8d0
		   keys[i].uid[0].name, 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->is_cardkey)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary public key marked as card key\n");
Packit d7e8d0
	  exit (1);
Packit d7e8d0
	}
Packit d7e8d0
      if (key->subkeys->next->card_number)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Secondary public key with card number set\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 `%s' has unexpected key ID: %s/%s\n",
Packit d7e8d0
		   keys[i].uid[0].name,
Packit d7e8d0
                   key->subkeys->next->keyid, keys[i].sec_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 (key->uids && key->uids->signatures)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "First user ID unexpectedly signed\n");
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->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 (key->uids && key->uids->next && key->uids->next->signatures)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Second user ID unexpectedly signed\n");
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
      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 (key->uids && key->uids->next && key->uids->next->next
Packit d7e8d0
	  && key->uids->next->next->signatures)
Packit d7e8d0
	{
Packit d7e8d0
	  fprintf (stderr, "Third user ID unexpectedly signed\n");
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
Packit d7e8d0
      if (keys[i].misc_check)
Packit d7e8d0
        keys[i].misc_check (keys+i, key);
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 (%d) returned than expected (%d)\n",
Packit d7e8d0
	       i, (int)(DIM (keys) - 1));
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  gpgme_release (ctx);
Packit d7e8d0
  return 0;
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
/* Check expration of keys.  This test assumes three subkeys of which
Packit d7e8d0
   2 are expired; it is used with the "Whisky" test key.  It has
Packit d7e8d0
   already been checked that these 3 subkeys are available. */
Packit d7e8d0
static void
Packit d7e8d0
check_whisky (struct key_info_s *keyinfo, gpgme_key_t key)
Packit d7e8d0
{
Packit d7e8d0
  const char *name = keyinfo->uid[0].name;
Packit d7e8d0
  gpgme_subkey_t sub1, sub2;
Packit d7e8d0
Packit d7e8d0
  sub1 = key->subkeys->next->next;
Packit d7e8d0
  sub2 = sub1->next;
Packit d7e8d0
Packit d7e8d0
  if (!sub1->expired || !sub2->expired)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "Subkey of `%s' not flagged as expired\n", name);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
  if (sub1->expires != 1129636886 || sub2->expires != 1129636939)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "Subkey of `%s' has wrong expiration date\n", name);
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
}
Packit d7e8d0