all messages for Guix-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Simon Tournier <zimon.toutoune@gmail.com>
To: Guix Devel <guix-devel@gnu.org>
Cc: "Ludovic Courtès" <ludo@gnu.org>,
	"Efraim Flashner" <efraim@flashner.co.il>,
	"Ricardo Wurmus" <rekado@elephly.net>,
	"Christopher Baines" <mail@cbaines.net>,
	"GNU Guix maintainers" <guix-maintainers@gnu.org>
Subject: Request-For-Comment process: concrete implementation (v5)
Date: Fri, 03 Jan 2025 19:38:01 +0100	[thread overview]
Message-ID: <87ttafn3p2.fsf@gmail.com> (raw)
In-Reply-To: <87h6m7yrfh.fsf@gmail.com>

Hi,

Below the updated version (v5) of the RFC introducing the RFC process.

The submission is: <https://issues.guix.gnu.org/74736#22>.

Well, a very good lesson is: Co-supporter is very important!  It helps
in crossing the final line. :-) In other words, the Timeline had not
been respected at all because the lack of an initial Co-supporter.

Almost two months ago, Noé resumed the proposal [1].  It appears to me
that now we are close to the end of the Comment period.

Yeah any comment is very welcome. :-)

Then, I propose to start the Last Call the 17th (January) and finalize
(or withdraw) for the end of the month (January, 31th) – in both cases,
a good opportunity to share a drink at Guix Days in Brussels. :-)

WDYT?

Cheers,
simon


