gpgme (5 files)

cvs user marcus cvs at cvs.gnupg.org
Fri Jun 3 00:38:28 CEST 2005


    Date: Friday, June 3, 2005 @ 00:59:41
  Author: marcus
    Path: /cvs/gpgme/gpgme

   Added: tests/gpg/t-wait.c
Modified: gpgme/ChangeLog gpgme/wait-global.c tests/ChangeLog
          tests/gpg/Makefile.am

gpgme/
2005-06-03  Marcus Brinkmann  <marcus at g10code.de>

	* wait-global.c (gpgme_wait): Break out of the fd processing loop
	after an error.
	Reported by Igor Belyi <gpgme at katehok.ac93.org>.

tests/
2005-06-03  Marcus Brinkmann  <marcus at g10code.de>

	* gpg/Makefile.am (TESTS): Add t-wait.
	* gpg/t-wait.c (main): New test.


-----------------------+
 gpgme/ChangeLog       |    6 ++++
 gpgme/wait-global.c   |    5 +++
 tests/ChangeLog       |    5 +++
 tests/gpg/Makefile.am |    4 +-
 tests/gpg/t-wait.c    |   72 ++++++++++++++++++++++++++++++++++++++++++++++++
 5 files changed, 90 insertions(+), 2 deletions(-)


Index: gpgme/gpgme/ChangeLog
diff -u gpgme/gpgme/ChangeLog:1.404 gpgme/gpgme/ChangeLog:1.405
--- gpgme/gpgme/ChangeLog:1.404	Thu Jun  2 23:59:34 2005
+++ gpgme/gpgme/ChangeLog	Fri Jun  3 00:59:41 2005
@@ -1,3 +1,9 @@
+2005-06-03  Marcus Brinkmann  <marcus at g10code.de>
+
+	* wait-global.c (gpgme_wait): Break out of the fd processing loop
+	after an error.
+	Reported by Igor Belyi <gpgme at katehok.ac93.org>.
+
 2005-06-02  Marcus Brinkmann  <marcus at g10code.de>
 
 	* wait.h (_gpgme_run_io_cb): New prototype.
Index: gpgme/gpgme/wait-global.c
diff -u gpgme/gpgme/wait-global.c:1.16 gpgme/gpgme/wait-global.c:1.17
--- gpgme/gpgme/wait-global.c:1.16	Thu Jun  2 23:59:34 2005
+++ gpgme/gpgme/wait-global.c	Fri Jun  3 00:59:41 2005
@@ -322,6 +322,11 @@
 		      _gpgme_io_close (ictx->fdt.fds[idx].fd);
 		  _gpgme_engine_io_event (ictx->engine, GPGME_EVENT_DONE,
 					  &err);
+
+		  /* Break out of the loop, and retry the select()
+		     from scratch, because now all fds should be
+		     gone.  */
+		  break;
 		}
 	    }
 	}
Index: gpgme/tests/ChangeLog
diff -u gpgme/tests/ChangeLog:1.101 gpgme/tests/ChangeLog:1.102
--- gpgme/tests/ChangeLog:1.101	Tue Dec  7 22:13:39 2004
+++ gpgme/tests/ChangeLog	Fri Jun  3 00:59:41 2005
@@ -1,3 +1,8 @@
+2005-06-03  Marcus Brinkmann  <marcus at g10code.de>
+
+	* gpg/Makefile.am (TESTS): Add t-wait.
+	* gpg/t-wait.c (main): New test.
+
 2004-12-07  Marcus Brinkmann  <marcus at g10code.de>
 
 	* gpg/mkdemodirs: Add copyright notice.
Index: gpgme/tests/gpg/Makefile.am
diff -u gpgme/tests/gpg/Makefile.am:1.20 gpgme/tests/gpg/Makefile.am:1.21
--- gpgme/tests/gpg/Makefile.am:1.20	Tue Dec  7 22:13:39 2004
+++ gpgme/tests/gpg/Makefile.am	Fri Jun  3 00:59:41 2005
@@ -1,5 +1,5 @@
 # Copyright (C) 2000 Werner Koch (dd9jn)
-# Copyright (C) 2001, 2004 g10 Code GmbH
+# Copyright (C) 2001, 2004, 2005 g10 Code GmbH
 # 
 # This file is part of GPGME.
 # 
@@ -28,7 +28,7 @@
 TESTS = t-encrypt t-encrypt-sym t-encrypt-sign t-sign t-signers	\
 	t-decrypt t-verify t-decrypt-verify \
 	t-export t-import t-trustlist t-eventloop t-edit \
-	t-keylist t-keylist-sig t-thread1
+	t-keylist t-keylist-sig t-thread1 t-wait
 
 CLEANFILES = secring.gpg pubring.gpg trustdb.gpg
 DISTCLEANFILES = pubring.gpg~ random_seed
Index: gpgme/tests/gpg/t-wait.c
diff -u /dev/null gpgme/tests/gpg/t-wait.c:1.1
--- /dev/null	Fri Jun  3 00:59:41 2005
+++ gpgme/tests/gpg/t-wait.c	Fri Jun  3 00:59:41 2005
@@ -0,0 +1,72 @@
+/* t-wait.c - Regression test.
+   Copyright (C) 2000 Werner Koch (dd9jn)
+   Copyright (C) 2001, 2002, 2003, 2004, 2005 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"
+
+
+int 
+main (int argc, char *argv[])
+{
+  gpgme_ctx_t ctx;
+  gpgme_error_t err;
+  gpgme_data_t sig, text;
+
+  init_gpgme (GPGME_PROTOCOL_OpenPGP);
+
+  err = gpgme_new (&ctx);
+  fail_if_err (err);
+
+  /* Checking a message without a signature.  */
+  err = gpgme_data_new_from_mem (&sig, "foo\n", 4, 0);
+  fail_if_err (err);
+  err = gpgme_data_new (&text);
+  fail_if_err (err);
+  err = gpgme_op_verify_start (ctx, sig, NULL, text);
+  fail_if_err (err);
+
+  while (gpgme_wait (ctx, &err, 0) == NULL && err == 0)
+    sleep(1);
+
+  if (gpg_err_code (err) != GPG_ERR_NO_DATA)
+    {
+      fprintf (stderr, "%s:%d: %s: %s\n",
+	       __FILE__, __LINE__, gpgme_strsource (err),
+	       gpgme_strerror (err));
+      exit (1);
+    }
+
+  gpgme_data_release (sig);
+  gpgme_data_release (text);
+  gpgme_release (ctx);
+  return 0;
+}




More information about the Gnupg-commits mailing list