So you'd like to contribute to NOS3? Below are some guidelines for contributors to follow in addition to a standard code of conduct. Contributions come in all shapes and sizes. We appreciate your help with documentation, unit tests, framework code, continuous-integration, or simply reporting bugs and improvement ideas. We can't promise that we'll accept every suggestion or fix every bug in a timely manner but we'll respond to you as quickly as possible.
- Code of Conduct
- Ways to Contribute
For discussions, questions, or ideas, start a new discussion in the cFS repository under the Discussions tab. If you prefer email, you can also join the cfs community mailing list.
Perform a cursory search to see if the bug has already been reported. If a bug has been reported and the issue is still open, add a comment to the existing issue instead of opening a new one.
If you find a bug in our code don't hesitate to report it:
- Open an issue using the bug report template.
- Describe the issue.
- Describe the expected behavior if the bug did not occur.
- Provide the reproduction steps that someone else can follow to recreate the bug or error on their own.
- If applicable, add code snippets or references to the software.
- Provide the system the bug was observed on including the hardware, operating system, and versions.
- Provide any additional context if applicable.
- Provide your full name or GitHub username and your company organization if applicable.
- The NOS3 team will label the issue.
- A team member will try to reproduce the issue with your provided steps. If the team is able to reproduce the issue, the issue will be left to be implemented by someone.
NOS3 has a multitude of users from different fields and backgrounds. We appreciate your ideas for enhancements!
Perform a cursory search to see if the feature has already been requested. If a feature request has been reported and the issue is still open, add a comment to the existing issue instead of opening a new one.
- Open an issue using the feature request template.
- Describe the feature.
- Describe the solution you would like.
- Describe alternatives you've considered.
- Provide any additional context if applicable.
- Provide your full name or GitHub username and your company organization if applicable.
- The project team will label the issue.
- The project team will evaluate the feature request, possibly asking you more questions to understand its purpose and any relevant requirements. If the issue is closed, the team will convey their reasoning and suggest an alternative path forward.
- If the feature request is accepted, it will be marked for implementation.
Ready to Add Your Code? Follow GitHub's fork-branch-pull request pattern.
-
Fork the relevant component.
-
Find the related issue number or create an associated issue that explains the intent of your new code.
-
Create a new branch in your fork to work on your fix. We recommend naming your branch
fix-ISSUE_NUMBER-<FIX_SUMMARY>
. -
Add commits to your branch. For information on commit messages, review How to Write a Git Commit Message.
We recommend creating your pull-request as a "draft" and to commit early and often so the community can give you feedback at the beginning of the process as opposed to asking you to change hours of hard work at the end.
- For the title, use the title convention
Fix #XYZ, SHORT_DESCRIPTION
. - Describe the contribution. First document which issue number was fixed using the template "Fix #XYZ". Then describe the contribution.
- Provide what testing was used to confirm the pull request resolves the link issue. If writing new code, also provide the associated coverage unit tests.
- Provide the expected behavior changes of the pull request.
- Provide the system the bug was observed on including the hardware, operating system, and versions.
- Provide any additional context if applicable.
- Provide your full name or GitHub username and your company or organization if applicable.
- The NOS3 team will label and evaluate the pull request in the next configuration control board meeting.
- If the pull request is accepted, it will be merged.