Skip to content

zachcasper/design-notes

 
 

Repository files navigation

Design notes

This design-notes repository contains design proposals, enhancements, and architectural decisions for Radius. It provides a consistent and controlled path to record changes and developments, ensuring clarity and transparency for all stakeholders in the Radius community.

Design notes are used for evaluating the design of planned changes and additions to Radius. Do not use this repository for feature requests - please create an issue on the main Radius repository instead. We create documents in this repo to describe why and how to accomplish something once we have agreement that it is appropriate for the project.

Minor changes such as documentation updates or small bug fixes may be reviewed and implemented directly via a GitHub issue. For larger changes, such as new feature design, a design note pull-request and review is required. These must get consensus from Radius maintainers and the community. A scenario and feature specification following the feature spec template should precede the design note template.

For more information on how to contribute to Radius visit CONTRIBUTING.md.

Review note review process and instructions

Our design note review review process is based on pull-requests to this repository.

  • Major design topics will be reviewed during our design review meetings.
  • Minor design review topics may be asynchronously reviewed without a meeting depending on capacity.

Our design review meeting is currently a closed meeting.

Creating a pull-request

Follow the following steps to create a pull-request:

  • Create a new document using the design note template in this repository.
    • Name the document using the year and month followed by a short description name. eg: 2023-04-tls-termination.md
    • Place the document in the appropriate folder based on the area. See the Structure section in this readme for descriptions.
    • Fill out the template and DO NOT omit sections.
    • If you have supporting assets like images please place them a directory using the same name as the document (without .md).
  • When you are ready for feedback:
    • Commit the document.
    • Push your changes.
    • Open a pull-request on this repository.

Please open your pull-request before the design meeting where you want to review the document. Community members that are subscribed to the repository will be notified when the pull-request is opened.

Spell Checking

The PR check workflow runs a spell checker (pyspelling) using a custom dictionary file. If the spell check fails look at the workflow output for which words are misspelled. Add words to the dictionary file if they are spelled correctly but pyspelling doesn't know them.

If you install pyspelling locally you can run the spell check on your machine with this command (from the root folder of the repo):

pyspelling --verbose --config ./.github/config/.pyspelling.yml

Note: Pyspelling has a dependency on Aspell, which must also be present on your system to run pyspelling.

During the review

During a review, community members and maintainers will ask questions and leave feedback. The design may be approved as-is or it may be returned for iteration.

As a reviewer: Please make a record of all major questions and feedback in the pull-request using comments. This allows the community to see the history and discussion even if they were not present when it was discussed.

After the review: authors

If the design is approved:

  • Please incorporate any outstanding feedback.
  • Please respond to, and resolve all comments in the document explaining the resolution of the feedback.
  • One or more approvers will approve the pull-request so that it can be merged.
  • Merge the pull-request.

Development work on implementing the design begins only after the design is approved.

If there are updates come up during development work that need consideration and team review, please create a pull-request with proposed updates to the design. The design review process will be repeated for this new pull-request.

If the design is not approved:

  • Please leave a comment on the pull-request explaining the major feedback and next steps for proceeding.
  • It is your responsibility as the author to document the next steps clearly so we can pick up where we left off.
  • Please iterate on the proposal and prepare the next review. This may include responding to and resolving feedback in the pull-request.

Structure

The repository is organized into several sections, each corresponding to a specific area of Radius:

Directory Name Description
architecture Contains the overall system architecture designs for Radius services.
bicep Contains the designs related to deployment-engine, Bicep compiler, and Bicep types.
cli Contains the designs for Radius CLI.
features Contains feature specifications.
recipe Contains the designs related to Radius recipes.
resources Contains the designs for Radius resource types in Application.* namespace.
tools Contains the designs for engineering tools, such as GitHub Action Workflow and test-infra.
template Contains the template for design documents.
ucp Contains the designs for the Universal Control Plane (UCP).

Code of Conduct

Please refer to our Radius Community Code of Conduct

About

Design documents for Radius

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Modula-3 100.0%