gpgme-1-0-branch gpgme (5 files)
cvs user marcus
cvs at cvs.gnupg.org
Fri Jun 3 00:48:41 CEST 2005
Date: Friday, June 3, 2005 @ 01:09:54
Author: marcus
Path: /cvs/gpgme/gpgme
Tag: gpgme-1-0-branch
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.386.2.6 gpgme/gpgme/ChangeLog:1.386.2.7
--- gpgme/gpgme/ChangeLog:1.386.2.6 Fri Jun 3 00:05:32 2005
+++ gpgme/gpgme/ChangeLog Fri Jun 3 01:09:54 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.10.2.3 gpgme/gpgme/wait-global.c:1.10.2.4
--- gpgme/gpgme/wait-global.c:1.10.2.3 Fri Jun 3 00:05:32 2005
+++ gpgme/gpgme/wait-global.c Fri Jun 3 01:09:54 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.100.2.1 gpgme/tests/ChangeLog:1.100.2.2
--- gpgme/tests/ChangeLog:1.100.2.1 Tue Dec 7 22:11:53 2004
+++ gpgme/tests/ChangeLog Fri Jun 3 01:09:54 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.19.2.1 gpgme/tests/gpg/Makefile.am:1.19.2.2
--- gpgme/tests/gpg/Makefile.am:1.19.2.1 Tue Dec 7 22:11:53 2004
+++ gpgme/tests/gpg/Makefile.am Fri Jun 3 01:09:54 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.2.1
--- /dev/null Fri Jun 3 01:09:54 2005
+++ gpgme/tests/gpg/t-wait.c Fri Jun 3 01:09:54 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