Skip to content
This repository has been archived by the owner on Jun 28, 2023. It is now read-only.

Latest commit

 

History

History
112 lines (75 loc) · 4.57 KB

README.md

File metadata and controls

112 lines (75 loc) · 4.57 KB

Proposing Changes to Tanzu Community Edition

Introduction

Tanzu Community Edition relies on design proposals to assess the viability of non-trivial changes to the project. This document covers details on the proposal process, which can also be used as guidelines for how to create a proposal.

The Proposal Process

The proposal process is the process for reviewing a proposal and reaching a decision about whether to accept or decline the proposal.

  1. The proposal author creates a brief issue describing the proposal.

    A design doc is not required at this point; although proposal authors are welcome to create one.

    While we recommend ensuring a proposal is Accepted before starting non-trivial work, we welcome, and like, implementations that demonstrate the proposal. However, if a proposal is declined, there is a chance any implementation work could go to waste.

  2. A discussion on the issue tracker aims to triage the proposal into one of three outcomes:

    • Accepted (proposal/accepted label)
    • Declined (proposal/declined label)
    • Needs Design Doc (proposal/needs-design-doc label)

    If the proposal is Accepted or Declined, the process is done.

  3. Maintainers determine whether a design doc is required. If it is, a proposal/needs-design-doc label is applied.

  4. The proposal author creates a design doc. This facilitates discussions (in a GitHub PR) around the proposal.

  5. The proposal author or maintainers notify the community, via mailing list, that RFCs are open and when we plan to close it.

  6. Maintainers review open proposals weekly to move them forward.

Design Documents

When a design doc is requested, a proposal author should:

  1. Create a branch on their fork of the community-edition repository.

  2. Create the file docs/designs/${GH_ISSUE_NUMBER}-${SHORT_PROPOSAL_TITLE}.md.

  3. Use the template to get started.

  4. If images will be used, store and reference them in docs/designs/imgs-${GH_ISSUE_NUMBER}/.

  5. Create a PR against the vmware-tanzu/community-edition repository.

    Authors are encouraged to keep a PR open as they work on the design doc. If the doc is not ready for review, please ensure the PR is a draft.

note: PRs for design docs are linted using markdownlint, you can run it locally or use make check.

The Review Process

The progress of proposals are tracked in the Proposal GitHub Project.

The TCE maintainers meet weekly to review proposals that have not been Approved or Declined. A summary of the discussion for each proposal will be added to the proposal issue in GitHub. The outcome of these reviews could be:

  • No changes
  • Requests for more details
  • Approving a proposal
  • Declining a proposal

When a proposal involves a dependency or upstream project, such as tanzu-framework, a maintainer from that project will be asked to join the review process.

When a proposal is completed and ready for review, TCE maintainers will declare an initial window to solicit comments (RFC). During this period, we're requesting the following from users, community members, and contributors:

  • Leave feedback in comments on proposal issues
  • Leave comments on an open design doc PR (if a design doc was created)

If you'd like to discuss a proposal or decision made around a proposal in person, please attend our office hours, which are open to the public.

Definitions

  • A proposal is a GitHub issue referring to a change that must be considered for approval before work should begin. It is labeled with proposal/pending.

  • A design document is a detailed expansion of the proposal. It's submitted as a PR containing a markdown file, which references the proposal issue.

Attribution

The proposal process found here was influenced and based off: