Thank you for your interest in contributing to the gofer-engine
project. This document provides a high-level overview of how to get started as a contributor.
Before you start, please read the README to get a better understanding of the project.
1. Read the README
Please read the README before logging new issues, even if you think you have found a bug.
Issues that ask questions answered in the README will be closed without elaboration.
Search the existing issues before logging a new one.
Some search tops:
- Don't restrict your search to only open issues. An issue with a title similar to yours may have been closed as a duplicate of one with a less-findable title.
- Check for synonyms. For example, if you bug involves an interface, it likely also occurs with channels.
- Search for the title of the issue you're about to log. This sounds obvious but 80% of the time this is sufficient to find a duplicate when one exists.
- Read more than the first page of results. Many bugs may use the same words so relevancy sorting is not particularly useful.
- If you have a crash, search for the first few topmost function names shown in the call stack.
The issue tracker is for issues, in other words, bugs and suggestions. If you have a question, please use these platforms:
Not being rude, but we don't want to clutter the issue tracker with questions, so we'll close them without giving answers.
When logging a bug, please be sure to include the following:
- What version of
gofer-engine
are you using? - What version of Node.js are you using?
- What operating system are you using?
- If at all possible, an isolated way to reproduce the behavior.
- The behavior you expect to see, and the actual behavior.
We also accest suggestions in the issue tracker. Be sure to search first.
In general, things we find useful when reviewing suggestions are:
- A description of the problem you're trying to solve
- An overview of the suggested solution
- Examples of how the suggestion would work in various places
- Code examples showing e.g. "this would be an error, this wouldn't"
- Code examples showing the input and output of the new feature
- If relevant, precedent in other interface designs/spec sheets can be useful for establishing context and expected behavior.
- Fork the repository
- Create a new branch for your changes
- Make your changes locally
- FUTURE: Run the tests locally
- Commit your changes with a descriptive commit message
- Push your changes to your fork.
- Create a pull request against the
main
branch of this repository. - Wait for a maintainer to review your changes.
- Respond to any feedback from the maintainer.
Things to consider when making changes:
- If your changes modify documentation, please update the documentation in the same PR.
- Use English for all communication including variable naming and comments as much as possible.
- Add comments to your code where appropriate to explain "WHY" you did something.
- Refrain from adding comments that explain "WHAT" you did. The code should be self-explanatory.
- Try to keep your changes as small as possible. This makes it easier for the maintainers to review your changes. If multiple features are being added, please consider splitting them into multiple independent PRs.
- FUTURE: If you are adding a new feature, please add tests to cover the new feature.
- FUTURE: If you are fixing a bug, please add a test that covers the bug.
If you have any questions, please feel free to reach out to the maintainers in Discussions or Discord