diff options
| author | Werner Koch <[email protected]> | 2001-01-08 20:40:25 +0000 | 
|---|---|---|
| committer | Werner Koch <[email protected]> | 2001-01-08 20:40:25 +0000 | 
| commit | d6cd1f97cab9cbb08560825444c1f848ac45f840 (patch) | |
| tree | d878d785f249a37771db47507e0dbc64c8145502 /tests | |
| parent | Add 2 missing files and other changes (diff) | |
| download | gpgme-d6cd1f97cab9cbb08560825444c1f848ac45f840.tar.gz gpgme-d6cd1f97cab9cbb08560825444c1f848ac45f840.zip | |
More changes and and some new functions
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/Makefile.am | 3 | ||||
| -rw-r--r-- | tests/t-keylist.c | 22 | ||||
| -rw-r--r-- | tests/t-trustlist.c | 89 | 
3 files changed, 112 insertions, 2 deletions
| diff --git a/tests/Makefile.am b/tests/Makefile.am index de7a0456..27482bb8 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -2,7 +2,8 @@  TESTS_ENVIRONMENT = GNUPGHOME=.  -TESTS = t-encrypt t-sign t-decrypt t-verify t-keylist t-export t-import  +TESTS = t-encrypt t-sign t-decrypt t-verify t-keylist t-export t-import \ +	t-trustlist  EXTRA_DIST = mkdemodirs pubdemo.asc secdemo.asc cipher-1.asc geheim.txt \ diff --git a/tests/t-keylist.c b/tests/t-keylist.c index e07da463..d17c8da3 100644 --- a/tests/t-keylist.c +++ b/tests/t-keylist.c @@ -42,12 +42,32 @@ doit ( GpgmeCtx ctx, const char *pattern )      while ( !(err = gpgme_op_keylist_next ( ctx, &key )) ) {          char *p; +        const char *s; +        int i; +          printf ("<!-- Begin key object (%p) -->\n", key );          p = gpgme_key_get_as_xml ( key ); -        if ( p ) +        if ( p ) {              fputs ( p, stdout ); +            free (p); +        }          else              fputs("<!-- Ooops: gpgme_key_get_as_xml failed -->\n", stdout ); + +        s = gpgme_key_get_string_attr (key, GPGME_ATTR_KEYID, NULL, 0 ); +        printf ("<!-- keyid=%s -->\n", s ); +        s = gpgme_key_get_string_attr (key, GPGME_ATTR_ALGO, NULL, 0 ); +        printf ("<!-- algo=%s -->\n", s ); +        for (i=0; ; i++ ) { +            s = gpgme_key_get_string_attr (key, GPGME_ATTR_NAME, NULL, i ); +            if (!s) +                break; +            printf ("<!-- name.%d=%s -->\n", i, s ); +            s = gpgme_key_get_string_attr (key, GPGME_ATTR_EMAIL, NULL, i ); +            printf ("<!-- email.%d=%s -->\n", i, s ); +            s = gpgme_key_get_string_attr (key, GPGME_ATTR_COMMENT, NULL, i ); +            printf ("<!-- comment.%d=%s -->\n", i, s ); +        }          printf ("<!-- End key object (%p) -->\n", key );      }      if ( err != GPGME_EOF ) diff --git a/tests/t-trustlist.c b/tests/t-trustlist.c new file mode 100644 index 00000000..ad014869 --- /dev/null +++ b/tests/t-trustlist.c @@ -0,0 +1,89 @@ +/* t-trustlist.c  - regression test + *	Copyright (C) 2000 Werner Koch (dd9jn) + * + * This file is part of GPGME. + * + * GPGME is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 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 General Public License for more details. + * + * You should have received a copy of the GNU 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 + */ + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <assert.h> + +#include "../gpgme/gpgme.h" + +#define fail_if_err(a) do { if(a) {                                       \ +                               fprintf (stderr, "%s:%d: GpgmeError %s\n", \ +                                __FILE__, __LINE__, gpgme_strerror(a));   \ +                                exit (1); }                               \ +                             } while(0) + +static void +doit ( GpgmeCtx ctx, const char *pattern ) +{ +    GpgmeError err; +    GpgmeTrustItem item; + +    err = gpgme_op_trustlist_start (ctx, pattern, 0 ); +    fail_if_err (err); +     +    while ( !(err = gpgme_op_trustlist_next ( ctx, &item )) ) { +        printf ("l=%d k=%s t=%d o=%s v=%s u=%s\n", +        gpgme_trust_item_get_int_attr    (item, GPGME_ATTR_LEVEL, NULL, 0 ), +        gpgme_trust_item_get_string_attr (item, GPGME_ATTR_KEYID, NULL, 0 ), +        gpgme_trust_item_get_int_attr    (item, GPGME_ATTR_TYPE, NULL, 0 ), +        gpgme_trust_item_get_string_attr (item, GPGME_ATTR_OTRUST, NULL, 0 ), +        gpgme_trust_item_get_string_attr (item, GPGME_ATTR_VALIDITY, NULL, 0 ), +        gpgme_trust_item_get_string_attr (item, GPGME_ATTR_USERID, NULL, 0 ) +                ); +        gpgme_trust_item_release (item); +    } +    if ( err != GPGME_EOF ) +        fail_if_err (err); +} + + +int  +main (int argc, char **argv ) +{ +    GpgmeCtx ctx; +    GpgmeError err; +    int loop = 0; +    const char *pattern; +     +    if( argc ) { +        argc--; argv++; +    } +     +    if (argc && !strcmp( *argv, "--loop" ) ) { +        loop = 1; +        argc--; argv++; +    } +    pattern = argc? *argv : NULL; + +    err = gpgme_new (&ctx); +    fail_if_err (err); +    do { +        fprintf (stderr, "** pattern=`%s'\n", pattern ); +        doit ( ctx, pattern ); +    } while ( loop ); +    gpgme_release (ctx); + +    return 0; +} + + + | 
