Bug 485564 - Workspace build fails on Neon developer version when trying to build gpgme
Summary: Workspace build fails on Neon developer version when trying to build gpgme
Status: ASSIGNED
Alias: None
Product: kdesrc-build
Classification: Developer tools
Component: general (show other bugs)
Version: Git
Platform: Neon Linux
: NOR normal
Target Milestone: ---
Assignee: Michael Pyne
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2024-04-14 22:02 UTC by Nathan Misner
Modified: 2024-08-31 20:07 UTC (History)
6 users (show)

See Also:
Latest Commit:
Version Fixed In:
Sentry Crash Report:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Nathan Misner 2024-04-14 22:02:36 UTC
This is on the latest commit of kdesrc-build (87cdf784) and a fully updated copy of Neon developer version.
When the build process gets to custom-qt6-libs, it pulls a version of gpgme from upstream. When it tries to build gpgme, the build fails with this error: 

/home/nathan/kde/src/gpgme/lang/cpp/src/editinteractor.cpp:299:32: error: 'GPG_ERR_NO_RESET_CODE' was not declared in this scope; did you mean 'GPG_ERR_NO_USER_ID'?
  299 |         return Error::fromCode(GPG_ERR_NO_RESET_CODE);
      |                                ^~~~~~~~~~~~~~~~~~~~~
      |                                GPG_ERR_NO_USER_ID

It looks like gpgme depends on another package, libgpg-error-dev, and that gpgme recently got an update that relies on new error codes that were added to that package. It may also require new versions of the other GnuPG stuff, I didn't check.
Comment 1 Malte S. Stretz 2024-04-16 15:45:03 UTC
This still happens on Neon user edition. For me it fails in

> Building gpgme from custom-qt6-libs (19/43)
>         Fetching remote changes to gpgme
>         Merging gpgme changes from branch master
>         No changes to gpgme source code, but proceeding to build anyway.
>         Compiling... failed (after 20 seconds)

I checked https://invent.kde.org/sysadmin/repo-metadata/-/blob/master/module-definitions/custom-qt6-libs.ksb?ref_type=heads and it does define an "option" libgpg-error.

But when I look into the src directory I only see the gpgme directory, not the libgpg-error so it is never checked out?

Maybe because the libgpgme11-dev package which probably pulls in libgpg-error-dev as well is installed via  https://invent.kde.org/sysadmin/repo-metadata/-/blob/master/distro-dependencies/debian.ini?ref_type=heads?
Comment 2 Malte S. Stretz 2024-04-17 07:05:37 UTC
Ok, I found the issue: There is no dependency at all defined between gpgme and libgpg-error. So the latter is never build (except for Qt I guess) and as long as the system headers match the gpgme package nobody notices.

I worked around it via this command:
echo 'third-party/gpgme: third-party/libgpg-error' >> ~/.local/state/sysadmin-repo-metadata/dependencies/dependency-data-kf6-qt6

Not sure how this should be fixed properly, maybe in https://invent.kde.org/nicolasfella/dependency-generator?

The quickest fix would probably if third-party/libgpg-error was added as a dependency to https://invent.kde.org/frameworks/kwallet/-/blob/master/.kde-ci.yml since kwallet is the only app which depends on gpgme according to the dependencies file.
Comment 3 Bug Janitor Service 2024-05-04 23:40:01 UTC
A possibly relevant merge request was started @ https://invent.kde.org/frameworks/kwallet/-/merge_requests/82
Comment 4 AceLan Kao 2024-05-06 07:31:01 UTC
I still can't pass the build with the fix, is there anything I should do after switch to your tree?

acelan@acelan-precision5470:~/kde/src/kwallet git:(add_libgpg-error_dependency*) $ git show
commit 111c7693c641b4ce7912c462abfd0c5b40d4bcba (HEAD -> add_libgpg-error_dependency, origin/add_libgpg-error_dependency)
Author: Nathan Misner <nathan@infochunk.com>
Date:   Sat May 4 18:25:33 2024 -0500

    CI: Add libgpg-error as a dependency
    
    Depending on gpgme but not libgpg-error makes kdesrc-build fail if the
    libgpg-error headers shipped by your distro are older than the version
    required by upstream gpgme.
    
    BUG: 485564

diff --git a/.kde-ci.yml b/.kde-ci.yml
index 16690708..5f7e0030 100644
--- a/.kde-ci.yml
+++ b/.kde-ci.yml
@@ -13,6 +13,7 @@ Dependencies:
     'frameworks/kwidgetsaddons' : '@same'
     'libraries/qca': '@latest'
     'third-party/gpgme' : '@same'
+    'third-party/libgpg-error' : '@same'
 
 Options:
   test-before-installing: True

Got the identical error

Building gpgme from custom-qt6-libs (15/21)
        Fetching remote changes to gpgme
        Merging gpgme changes from branch master
        No changes to gpgme source code, but proceeding to build anyway.
        Compiling... failed (after 4 seconds)

gpgme didn't build, stopping here.
Comment 5 Ingo Klöcker 2024-05-16 09:47:23 UTC
Just a heads-up: I have raised the required version of libgpg-error in gpgme to 1.47 (which added the new error code). No idea how to get kdesrc-build/kde-builder to build libgpg-error. Maybe it relies on the version provided by your distribution.
Comment 6 Malte S. Stretz 2024-05-16 11:51:20 UTC
This is my workaround:

echo 'third-party/gpgme: third-party/libgpg-error' >> ~/.local/state/sysadmin-repo-metadata/dependencies/dependency-data-kf6-qt6

I think this shouldn't be required anymore but that tool from Nicolas Fella has to be run to update the dependencies from the CI data. Maybe that was done already; if it still doesn't work (I didn't check, my workaround works for me) I guess there is a bug in that tool. Since it is written in rust I didn't want to dive into that topic.
Comment 7 Malte S. Stretz 2024-05-16 11:55:18 UTC
Hmmm... the posted commit added the dependency to kwallet. But I think it is required earlier in the build chain so if Nicolas' tool was run maybe it is still broken because it isn't pulled in early enough. Or due to the dependency ordering third-party/libgpg-error is built after third-party/gpgme since the former is no dep on the latter but on kwallet.

IMO the cleanest solution would be to define the dep like I did in my workaround but that would probably require some change in Nicolas' tool.
Comment 8 Andrew Shark 2024-08-31 20:07:50 UTC
> Since it is written in rust I didn't want to dive into that topic.

I have rewritten it in Python, it is resided in the sysadmin/repo-metadata repo.

> I worked around it via this command:
> echo 'third-party/gpgme: third-party/libgpg-error' >> ~/.local/state/sysadmin-repo-metadata/dependencies/dependency-data-kf6-qt6

Correct, this will be the current workaround.

For the proper resolving, I think I should have separate dependencies/module-definitions files for kde-builder, and implementing it there.