Skip to content

Latest commit

 

History

History
125 lines (102 loc) · 12.2 KB

CONTRIBUTING.md

File metadata and controls

125 lines (102 loc) · 12.2 KB

Context

This file refers to the process of contributing to this documentation repository.

💡 For contributing to BlueOS itself please see the source code repository.

Repository Structure

  1. Each branch covers some form of release of the software
    • The latest branch covers the unstable features in development / early testing
    • The stable and X.Y versioned branches track major and minor stable releases
      • stable documents the current latest stable version
      • It only branches into the corresponding numbered branch at the time of the next version number increment
    • Patch release (X.Y.Z) changes are documented (as relevant) in the corresponding minor release branch (X.Y)
  2. Documentation content is in the content directory
  3. The theme is included in the themes directory, as a git submodule

Release Synchronisation

  1. Documentation contributions should be opened as Draft pull requests until the documented features have been merged into the software codebase, or released in the relevant version
  2. Documentation completeness should not prevent software feature merging, but may hold up versioned software releases
    • Ideally every released feature and interface should have documentation available, but to avoid confusion documentation should never be merged for features that are not yet available
    • It is recommended that software pull requests that change an interface or part of the documented code structure be marked with a docs-needed label, and include a comment about which aspects need to be documented prior to the feature being merged (while the details are still front of mind for the developer)
    • If a software pull request is labelled as docs-needed, once a corresponding documentation pull request is merged the feature PR can be re-labelled with a completion status (e.g. docs-minimal or docs-complete)
    • Beta releases may require that no merged features are labelled with docs-needed, and stable releases may require that no included features are labelled with docs-needed or docs-minimal
  3. When a new major or minor stable release of the software is made, the stable branch gets duplicated into a new branch tracking that version, which then gets reconfigured with a fixed release number, and the now-stable features in the latest branch get cherry-picked to the stable branch
    • This is handled by the documentation maintainers

Making a Contribution

Highlighting Documentation Holes/Weaknesses

💡 Suggesting areas for improvement is a valuable contribution!

While we strive to have comprehensive and clear documentation, it is not always obvious to developers which features need additional explanation. If there's a feature you're struggling to make sense of then others likely are too, so please let us know about it!

After searching for existing information, the recommended approaches are to:

  1. Ask questions on the community forum, for clarification of features you would like a better explanation of
  2. Create an Issue in this repository, with notes of your existing understanding, what you're unsure about, and/or any links and references that seem relevant

Adding to the Documentation

💡 Contributions should typically be made from a unique branch in an external fork.

Specific processes are covered below, but the general process is:

  1. Create a GitHub account
  2. Fork this repository
  3. Make a new branch for your changes
  4. Commit your changes to your branch
    • Small changes can just be made through GitHub's standard web interface
    • If making significant changes, press . to open the repository in an online editor, or clone your fork to your local machine and push your commits up to your GitHub repository once they're complete
  5. Create a Draft pull request while work is underway, with a link in the description to any issues it resolves or software feature pull requests it documents
  6. Change the pull request to "ready for review" once the underlying software change is merged, the documentation is building successfully, and the new content is ready
  7. Fix any requested changes/improvements
  8. Once your pull request is merged, update the status/labels of any relevant Issues and software pull requests, or comment on them if you don't have edit access

Content Improvements

Documenting a New/Upcoming Feature

💡 These can often be found by searching the software repository for pull requests with the docs-needed label.

  1. Ensure your fork's latest branch is up to date with this repository
  2. Branch out from your latest branch into a unique branch, ideally with a short name that reflects its purpose
  3. Submit a Draft pull request with your changes, and include "Documents bluerobotics/BlueOS#{PULL-REQUEST}" in the description
    • {PULL-REQUEST} is the ID number of the software feature pull request covered by the proposed documentation
    • If your pull request covers multiple features, you can specify "Documents:" followed by a list of software feature pull request links
  4. Ensure your changes can be built, and (if relevant) clean up your commit history with an interactive rebase
  5. Mark your pull request as "ready for review", and fix any requested changes
  6. Once your pull request is merged, update the relevant software repository pull request(s) by changing the docs-needed label to docs-complete or docs-minimal as appropriate, or commenting the new documentation state if you don't have edit access to the repository

