From ca963b23c03d9102174149cf607547f06d875e2d Mon Sep 17 00:00:00 2001 From: Andrew Klychkov Date: Sat, 27 Mar 2021 10:03:03 +0100 Subject: [PATCH] Add review_checklist.md (#127) * Add review_checklist.md * Add general tips * Improve general tips * fix * fix * fix * fix * fix * fix * Fix * Update review_checklist.md Co-authored-by: Amin Vakil * Fix * Update review_checklist.md Co-authored-by: Amin Vakil * Update review_checklist.md Co-authored-by: Amin Vakil * Rename checklist Co-authored-by: Amin Vakil * Update REVIEW_CHECKLIST.md Co-authored-by: Jorge Rodriguez (A.K.A. Tiriel) * Add suggested * Add clarifications Co-authored-by: Amin Vakil Co-authored-by: Jorge Rodriguez (A.K.A. Tiriel) --- REVIEW_CHECKLIST.md | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 REVIEW_CHECKLIST.md diff --git a/REVIEW_CHECKLIST.md b/REVIEW_CHECKLIST.md new file mode 100644 index 0000000..889cd38 --- /dev/null +++ b/REVIEW_CHECKLIST.md @@ -0,0 +1,36 @@ +# Review Checklist + +When reviewing, keep in mind that we follow [Ansible Code of Conduct](https://docs.ansible.com/ansible/latest/community/code_of_conduct.html) in all our contributions and interactions within this repository. + +**General tips** +- Try to create a culture of collaboration when reviewing +- Welcome the author and thank them for the pull request +- When suggesting changes, try to use questions, not statements +- When suggesting mandatory changes, do it as politely as possible providing documentation references +- If your suggestion is optional or a matter of personal preferences, please say it explicitly +- When asking for adding tests or for complex code refactoring, say that the author is welcome to ask for clarifications and help if they need +- If somebody suggests a good idea, mention it or put a thumbs up +- After merging, thank the author and reviewers for their time and effort + +**Standards and documentation** +- [ ] if the pull request is not a documentation fix, it must include a [changelog fragment](https://docs.ansible.com/ansible/devel/community/development_process.html#creating-a-changelog-fragment) - please check the format carefully +- [ ] if new files are added with the pull request, they follow the [licensing rules](https://github.com/ansible-collections/overview/blob/main/collection_requirements.rst#licensing) +- [ ] the changes follow the [Ansible documentation standards](https://docs.ansible.com/ansible/devel/dev_guide/developing_modules_documenting.html) and the [style guide](https://docs.ansible.com/ansible/devel/dev_guide/style_guide/index.html#style-guide) +- [ ] the changes follow the [development conventions](https://docs.ansible.com/ansible/devel/dev_guide/developing_modules_best_practices.html) +- [ ] if a new plugin is added, it is one of the [allowed plugin types](https://github.com/ansible-collections/overview/blob/main/collection_requirements.rst#modules-plugins) +- [ ] documentation, examples, and return sections use FQCNs for the `M(..)` [format macros](https://docs.ansible.com/ansible/latest/dev_guide/developing_modules_documenting.html#linking-and-other-format-macros-within-module-documentation) when referring to modules +- [ ] modules and plugins from ansible-core use `ansible.builtin.` as a FQCN prefix when mentioned +- [ ] when a new option, module, plugin, or return value is added, the corresponding documentation or return sections use `version_added:` containing the *collection* version which they will be first released in + * this usually is the next minor release, sometimes the next major release (example: if 2.7.5 is the current release, the next minor release will be 2.8.0, and the next major release will be 3.0.0) +- [ ] FQCNs are used for `extends_documentation_fragment:`, unless the author is referring to doc_fragments from ansible-core + +**Tests (if applicable and technically possible to implement):** +- [ ] the pull request has [integration tests](https://docs.ansible.com/ansible/devel/dev_guide/testing_integration.html) +- [ ] the pull request has [unit tests](https://docs.ansible.com/ansible/devel/dev_guide/testing_units.html) +- [ ] all changes are covered +- [ ] integration tests also cover `check_mode` (if it is supported) +- [ ] integration tests check an actual state of the system, not only what the module reports (for example, if the module changes a file, check that the file was actually changed by using the `ansible.builtin.stat` module) + +**Other** +- [ ] the pull request does not contain merge commits (see GitHub warnings at the bottom of the pull request) - in this case, ask the author to rebase the pull request branch +- [ ] if the pull request contains breaking changes, ask the author and the collection maintainers if it is really needed and there is no way not to introduce them