GNU bug report logs - #76503
[GCD] Migrating repositories, issues, and patches to Codeberg

Previous Next

Package: guix-patches;

Reported by: Ludovic Courtès <ludo <at> gnu.org>

Date: Sun, 23 Feb 2025 15:21:02 UTC

Severity: normal

Done: Maxim Cournoyer <maxim.cournoyer <at> gmail.com>

Full log


View this message in rfc822 format

From: Steve George <steve <at> futurile.net>
To: Ludovic Courtès <ludo <at> gnu.org>
Cc: 76503 <at> debbugs.gnu.org, Guix Devel <guix-devel <at> gnu.org>, info-guix <at> gnu.org
Subject: [bug#76503] [GCD] Migrating repositories, issues, and patches to Codeberg
Date: Wed, 7 May 2025 14:36:56 +0100
Hi all,

I collated the results of the voting on GCD 002.

Voting by members:
  - 49 people in the voting pool
  - 33 votes in total
  - 24 Support, 9 Accept
  -  0 Disapprove

Declarations by observers (people not in teams):
  - 7 total declarations
  - 7 Support
  - 0 Accept
  - 0 Disapprove

Voting result:
  - 67% (33 votes) voted to pass the GCD
  -  0% disapproved
  - 33% abstained by not voting

As more than 25% of members voted to pass, and there were no disapprovals this GCD is accepted as final and may now be implemented.

* Please check that I captured **your vote** correctly, the voting tally is here:

  https://codeberg.org/futurile/guix-org/src/branch/master/gcd-voting-summary/gcd002-voting-record.rec

* Voting summary for this GCD is here:

  https://codeberg.org/futurile/guix-org/src/branch/master/gcd-voting-summary/gcd002-voting-summary.md

Hope this is useful!

Steve / Futurile

On 23 Feb, Ludovic Courtès wrote:
> Hello Guix!
> 
> This is the formal submission of “Migrating repositories, issues, and
> patches to Codeberg” (GCD 002), a preliminary draft of which I posted
> before the Guix Days⁰.
> 
> In accordance with the GCD Process, discussion will end on April 23rd at
> the latest.
> 
> I would like to remind everyone that you can try out Codeberg either by
> contributing to one of the Guix-Science repositories¹, or by reviewing
> or making a pull request for a trivial packaging change (and nothing
> more!) in my Guix clone at Codeberg:
> 
>   https://lists.gnu.org/archive/html/guix-devel/2025-02/msg00313.html
> 
> Please do try it especially if you feel reluctant or wonder what the
> workflow would be like.
> 
> Ludo’.
> 
> ⁰ https://lists.gnu.org/archive/html/guix-devel/2025-01/msg00218.html
> ¹ https://codeberg.org/guix-science
> 

> title: Migrating repositories, issues, and patches to Codeberg
> id: 002
> status: submitted
> discussion: https://issues.guix.gnu.org/<number assigned by issue tracker>
> authors: Ludovic Courtès
> sponsors: Tobias Geerinckx-Rice, Ricardo Wurmus
> date-submitted: 2025-02-23
> date: 2025-02-23
> SPDX-License-Identifier: CC-BY-SA-4.0 OR GFDL-1.3-no-invariants-or-later
> ---
> 
> # Summary
> 
> The contribution workflow in Guix has been facing several challenges:
> difficult onboarding, lack of legibility, complex, unreliable, and
> labor-intensive infrastructure, and lack of automation.  All these lead
> to an experience that contributors often find frustrating and hinders
> quality assurance efforts.  We propose to address these limitations by
> migrating repositories, issue tracking, and patch tracking to Codeberg,
> a “modern” forge hosted by a non-profit.
> 
> # Motivation
> 
> To keep track of bug reports and patches, Guix historically chose tools
> that were *simple* in their design:
> 
>   - bug reports and patches can be sent by plain email, without having
>     to create an account or even subscribe to a mailing list;
>   - discussion and patch review happen naturally by email, without
>     requiring special tools;
>   - the Debbugs instance at https://bugs.gnu.org keeps track of bug
>     reports and patches by assigning them an identifier and creating a
>     mailing list specifically for each bug or patch.
> 	
> However, to overcome several limitations, the project developed
> processes and tools, which can be characterized as *incidental
> complexity*:
> 
>   - because the Debbugs web interface is crude by today’s standards and
>     hard to search and navigate, the project developed
>     [mumi](https://git.savannah.gnu.org/cgit/guix/mumi.git/), the web
>     interface running at https://issues.guix.gnu.org;
>   - to navigate bugs and patches more conveniently than what an email
>     client supports, contributors were
>     [encouraged](https://guix.gnu.org/manual/devel/en/html_node/Debbugs-User-Interfaces.html)
>     to use interfaces like `debbugs.el` or `b4`;
>   - sending patch series by email does not play well with Debbugs’
>     automatic identifier assignment, so [contributors were told to send
>     their “cover letter”, wait for an identifier to be assigned, and
>     then send the
>     rest](https://guix.gnu.org/manual/devel/en/html_node/Sending-a-Patch-Series.html#Multiple-Patches-1);
>   - to help sending and applying patch series, mumi was extended to
>     provide a command line interface;
>   - to build patch series submitted by email, the [QA
>     service](https://qa.guix.gnu.org) has to rely on a [Patchwork
>     instance](https://patches.guix-patches.cbaines.net/project/guix-patches/list/)
>     that is subscribed to the `guix-patches` mailing list, coupled with
>     its own [parsing of incoming
>     email](https://git.savannah.gnu.org/gitweb/?p=guix/data-service.git;a=blob;f=guix-data-service/branch-updated-emails.scm;h=aeb1570dfda725864a77780d0541f26c090b0e55;hb=c886685e9284da4bbed9377f70dd70da9e7ca29f);
>   - the project added a commit hook to create add unique `Change-Id`
>     headers in commit messages in an attempt to correlate commits in the
>     repository with messages send to `guix-patches`; none of the
>     existing tools takes advantage of it though, and it is up to
>     contributors to manually close entries in the bug/patch tracker once
>     they have been fixed/applied.
> 
> Developing and maintaining this software and infrastructure is
> time-consuming.  Worse, it leaves contributors largely dissatisfied for
> a variety of reasons:
> 
>   - the process is unfamiliar to most newcomers;
>   - the tools and infrastructure in Guix have become a maze;
>   - apart from the happy few using `debbugs.el` in Emacs, navigating
>     open issues and patches is hard; filtering incoming messages is
>     equally hard, even for those with 10+ years of experience with
>     advanced email tools (Gnus, mu4e, notmuch, b4, etc.);
>   - because the various parts of the development process (repository,
>     issue tracking, QA automation, `etc/teams.scm`) are largely
>     disconnected, even long-time contributors can hardly follow issues
>     relevant to them; issues may remain open after they’ve been fixed,
>     new activity on an issue may go unnoticed, cross-references among
>     issues are not visible in any of the interfaces, etc.
> 
> All this contributes to a [poor
> experience](https://guix.gnu.org/en/blog/2025/guix-user-and-contributor-survey-2024-the-results-part-3/)
> for those who choose to contribute despite the barrier to entry,
> probably discourages many to even start contributing, and adds to the
> load of committers and infrastructure maintainers.
> 
> # Detailed Design
> 
> This section explains the chosen solution among the available options,
> the scope of the proposed migration, a migration path, and an outlook on
> automation.
> 
> ## Choice of a Forge
> 
> We set out to choose a “modern forge” that supports a pull-request style
> workflow and provides good integration between the repository, the issue
> tracker, and the merge request tracker.  Such a system is necessarily
> more *complex* at first glance than the email-based tools we have but
> (1) the increase in complexity is reasonable once we consider the
> incidental complexity of the existing services, as mentioned above, and
> (2) we think the added usage benefits outweigh this increase in
> complexity.
> 
> The software behind the forge has to be free software that is
> *plausibly* self-hosted on Guix System—this probably rules out GitLab
> Community Edition and makes [Forgejo](https://forgejo.org/) the main
> contender.
> 
> [SourceHut](https://sourcehut.org/), the other interesting option, does
> not offer the same convenience when it comes to dealing with patches and
> runs the risk of reproducing onboarding and integration issues
> surrounding an email-based workflow and “read-only” web interface that
> Guix is already experiencing.
> 
> Forgejo has several features to support collaboration among a large
> number of people and on a large code base, including
> [teams](https://docs.codeberg.org/collaborating/create-organization/#teams)
> and [issue and pull request
> templates](https://forgejo.org/docs/latest/user/issue-pull-request-templates/).
> Support for
> [federation](https://forgejo.org/2023-01-10-answering-forgejo-federation-questions/)
> is also under development and is a promising way to avoid
> centralization.
> 
> Instead of self-hosting, this GCD suggests using the Forgejo instance on
> codeberg.org, run by the [Codeberg e.V.](https://codeberg.org/about)
> non-profit, registered in Germany.  The non-profit has a good track
> record of running codeberg.org with minimal downtime, is [committed to
> supporting free software
> development](https://codeberg.org/Codeberg/org/src/branch/main/en/bylaws.md#preamble),
> [transparent](https://codeberg.org/Codeberg/org), and has governance set
> up to achieve its mission.
> 
> The Guix-Science umbrella project [has been using Codeberg for several
> months
> now](https://hpc.guix.info/blog/2025/01/join-the-guix-science-community/),
> which has allowed us to gain confidence in its suitability for a project
> like Guix.
> 
> ## Rights and Privileges
> 
> Migration should preserve rights and privileges regarding access to the
> repositories.  To that end, we propose the following rules:
> 
>   - Committers to several of the repositories listed above and [Savannah
>     “group admins”](https://savannah.gnu.org/projects/guix) can request
>     membership in the [“Owners”
>     team](https://docs.codeberg.org/collaborating/create-organization/#teams)
>     of the [Guix *organization*](https://codeberg.org/guix).  As of this
>     writing, only three people are members.
>   - Anyone listed the `.guix-authorizations` file of Guix can request
>     membership of the https://codeberg.org/guix/guix once it is created.
>   - Committers to one of the other repositories can request membership
>     of that repository.
> 
> In the future, we should extend the [“Commit
> Rights”](https://guix.gnu.org/manual/devel/en/html_node/Commit-Access.html)
> section of the manual to clarify the distinction between being a member
> of the organization and being a member of a specific repository, in a
> specific team.
> 
> ## Repository Migration Path
> 
> The Guix project at Savannah contains the following repositories:
> 
>   - [Guix itself](https://git.savannah.gnu.org/git/guix.git);
>   - [the bootstrappable.org web
>     site](https://git.savannah.gnu.org/git/guix/bootstrappable.git);
>   - [the DHCP client in
>     Guile](https://git.savannah.gnu.org/git/guix/dhcp.git) (forgotten
>     2015 Google Summer of Code project);
>   - [Guile bindings to
>     GNUnet](https://git.savannah.gnu.org/git/guix/gnunet.git) (forgotten
>     2015 Google Summer of Code project);
>   - [Guix artwork and web
>     site](https://git.savannah.gnu.org/git/guix/guix-artwork.git);
>   - [Cuirass](https://git.savannah.gnu.org/git/guix/guix-cuirass.git);
>   - [“maintenance”
>     repository](https://git.savannah.gnu.org/git/guix/maintenance.git)
>     (includes Guix System infrastructure configuration, talks, and other
>     documents);
>   - [scripts for videos presenting
>     Guix](https://git.savannah.gnu.org/git/guix/videos.git);
>   - [Guix Data
>     Service](https://git.savannah.gnu.org/git/guix/data-service.git);
>   - [Emacs-Guix](https://git.savannah.gnu.org/git/guix/emacs-guix.git);
>   - [Guix Build
>     Coordinator](https://git.savannah.gnu.org/git/guix/build-coordinator.git);
>   - [nar-herder](https://git.savannah.gnu.org/git/guix/nar-herder.git);
>   - [QA
>     Frontpage](https://git.savannah.gnu.org/git/guix/qa-frontpage.git);
>   - [mumi](https://git.savannah.gnu.org/cgit/guix/mumi.git);
>   - [Guix Consensus
>     Documents](https://git.savannah.gnu.org/git/guix/guix-consensus-documents.git).
> 	
> Within **30 days** following acceptance of this GCD, committers would
> migrate all these repositories to https://codeberg.org/guix.
> 
> For Guix itself, we would decide on a **flag day** 14 days after
> acceptance of this GCD at the earliest, and 30 days at the latest.  On
> that day, the official URL of the Guix repository would become
> https://codeberg.org/guix/guix.git.  A commit would reflect that by
> updating:
> 
>   1. the `url` field in `.guix-channel`;
>   2. the `%default-channel-url` variable in `(guix channels)`;
>   3. any other reference to the URL that may appear in the repository,
>      in particular in the manual.
>   
> To ease this migration and possibly future migration, we may add a new
> `git.guix.gnu.org` DNS entry with HTTP redirects to
> `git.savannah.gnu.org` (before migration) and `codeberg.org` (after
> migration); a [patch](https://issues.guix.gnu.org/76296) implementing
> this has been submitted.  The `%default-channel-url` variable would
> refer to `https://git.guix.gnu.org/guix.git`.
> 
> Following this commit, an entry in `etc/news.scm` would explain the
> migration.  See [this entry in
> Guix-Science](https://codeberg.org/guix-science/guix-science/commit/fd1b2dacd8d37c9d1939f9dc5a5b74256171ccbd)
> for an example.
> 
> The Savannah `guix.git` repository would become a mirror of the one at
> Codeberg, with a script periodically updating it for **at least one
> year** after the switch, as a way to ease migration to the new
> repository for users.  Other repositories would be deleted from Savannah
> once migrated, to avoid confusion.
> 
> ## Issue Tracker Migration Path
> 
> Importing all the issues and patches from Debbugs/mumi into Codeberg
> would be impractical: it would require the development of specific
> tools, would be a lossy process due to the fundamental mismatch between
> plain text email threads and Forgejo issues and pull requests, and would
> bring little in return.
> 
> Our proposal is the following:
> 
>   - https://issues.guix.gnu.org will remain up and running for at least
>     **two years** following acceptance of this GCD.  Note that once
>     issues.guix.gnu.org is down, issues will remain visible at
>     https://bugs.gnu.org and email archives will remain visible at
>     https://mail.gnu.org.
>   - Within **30 days** after acceptance of this GCD, mailing list
>     administrators will set up the `bug-guix` and `guix-patches` mailing
>     lists in “Emergency Moderation” mode in the Mailman
>     interface—meaning that messages will not get through anymore.  It
>     will still be possible to interact on individual issues via
>     `NNN <at> debbugs.gnu.org`.
>   - The switchover will be advertised before it takes place with a post
>     to `info-guix <at> gnu.org`, to `guix-devel <at> gnu.org`, as well as through
>     a blog post.
>   - The “Contributing” section of the manual will be updated accordingly
>     at that time.
> 	
> ## User Interfaces
> 
> For many contributors, a strength of the email-based workflow is that it
> works out of the browser, possibly offline; we want to preserve that
> comfort as much as possible.
> 
> Everything that can be done through Forgejo’s web interface can be done
> *via* its [HTTP
> interface](https://forgejo.org/docs/latest/user/api-usage/).  This has
> given rise to several Emacs and command-line interfaces that existing
> contributors may find convenient.
> 
> [forgejo-cli](https://codeberg.org/Cyborus/forgejo-cli/) and
> [codeberg-cli](https://codeberg.org/Aviac/codeberg-cli) provide rather
> comprehensive command-line interfaces, as [reported by
> Efraim](https://lists.gnu.org/archive/html/guix-devel/2025-02/msg00057.html).
> 
> [fj.el](https://codeberg.org/martianh/fj.el/) is an Emacs interface
> similar to `mastodon.el` that lets you view and comment on issues and
> pull requests, list repositories, view notifications, and so on.  It
> does not support off-line access.  It can be set up with something like:
> 
> ```lisp
> (with-eval-after-load 'fj
>   (setq fj-host "https://codeberg.org")
>   (setq fj-user "civodul")
>   (setq fj-token
>         (funcall (plist-get
> 		  (car
> 		   (auth-source-search :host "codeberg.org/api/v1"
> 				       :user fj-user
> 				       :type 'netrc))
> 		  :secret))))
> ```
> 
> … and a line like this one to `~/.authinfo.gpg`:
> 
> ```
> machine codeberg.org/api/v1 login civodul password TOKEN
> ```
> 
> … where `TOKEN` is the [token obtained from
> Codeberg](https://docs.codeberg.org/advanced/access-token/).
> 
> [Magit-Forge](https://github.com/magit/forge/) is another Emacs
> interface to forges, with Magit integration and support for working
> off-line.  However, Forgejo support is currently next to nonexistent:
> only `forge-browse` is supported (allowing users to open a browser on a
> forge page).
> 
> Besides these interfaces, there is a couple of tricks that can simplify
> the life of contributors and reviewers, out of the browser.
> 
> As a contributor, you can create pull requests without first creating a
> fork and then a merge request thanks to the [AGit
> workflow](https://forgejo.org/docs/latest/user/agit-support/).  This
> works by passing `git push` the relevant *options*, as in this example:
> 
> ```
> git push origin HEAD:refs/for/main  \
>   -o topic="update-hello" \
>   -o title="gnu: hello: Update to 42." \
>   -o description='This updates the `hello` package."
> ```
> 
> As a reviewer, it is possible to pull references of pending pull
> requests by adding something like this to `.git/config`:
> 
> ```
> [remote "pulls"]
>        url = git <at> codeberg.org:org/guix-science/guix-science.git
>        fetch = +refs/pull/*/head:refs/remotes/pulls/pr/*
> ```
> 
> Running `git fetch pulls` then retrieves references to branches
> corresponding to all the pull requests.
> 
> ## Teams
> 
> All the teams currently defined in `etc/teams.scm` will be reified as
> [teams](https://docs.codeberg.org/collaborating/create-organization/#teams)
> in the [Guix organization](https://codeberg.org/guix).
> 
> All these teams would have read-only access to the repositories, with
> the exception of a new *Committers* team, with read-write access to the
> repository, which would contain all the people who already have [commit
> rights on
> Savannah](https://savannah.gnu.org/project/memberlist.php?group=guix)
> (“on-duty members”).
> 
> Team scopes in `etc/teams.scm` will be converted to a `CODEOWNERS` file
> similar to [that found in
> Guix-Science](https://codeberg.org/guix-science/guix-science/src/branch/master/CODEOWNERS).
> That way, pull requests will automatically have them suggested as
> reviewers for changes in their scope.
> 
> ## Continuous Integration
> 
> Forgejo supports
> [*webhooks*](https://forgejo.org/docs/latest/user/webhooks/), `POST`
> requests that are sent to the server of one’s choice upon events such as
> pull request creation.  Cuirass (running at ci.guix.gnu.org) already
> [supports](https://hpc.guix.info/blog/2025/01/join-the-guix-science-community/)
> them and automatically creates a *jobset* when a pull request is made.
> The [QA frontpage](https://qa.guix.gnu.org) and its [Data
> Service](https://data.qa.guix.gnu.org) does not support Forgejo webhooks
> yet but can be extended to do so without too much effort, possibly
> sharing or reusing the Forgejo interface code from Cuirass.
> 
> In the Guix repository, we will set up webhooks to trigger the creation
> of a new jobset at ci.guix.gnu.org (Cuirass) as soon as migration is
> complete.  While this has been successfully used for several months for
> [Guix-Science](https://codeberg.org/guix-science), scalability will be
> the major concern here; additional developments may be needed to
> consolidate this support.  Eventually the QA frontpage will also support
> those webhooks.
> 
> We will arrange so that the build status of a pull request is clearly
> visible right from that pull request.
> 
> Eventually, the QA service or a [Forgejo
> *action*](https://forgejo.org/docs/latest/user/actions/) may
> automatically provide feedback from `guix lint` as a reply to pull
> requests.
> 
> ## Workflow
> 
> Once continuous integration (CI) is fully operational, pull requests may
> be merged if and only if they successfully built.  “World-rebuild” pull
> requests would still follow the [existing branching
> process](https://guix.gnu.org/manual/devel/en/html_node/Managing-Patches-and-Branches.html).
> 
> Note that since Guix requires signed commits by people listed in
> `.guix-authorizations`, we will *not* be able to click the “Merge”
> button nor to enable auto-merge on build success.
> 
> If and when the project migrates, we will incrementally adjust our
> workflow to ensure it scales better.
> 
> ## Translation
> 
> We may eventually consider migrating translation work from [Fedora’s
> Weblate](https://translate.fedoraproject.org/projects/guix/) to
> [Codeberg’s](https://docs.codeberg.org/codeberg-translate/), as a way to
> make it more discoverable and better integrated.
> 
> # Cost of Reverting
> 
> While the project *could* migrate back from Codeberg to bugs.gnu.org
> (Debbugs), migrating issues and pull requests from Codeberg to Debbugs
> would be practically infeasible.  It is unlikely that anyone would want
> this.
> 
> A more interesting question is: what would it take to migrate to a
> different Forgejo instance or to a different forge?
> 
> Migrating to a different Forgejo instance would be rather simple since
> Forgejo is able to *import* entire repositories with their settings
> (including teams) and issues and pull requests from other instances.
> Users would have to create accounts on the new forge instance though.
> However, if federation support matures in Forgejo, one may be able to
> operate on a repository from distinct but *federated* instances.  That
> would make any move much easier.
> 
> Forgejo appears to support
> [“mirroring”](https://forgejo.org/docs/latest/user/repo-mirror/) to
> GitLab instances, for instance, which could help migrating to a GitLab
> instance.  Migrating to a sourcehut instance would probably be more
> difficult because of the feature mismatch.
> 
> Note that Forgejo offers a [rich HTTP
> interface](https://forgejo.org/docs/latest/user/api-usage/) that
> essentially allows users to get the raw data behind issues, pull
> requests, and more, meaning that it is theoretically always possible to
> grab the data.
> 
> # Drawbacks and Open Issues
> 
> Leaving it up to an external organization to manage critical
> infrastructure of our project comes with risks.
> 
> First, everyone will have to create an account and accept [Codeberg’s
> Terms of
> Use](https://codeberg.org/Codeberg/org/src/branch/main/TermsOfUse.md)
> before they can contribute, which can be seen as a step back compared to
> the email-based workflow.
> 
> Codeberg e.V., the non-profit that runs Codeberg, could always go
> bankrupt, suffer from governance issues, or run into problems that any
> non-profits face and which could lead to service discontinuation.  This
> could be mitigated by weaving close ties with Codeberg e.V., for
> instance by financially supporting it, by setting a joint team to
> monitor resource consumption induced by Guix and discuss any issues
> encountered by either parties proactively, or by [joining
> it](https://join.codeberg.org/) as an active member with voting rights.
> 
> The self-hosting option has its appeal for a project with the size and
> values of Guix—it is not uncommon for similar projects to do that, an
> example being the [Lix project](https://git.lix.systems/); there even
> exists a [preliminary Forgejo service for
> Guix](https://git.boiledscript.com/hako/Rosenthal/src/commit/7a6a28e872b3168f9b6513ccf797e247cd8a366d/rosenthal/services/web.scm#L32).
> However the author thinks that, as it stands, Guix system administrators
> have more than enough on their plate and are perhaps not up to the task
> of providing the availability guarantees we expect from such a service.
> 
> As of this writing, Forgejo integration in Cuirass is functional but
> partial (useful configuration options and hardening mechanisms are
> missing) and missing from QA-Frontpage.  This will have to be addressed
> to fully take advantage of the new pull-request workflow.
> 





This bug report was last modified 16 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.