Skip to content

Latest commit

 

History

History
83 lines (70 loc) · 5.27 KB

PROCESS.md

File metadata and controls

83 lines (70 loc) · 5.27 KB

IBC Standardisation Process

IBC standardisation will follow an adaptation of the TC 39 process used by the ECMAScript steering committee.

Stage 1 - Strawman

  • Purpose: Start the specification process
  • Entrance Criteria: Open an issue on this repository with a short outline of your proposal and a specification name.
  • Acceptance Requirements: No acceptance required to move to the next stage. Keep the issue around to track the specification status, and close it when the final specification is merged or the proposal abandoned.
  • Spec Quality: Outline only. Link to any prior documentation, discussion, or reference materials.
  • Changes Expected Post-Acceptance: N/A
  • Implementation Types Expected: None required, but link to any existing

Stage 2 - Draft

  • Purpose:
    • Make the case for the addition of this specification to the IBC ecosystem
    • Describe the shape of a potential solution
    • Identify challenges to this proposal
  • Entrance Criteria:
    • Prose outlining the problem or need and the general shape of a solution in a PR to a ./spec/{area}/ics-{{ .Spec.Number }}-{{ .Spec.Name }}/README.md file in this repository. This file should contain:

      • List of expected projects & users within the Cosmos ecosystem who might make use of the specification along with any particular requirements they have
      • Discussion of key algorithms, abstractions, and semantics
      • High-level application interface outline, where applicable
      • Identification of potential design trade-offs and implementation challenges/complexity

      For a more detailed description of standard requirements, see ICS 1.

      For more details on submitting a PR, take a look at the Pull Requests section in the contribution guidelines.

    • Identified author(s) who will advance the proposal in the header of the standard file

    • Any additional reference documentation or media in the ./spec/ics-{{ .Spec.Number }}-{{ .Spec.Name }} directory

    • The specification team expects that this proposal will be finalised and eventually included in the IBC standard set.

  • Spec Quality:
    • Follows the structure laid out in ICS 1 and provides a reasonable overview of the proposed addition.
  • Acceptance Requirements:
    • The PR has received two approvals from members of the core specification committee, at which point it can be merged into the IBC repository.
  • Changes Expected Post-Acceptance:
    • Changes to details but not to the key concepts are expected after a standard enters draft stage. Implementers should work with the spec authors as work continues on spec development.
  • Implementation Types Expected:
    • Tightly bounded demos, example repositories showing reproduction steps for issues fixed by proposal

Stage 3 - Candidate

  • Purpose:
    • Indicate that further refinement will require feedback from implementations and users
  • Entrance Criteria:
    • Everything from stages 1 & 2
    • Complete specification text
    • At least one specification-compatible implementation exists
    • All relevant ecosystem stakeholders have been given a chance to review and provide feedback on the standard
    • The solution is complete and no further work is possible without implementation experience, significant usage and external feedback.
  • Spec Quality:
    • Complete: all semantics, syntax and API are completed as described
  • Acceptance Requirements:
    • The PR changing the stage to "candidate" has been approved by two members of the core specification team.
  • Changes Expected Post-Acceptance:
    • Limited: only those deemed critical based on implementation experiences.
  • Implementation Types Expected:
    • Specification-compliant

Stage 4 - Finalised

  • Purpose:
    • Indicate that the addition is included in the formal ICS standard set
  • Entrance Criteria:
    • Everything from stages 1,2,3
    • At least two specification-compatible implementations exist, and they have been tested against each other
    • All relevant ecosystem stakeholders approve the specification (any holdout can block this stage)
    • Acceptance tests are written and merged into the relevant repositories
    • All files in the ./spec/ics-{{ .Spec.Number }}-{{ .Spec.Name}}/ directory are up to date and merged into the cosmos/ics repository
  • Acceptance Requirements:
    • The PR changing the stage to "finalised" has been approved by representatives from all relevant ecosystem stakeholders, and all members of the core specification team.
  • Spec Quality:
    • Final: All changes as a result of implementation experience are integrated
  • Changes Expected Post-Acceptance:
    • Backward-compatible fixes or breaking changes that are supported by a backwards-compatibility preserving upgrade protocol
  • Implementation Types Expected:
    • Shipping/Production

Calls for implementation and feedback

When an addition is accepted at the “candidate” (stage 3) maturity level, the committee is signifying that it believes design work is complete and further refinement will require implementation experience, significant usage and external feedback.