This document provides explicit standards expected in Clever Cloud documentation. Inspiration and research for this document comes from the incredible Awesome Code Review project.
Those are general standards to fulfill for every modification in this repository.
The structure of this docs aims to be as clear as possible for Clever Cloud users. Submitted changes can be merged as long as they respect these standards:
- Readers know where to go or where to click to find an information
- Readers know why they're on a specific page
- The site keeps a coherent and intuitive design
Follow the established structure in this doc. If you wish to propose changes to the structure, open an issue first to discuss it, or post it in the forum.
Follow these guidelines while writing new content. The goal is to help you write in a clear, precise, and unambiguous language. They're not meant to be a burden, but to help you deliver the best content possible.
Sources for quality content are currently being updated.
- Don't assume the user "knows better": if you think something is obvious, it's not. Better over-explain than under-explain.
- Use active voice: passive voice can make it harder for the readers to figure out who's supposed to do something.
- Use second person: address the reader directly.
- Keep it simple: avoid jargon, complex sentences, and jokes.
- Keep it short: keep the sentences short. Titles should be short and to the point. Keep longer content for the description metadata or the card subtitle.
- Placeholder phrases like please note and at this time.
- Words and phrases that make promises or project plans and strategies: See Writing timeless documentation.
- Using phrases like simply, It's that simple, It's easy, or quickly in a procedure.
- Over-politeness with the use of please: go straight to the point.
This doc uses Hugo with Hextra theme, which provides a variety of shortcodes to enhance it and improve its readability. For example :
- Steps are well suited for the
/guides/
section, or for any tutorial. - Callouts draw attention to an important information in the page. However, don't overuse them, as too many callouts can miss their point and make the page crowded. Limit callouts to one or two per page.
- Don't override global styles for font type, size, or color
- Comment your code if you add any custom CSS
- When importing from an external CSS tool, import the relevant classes only rather than the whole file
- Opt for self hosting over CDN: When used in
<head>
, it can impact site's performance. Using CDN for test purposes when submitting your PR and deploying a review app is totally fine, however.
These are the guidelines when submitting or reviewing a PR in this repository. The better you follow them, the faster the is the review process.
Priority goes to PRs that reference a problem addressed in an issue fitting the current milestone, or that fix a bug. But that doesn't mean that you can't submit or review a PR that doesn't fit those criteria if you think it's important. If you think it's important, it probably is.
- Keep it small: The quality of the review is inversely proportional to the size of the PR. Smaller PRs simplify the reviewing process and increase the chances of getting constructive feedback.
- Accept the feedback: If reviewers ask you to make changes, do it. If you disagree, explain why. If you aren't sure, ask for clarification. Don't nitpick on the feedback, and don't take it personally.
- Latency: Long PR review latency can be disappointing for the authors, and make merge conflicts arise in their branch. Long latency kills productivity and moral, so make sure to review PRs in a timely manner.
- Don't nitpick: If the PR respects the preceding standards and provide updated content, don't ask for changes just for the sake of it. If you think something isn't perfect, but it's not a big deal, don't ask for changes.
- Provide alternatives: If you think the author needs to change something, provide an example to illustrate your point. Use the
suggestion
feature on GitHub so the author can commit it directly if they agree with it. - It's OK to make mistakes: Explain what's wrong, why, and how to improve. If someone is violating a standard, refer to this doc to explain.
If you are a member of Clever Cloud, act like you were submitting a PR and receiving feedback in any other Open Source project. This means:
- Don't bring internal company debates into the PR Discussion: If conflict arises, take it to a private channel or in-person discussion. Pair-programming is a great way to solve conflicts together, consider it.
- Don't use authority or seniority to push your PRs: If you are a senior, your PRs aren't more important than others. If you are a junior, your PRs aren't less important than others. No one cares who you are, just the work you've done on this PR, and the fact you are willing to contribute to this doc is already highly appreciated.