Improving/Adding Documentation for Released Features

💡 Relevant features can typically be found by looking through the public documentation for features with minimal information, and/or searching this repository for issues with the content label, or searching the software repository for pull requests with the docs-minimal label.

Documentation for existing features should generally first be added to the latest branch, before optionally being backported to the stable and/or any relevant version branches, usually via git cherry-pick.

If your changes were requested in an Issue, make sure to include "Resolves #{ISSUE-NUMBER}" in the description of your pull request, to link to and automatically close the Issue when the pull request is merged.

Infrastructure Improvements

Modifying the Documentation Structure

💡 Requested features/fixes can be found by searching this repository for issues with the infrastructure label.

⚠️ As the infrastructure can affect all aspects of the public documentation, it is necessary to ensure that infrastructure changes maintain compatibility with all the content branches, or (if absolutely necessary) update all the content branches with the relevant changes to work with the modified infrastructure.

  1. Ensure all branches of your fork are up to date with this repository
  2. Branch out from your latest branch, and make your desired changes
  3. Submit your changes as a Draft pull request, and ensure that the full documentation is able to build successfully
    • If your changes were requested in an Issue, include "Fixes #{ISSUE-NUMBER}" in the description of your pull request to link to and automatically close the Issue when the pull request is merged
  4. Submit pull requests to the versioned branches as relevant, to make use of the updated infrastructure
    • Include a link to the infrastructure pull request in the description of any content pull requests, to provide relevant context
  5. Mark your pull request(s) as "ready for review", and fix any requested changes

Modifying the Theme

The theme is maintained in an external repository, and included in this one as a submodule. Zola supports overriding theme components via the "templates" folder, which can be useful for initial testing and any specifics required for the software being documented, but if you want to update the upstream theme used:

  1. Fork and branch out from the theme repository, and make your desired changes in a Draft pull request
  2. Fork and branch out from the latest branch of this repository
  3. Add your forked theme as a submodule to the "theme" folder of your branch, with a unique name
  4. Change the theme variable of config.toml to match your theme name
  5. Generate the docs, to confirm that the theme changes do not break the build process, and the results look as intended
  6. Iterate the theme changes as necessary
  7. Mark your theme pull request as ready for review
  8. Once the theme changes are merged, ensure the theme submodule in the documentation latest branch gets updated, along with any relevant changes to the docs configuration, shortcodes, or template
    • The submodule update is generally automatic, via the daily "Update Submodules" Action, but you may need to create a documentation pull request if there are other changes required

Testing

Automatic Generation on Pull Requests

This repository includes continuous integration workflows that will build the documentation automatically in GitHub's servers, both for pull requests and updating the public documentation when new changes get accepted and merged in. This is particularly useful for contributors who don't want to install dependencies or download the repository source to their device, especially when only making small changes, or if you prefer to avoid using commandline tools.

If the build process succeeds, the proposed state of the documentation can be previewed at
http://br-www-docs.s3-website-us-east-1.amazonaws.com/preview/blueos/<pull-request-number>

Local Setup

If you frequently contribute to the documentation, you may wish to set things up on your local machine, so you can build and test changes offline and more quickly, and more easily perform complex version history management with git, before pushing the working and clean source back up to your GitHub remote to update your pull request.

  1. Install Zola
  2. Clone the content branch you're making changes in
    • e.g. git clone -b BRANCH https://[email protected]/USER-NAME/BlueOS-docs BlueOS-docs-modified, where
      • USER-NAME is your GitHub username
      • BRANCH is the name of the content branch you're planning to change
  3. Enter the cloned repository and initialise the submodules, to get the theme
    cd BlueOS-docs-modified
    git submodule update --init --recursive
  4. zola serve from the base folder of the repository (not inside the "content" folder) to build, and preview your changes
  5. Make your changes, and resolve errors/problems as relevant
    • While serving the docs, the preview responds live to changes in the underlying files
  6. git commit your changes in logical groups
    • e.g. updating the usage overview and advanced sections to describe a single feature should be in a single commit
  7. git push your changes up to your repository remote
  8. Submit a pull request, as covered in the content/infrastructure sections above