1: [bug#74736] [PATCH v2 0/1] Add Request-For-Comment process.
Noé Lopez via Guix-patches via <guix-patches@gnu.org>
Sun, 08 Dec 2024 13:29:52 +0100
id:cover.1733614983.git.noelopez@free.fr
https://issues.guix.gnu.org/74736
https://issues.guix.gnu.org/msgid/cover.1733614983.git.noelopez@free.fr
https://yhetil.org/guix/cover.1733614983.git.noelopez@free.fr


--

title: Request-For-Comment process
Issue: 66844
Status: pending
Supporter: Simon Tournier
Co-supporters: Noé Lopez
date: 2023-10-31
---

# Summary

The “RFC” (request for comments) process is intended to provide a consistent
and structured path for major changes to enter the Guix project, so that all
stakeholders can make decisions collectively and be confident about the
direction it is evolving in.

# Motivation

Guix becomes a broadly used system with many contributors and the way we add
new features has been good but starts to show its limits.  The lack of a clear
process easy to consult makes difficult to share a common evolution.

There are a number of changes that are significant enough that they could
benefit from wider community consensus before being introduced.  Either
because they introduce new concepts, big changes or are controversial enough
that not everybody will consent on the direction to take.

Therefore, the purpose of this RFC is to introduce a process that allows to
bring the discussion upfront and strengthen decisions.  This RFC is used to
bootstrap the process and further RFCs can be used to refine the process.

It covers significant changes, where “significant” means any change that could
only be reverted at a high cost, or any change with the potential to disrupt
user scripts and programs or user workflows.  Examples include:

-   changing the <package> record type and/or its interfaces;
-   adding or removing a 'guix' sub-command;
-   changing the channel mechanism;
-   changing project policy such as teams, decision-making, the
    deprecation policy or this very document;
-   changing the contributor workflow and related infrastructure
    (mailing lists, source code repository and forge, continuous
    integration, etc.)

# Detailed design

## When to follow this process

This process is followed when one intends to make “significant” changes to the
Guix project.  What constitutes a “significant” change may include the
following:

-   Changes that modify user-facing interfaces that may be relied on
    -   Command-line interfaces
    -   Core Scheme interfaces
-   Big restructuring of packages
-   Hard to revert changes
-   Governance or changes to the way we collaborate

Certain changes do not require an RFC:

-   Adding, updating packages, removing outdated packages
-   Fixing security updates and bugs that don’t break interfaces

A patch submission that contains any of the aforementioned substantial changes
may be asked to first submit a RFC.

For general day-to-day contributions, please follow the regular process as
described by the manual, for example sections “Submitting Patches”, “Reviewing
the Work of Others”, “Teams” and “Making Decisions”.

## How the process works

1.  Clone <https://git.savannah.gnu.org/git/guix.git>
2.  Copy rfc/0000-template.md to rfc/00XY-good-name.md where good-name
    is descriptive but not too long and XY increments
3.  Fill RFC
4.  Submit to guix-patches@gnu.org
5.  Announce your RFC to guix-devel@gnu.org

Make sure the RFC proposal is as well-written as you would expect the final
version of it to be.  It does not mean that all the subtleties must be
considered at this point since that is the aim of Comment period.  It means
that the RFC process is not a prospective brainstorming and the RFC proposal
formalize an idea for making it happen.

The submission of a RFC proposal does not require an implementation.  However,
to improve the chance of a successful RFC, it is recommended to have an idea
for implementing it.  If an implementation is attached to the detailed design,
it might help the discussion.

At this point, at least one other person must volunteer to be “co-supporter”.
The aim is to improve the chances that the RFC is both desired and likely to
be implemented.  See “Co-supporter” section.

Once supporter and co-supporter(s) are committed in the RFC process, the
discussion starts.  Publicizing of the RFC on the project’s mailing list named
guix-devel is mandatory, and on other main communication channels is highly
recommended.

After a number of rounds of comments, the discussion should settle and a
general consensus should emerge.  Please follow the “Decision Making” and
“Timeline” sections.

A successful RFC is not a rubber stamp, and in particular still does not mean
the feature will ultimately be merged; it does mean that in principle all the
participants have agreed to the feature and are amenable to merging it.

An unsuccessful RFC is **not** a judgment on the value of the work, so a
refusal should rather be interpreted as “let's discuss again with a different
angle”. The last state of an unsuccessful RFC is archived under the directory
rfc/withdrawn/ and the status quo continues.

When time passing, a successful RFC might be replaced by another successful
RFC.  The status of the former is thus modified and becomes 'deprecated'; it
is archived under the directory rfc/deprecated.

At the end of the process, the status of the RFC is either successful,
withdrawn or deprecated.

## Co-supporter

A co-supporter is a contributor sufficiently familiar with the project's
practices, hence it is recommended, but not mandatory, to be a team member or
a contributor with commit access.  The co-supporter helps the supporter, they
are both charged with keeping the RFC moving through the process.  The
co-supporter role is to help the RFC supporter by being the timekeeper and
helps in pushing forward until process completion.

The co-supporter doesn’t necessarily have to agree with all the points
of the RFC but should generally be satisfied that the proposed additions
are a good thing for the community.

## Timeline

The lifetime of an RFC is structured into the following recommended
periods:

digraph "RFC Timeline" {
    submission[label=<Submission Period<br />7 days>]
    comments[label=<Discussion Period<br />30–60 days>]
    last_call[label=<Deliberation Period<br />14 days>]
    withdrawn[label=Withdrawn, shape=rectangle]
    final[label=Final, shape=rectangle]
    
    submission -> comments
    submission -> withdrawn
    comments -> last_call
    last_call -> withdrawn
    last_call -> final
    
    withdrawn -> submission [label="New version"]
    
    comments -> withdrawn
}

The author may withdraw their RFC proposal at any time; and it might be
submitted again using a new issue number.

### Submission (up to 7 days)

Anyone might be author and submits their RFC proposal as a regular patch and
look for co-supporter(s). See “Co-supporter” section.

Once the RFC proposal is co-supported, it marks the start of a Comment period.

### Comment (at least 30 days, up to 60 days)

The Comment period starts once the author publishes their RFC to guix-devel,
then the RFC is freely discussed by anyone for a period of at least 30 days.
It is up to the supporter and co-supporter(s) to ensure that sufficient
discussion is solicited.

Please make sure that all have the time and space for expressing their
comments.  The RFC is about significant changes, thus more opinions is better
than less.

The author is encouraged to publish updated versions of their RFC at any point
during the discussion period.

Once the discussion goes stale or after 60 days, the author must summarize the
state of the conversation and keep the final version.

It moves to the last call period.

### Last call (up to 14 days)

Once the final version is published, team members have 14 days to cast one of
the following replies on the patch-tracking entry about the RFC:

- Support: meaning that support in principle;
- Accept: meaning no opposition in principle;
- Disagree: meaning opposed in principle.

This deliberation period strengthens the consensus; see “Decision Making”.

The RFC is accepted if (1) at least 25% of the team members cast a reply, and
(2) no one disagrees.  In other cases, the RFC is withdrawn.

Anyone who is on a team (see file ‘teams.scm’) is a deliberating member and is
asked to reply.

## Decision Making

It is expected from all contributors, and even more so from team members, to
help in building consensus.  By using consensus, we are committed to finding
solutions that everyone can live with.

It implies that no decision is made against significant concerns and these
concerns are actively resolved with proposals that work for everyone.  A
contributor wishing to block a proposal bears a special responsibility for
finding alternatives, proposing ideas/code or explaining the rationale for the
status quo.

As a deliberating member, when replying “Disagree”, you mean (1) you cannot
live with the RFC and (2) you have been active and helping in discussing the
RFC during the Comment period.

To learn what consensus decision making means and understand its finer
details, you are encouraged to read
<https://www.seedsforchange.org.uk/consensus>.

## Merging the outcome

Once a consensus is made, a committer should do the following to merge the
RFC:

1.  Fill in the remaining metadata in the RFC header, including links
    for the original submission.
2.  Commit everything.
3.  Announce the establishment of the RFC to all.

## Template of RFC

The structure of the RFC is captured by the template; see the file
rfc/0000-template.md.  Please use Markdown as markup language.

## The Cost Of Reverting

The RFC process can be refined by further RFCs.

## Drawbacks

There is a risk that the additional process will hinder contribution more than
it would help.  We should stay alert that the process is only a way to help
contribution, not an end in itself.

Of course, group decision-making processes are difficult to manage.

The ease of commenting may bring a slightly diminished signal-to-noise ratio
in collected feedback, particularly on easily bike-shedded topics.

## Open questions

There are still questions regarding the desired scope of the process.  While
we want to ensure that changes which affect the users are well-considered, we
certainly don’t want the process to become unduly burdensome. This is a
careful balance which will require care to maintain moving forward.



  parent reply	other threads:[~2025-01-03 18:39 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-10-31 11:14 Request-For-Comment process: concrete implementation Simon Tournier
2023-11-16 15:03 ` Ludovic Courtès
2023-11-20  9:42   ` Simon Tournier
2023-11-22 18:17     ` Ludovic Courtès
2023-11-23  7:04 ` Efraim Flashner
2023-11-28 13:34   ` Simon Tournier
2023-12-19 12:33 ` Simon Tournier
2023-12-20 11:49   ` Ricardo Wurmus
2024-02-03 10:09     ` Simon Tournier
2024-02-03 10:34 ` [post Guix Days] Guix Common Document (was: Request-For-Comment process) Simon Tournier
2024-02-07  8:27   ` Efraim Flashner
2025-01-03 18:38 ` Simon Tournier [this message]
2025-01-07 10:40   ` Request-For-Comment process: concrete implementation (v5) Ludovic Courtès
2025-01-08 15:15     ` Suhail Singh

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87ttafn3p2.fsf@gmail.com \
    --to=zimon.toutoune@gmail.com \
    --cc=efraim@flashner.co.il \
    --cc=guix-devel@gnu.org \
    --cc=guix-maintainers@gnu.org \
    --cc=ludo@gnu.org \
    --cc=mail@cbaines.net \
    --cc=rekado@elephly.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/guix.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.