[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra
From: |
Leo Famulari |
Subject: |
bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra |
Date: |
Fri, 12 Feb 2016 19:12:40 -0500 |
User-agent: |
Mutt/1.5.24 (2015-08-30) |
On Fri, Feb 12, 2016 at 06:22:46PM -0500, Mark H Weaver wrote:
> address@hidden (Ludovic Courtès) writes:
>
> > Eric Bavier <address@hidden> skribis:
> >
> >>> > * With 14 test failures. This happened at least twice, on
> >>> > hydra.gnunet.org.
> >>>
> >>> Eric Bavier reported on #guix that it failed to build on his machine
> >>> twice in a row, with 14 test failures.
> >>
> >> I used 'git bisect' on the gnupg repository to narrow the failures
> >> down. Commit ee87c653bf is the commit that introduces the failures.
> >
> > Thanks for digging! Could you report it upstream?
>
> I reported it upstream, and now they have a fix in their repo.
> I've attached a patch to Guix which adds this upstream patch.
>
> Eric, would you be willing to test it and see if it fixes the problem
> for you?
I'm not Eric, but with this patch, I can successfully build on the
machine that was previously exhibiting the failures.
>
> Mark
>
> From bd025179efca777678f39a782f851e07719db05f Mon Sep 17 00:00:00 2001
> From: Mark H Weaver <address@hidden>
> Date: Fri, 12 Feb 2016 18:19:05 -0500
> Subject: [PATCH] gnu: gnupg: Add upstream fix for test failures on x86_64.
>
> Fixes <https://debbugs.gnu.org/22558>.
>
> * gnu/packages/patches/gnupg-simple-query-ignore-status-messages.patch: New
> file.
> * gnu-system.am (dist_patch_DATA): Add it.
> * gnu/packages/gnupg.scm (gnupg)[source]: Add patch.
> ---
> gnu-system.am | 1 +
> gnu/packages/gnupg.scm | 7 +-
> ...gnupg-simple-query-ignore-status-messages.patch | 142
> +++++++++++++++++++++
> 3 files changed, 148 insertions(+), 2 deletions(-)
> create mode 100644
> gnu/packages/patches/gnupg-simple-query-ignore-status-messages.patch
>
> diff --git a/gnu-system.am b/gnu-system.am
> index 9a2988c..3a47e00 100644
> --- a/gnu-system.am
> +++ b/gnu-system.am
> @@ -506,6 +506,7 @@ dist_patch_DATA =
> \
> gnu/packages/patches/gmp-arm-asm-nothumb.patch \
> gnu/packages/patches/gmp-faulty-test.patch \
> gnu/packages/patches/gnucash-price-quotes-perl.patch \
> + gnu/packages/patches/gnupg-simple-query-ignore-status-messages.patch \
> gnu/packages/patches/gobject-introspection-absolute-shlib-path.patch \
> gnu/packages/patches/gobject-introspection-cc.patch \
> gnu/packages/patches/gobject-introspection-girepository.patch \
> diff --git a/gnu/packages/gnupg.scm b/gnu/packages/gnupg.scm
> index a35e8fc..6cd37bc 100644
> --- a/gnu/packages/gnupg.scm
> +++ b/gnu/packages/gnupg.scm
> @@ -2,7 +2,7 @@
> ;;; Copyright © 2012, 2013, 2014, 2015 Ludovic Courtès <address@hidden>
> ;;; Copyright © 2013, 2015 Andreas Enge <address@hidden>
> ;;; Copyright © 2014 Eric Bavier <address@hidden>
> -;;; Copyright © 2014, 2015 Mark H Weaver <address@hidden>
> +;;; Copyright © 2014, 2015, 2016 Mark H Weaver <address@hidden>
> ;;; Copyright © 2015 Paul van der Walt <address@hidden>
> ;;; Copyright © 2015, 2016 Efraim Flashner <address@hidden>
> ;;; Copyright © 2016 Christopher Allan Webber <address@hidden>
> @@ -206,7 +206,10 @@ compatible to GNU Pth.")
> ".tar.bz2"))
> (sha256
> (base32
> - "06mn2viiwsyq991arh5i5fhr9jyxq2bi0jkdj7ndfisxihngpc5p"))))
> + "06mn2viiwsyq991arh5i5fhr9jyxq2bi0jkdj7ndfisxihngpc5p"))
> + (patches
> + (list (search-patch
> + "gnupg-simple-query-ignore-status-messages.patch")))))
> (build-system gnu-build-system)
> (native-inputs
> `(("pkg-config" ,pkg-config)))
> diff --git
> a/gnu/packages/patches/gnupg-simple-query-ignore-status-messages.patch
> b/gnu/packages/patches/gnupg-simple-query-ignore-status-messages.patch
> new file mode 100644
> index 0000000..153f71c
> --- /dev/null
> +++ b/gnu/packages/patches/gnupg-simple-query-ignore-status-messages.patch
> @@ -0,0 +1,142 @@
> +Copied from upstream:
> +http://git.gnupg.org/cgi-bin/gitweb.cgi?p=gnupg.git;a=commitdiff;h=acac103ba5772ae738ce5409d17feab80596cde6
> +
> +Fixes: https://debbugs.gnu.org/22558
> +Upstream bug: https://bugs.gnupg.org/gnupg/issue2229
> +
> +From acac103ba5772ae738ce5409d17feab80596cde6 Mon Sep 17 00:00:00 2001
> +From: "Neal H. Walfield" <address@hidden>
> +Date: Fri, 12 Feb 2016 22:12:21 +0100
> +Subject: [PATCH] common: Change simple_query to ignore status messages.
> +
> +* common/simple-pwquery.c (simple_query): Ignore status messages.
> +
> +--
> +Signed-off-by: Neal H. Walfield <address@hidden>
> +GnuPG-bug-id: 2229
> +---
> + common/simple-pwquery.c | 95
> ++++++++++++++++++++++++++++++++++---------------
> + 1 file changed, 67 insertions(+), 28 deletions(-)
> +
> +diff --git a/common/simple-pwquery.c b/common/simple-pwquery.c
> +index 90d04c0..b2d666c 100644
> +--- a/common/simple-pwquery.c
> ++++ b/common/simple-pwquery.c
> +@@ -618,6 +618,7 @@ simple_query (const char *query)
> + int fd = -1;
> + int nread;
> + char response[500];
> ++ int have = 0;
> + int rc;
> +
> + rc = agent_open (&fd);
> +@@ -628,40 +629,78 @@ simple_query (const char *query)
> + if (rc)
> + goto leave;
> +
> +- /* get response */
> +- nread = readline (fd, response, 499);
> +- if (nread < 0)
> +- {
> +- rc = -nread;
> +- goto leave;
> +- }
> +- if (nread < 3)
> ++ while (1)
> + {
> +- rc = SPWQ_PROTOCOL_ERROR;
> +- goto leave;
> +- }
> ++ if (! have || ! strchr (response, '\n'))
> ++ /* get response */
> ++ {
> ++ nread = readline (fd, &response[have],
> ++ sizeof (response) - 1 /* NUL */ - have);
> ++ if (nread < 0)
> ++ {
> ++ rc = -nread;
> ++ goto leave;
> ++ }
> ++ have += nread;
> ++ if (have < 3)
> ++ {
> ++ rc = SPWQ_PROTOCOL_ERROR;
> ++ goto leave;
> ++ }
> ++ response[have] = 0;
> ++ }
> +
> +- if (response[0] == 'O' && response[1] == 'K')
> +- /* OK, do nothing. */;
> +- else if ((nread > 7 && !memcmp (response, "ERR 111", 7)
> +- && (response[7] == ' ' || response[7] == '\n') )
> +- || ((nread > 4 && !memcmp (response, "ERR ", 4)
> +- && (strtoul (response+4, NULL, 0) & 0xffff) == 99)) )
> +- {
> +- /* 111 is the old Assuan code for canceled which might still
> +- be in use by old installations. 99 is GPG_ERR_CANCELED as
> +- used by modern gpg-agents; 0xffff is used to mask out the
> +- error source. */
> ++ if (response[0] == 'O' && response[1] == 'K')
> ++ /* OK, do nothing. */;
> ++ else if ((nread > 7 && !memcmp (response, "ERR 111", 7)
> ++ && (response[7] == ' ' || response[7] == '\n') )
> ++ || ((nread > 4 && !memcmp (response, "ERR ", 4)
> ++ && (strtoul (response+4, NULL, 0) & 0xffff) == 99)) )
> ++ {
> ++ /* 111 is the old Assuan code for canceled which might still
> ++ be in use by old installations. 99 is GPG_ERR_CANCELED as
> ++ used by modern gpg-agents; 0xffff is used to mask out the
> ++ error source. */
> + #ifdef SPWQ_USE_LOGGING
> +- log_info (_("canceled by user\n") );
> ++ log_info (_("canceled by user\n") );
> + #endif
> +- }
> +- else
> +- {
> ++ }
> ++ else if (response[0] == 'S' && response[1] == ' ')
> ++ {
> ++ char *nextline;
> ++ int consumed;
> ++
> ++ nextline = strchr (response, '\n');
> ++ if (! nextline)
> ++ /* Point to the NUL. */
> ++ nextline = &response[have];
> ++ else
> ++ /* Move past the \n. */
> ++ nextline ++;
> ++
> ++ consumed = (size_t) nextline - (size_t) response;
> ++
> ++ /* Skip any additional newlines. */
> ++ while (consumed < have && response[consumed] == '\n')
> ++ consumed ++;
> ++
> ++ have -= consumed;
> ++
> ++ if (have)
> ++ memmove (response, &response[consumed], have + 1);
> ++
> ++ continue;
> ++ }
> ++ else
> ++ {
> + #ifdef SPWQ_USE_LOGGING
> +- log_error (_("problem with the agent\n"));
> ++ log_error (_("problem with the agent (unexpected response
> \"%s\"\n"),
> ++ response);
> + #endif
> +- rc = SPWQ_ERR_RESPONSE;
> ++ rc = SPWQ_ERR_RESPONSE;
> ++ }
> ++
> ++ break;
> + }
> +
> + leave:
> +--
> +2.6.3
> +
> --
> 2.6.3
>
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Mark H Weaver, 2016/02/04
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Eric Bavier, 2016/02/05
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Leo Famulari, 2016/02/05
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Ludovic Courtès, 2016/02/07
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Mark H Weaver, 2016/02/12
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra,
Leo Famulari <=
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Mark H Weaver, 2016/02/12
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Eric Bavier, 2016/02/12
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Leo Famulari, 2016/02/13
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Leo Famulari, 2016/02/13
- bug#22558: gnupg-2.1.11 on x86_64 failed its tests many times on Hydra, Mark H Weaver, 2016/02/13