Contribution guide
Contributing to Servable
👍🎉 THANK YOU for taking the time to contribute! 🎉👍
The following is a set of guidelines for contributing to Servable and all projects in the servable organization on GitHub. Although these are strongly encouraged guidelines, nothing about this project is set in stone, if you believe something here should be edited, open a pull request to start a discussion about it.
Code of Conduct
This project and everyone participating in it is governed by the Servable Code of Conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to the contact method in the Code of Conduct.
What should I know before I get started?
Documentation
All of the documentation for the project is housed within the docs/docs
folder. The general website is housed within the docs
folder. It is important while contributing to Servable to ensure that the documentation is complete, up to date, and helpful.
Resources
It is highly encouraged to read through the following resources before contributing.
How Can I Contribute?
Reporting Bugs
When reporting bugs please fill out the issue template with as much detail as possible. If you do not fill out the issue template with enough detail for us to debug your issue, your issue is at risk for being closed.
Minimal, Complete and Verifiable Example (MCVE)
One of the most important things when submitting an issue is to provide a Minimal, Complete and Verifiable Example (or MCVE for short). If you are reporting a bug it is important for us to be able to test and debug your code as quickly as possible.
- Minimal – Use as little code as possible that still produces the same problem
- Complete – Provide all parts needed to reproduce your problem
- Reproducible – Test the code to make sure it reproduces the problem
Without following these steps when creating code examples it is nearly impossible for us to debug your issue. Help us by putting time and care into code examples so that we also can help you. Not following this guideline puts your issue at risk of being closed.
Submitting a Pull Request (PR)
It is highly recommended (although not required) to follow the pattern below before submitting a pull request. Not every step below will be relevant to all pull requests.
Before
- Identify a need in the project - This can be a bug, protocol request, or other change.
- Create a detailed issue to gauge interest - Although most pull requests are merged, we don't want you to waste time creating a pull request that doesn't have the support of the community. This doesn't mean that even if the community supports an issue that the corresponding pull request will be merged, but it increases the chances with community support. This step is highly encouraged for larger contributions, but not required. For smaller contributions (typos, adding tests, updating documentaion, minor code changes, etc.) it is not necessary to create a separate issue.
- Read through the
package.json
- Thepackage.json
file in the root of the repository has a lot of useful information about the project. Especially read through thescripts
section, as a lot of those scripts can help speed up your development process when working in Servable. There are scripts for running tests, building the website, debugging code, fixing lint issues, etc.
During
- Create a fork & branch - Before contributing to Servable you must create a fork of the main repository and create a branch on your fork. It is highly discouraged from using a primary branch (ex.
main
oralpha
) to make your changes. This is due to the fact that if you enableAllow edits from maintainers
option, maintainers might commit directly to your primary branch which could cause problems if others are using your fork in their applications. - Install dependencies - Run
npm install
to install all the dependencies of the project. - Maintain consistency throughout - While working in the project, we highly encourage you to maintain the same coding style that the rest of the project uses. This means looking around at similar code and trying to adopt the same style and conventions in your code.
- Run tests & linter often - It is highly encouraged to run
npm test
&npm run lint
often to ensure you are conforming to the project guidelines. In order for a pull request to be merged all tests must pass, the linter must throw no errors, and test code coverage must not decrease. - Write tests - While (or better yet, before) making changes you should write tests in the test suite to ensure things work as expected.
- Test Edge Cases - While writing tests try to consider edge cases that might occur and write test for those edge cases. For example, what happens if you a user passes in no arguments, or what happens if the type passed in is not the type you expect.
- Code Coverage Must Not Decrease - Your pull request will not be merged if it decreases the code coverage for tests, so it is important to write tests to ensure any code added or modified is covered by tests.
- No Log Output - It is also important that your tests do not print any output to the console or logs, this includes
console.log
, UncaughtPromiseExceptions, etc. All logs printed should come directly from Jest. - One Test Must Fail Prior to Code Changes - At least one test you write should fail without the code changes you have made.
- Self Contained and Static - All tests should be self contained and should not rely on each other in order to pass. All tests must also be static and have no potential of failing based on random or outside factors.
- Logic inside Jest Blocks - All test logic should take place within Jest blocks (ex.
it
,before
,beforeEach
,after
orafterEach
). No interaction with Servable or outside references should take place outside of those blocks (ex. you should not create models or schemas in the global ordescribe
scope).
- Update documentation - For anything that effects users using Servable, documentation should be added/deleted/modified to reflect the changes you have made. It is important to ensure the documentation you write is as clear as possible, giving examples, and attempting to answer as many relevant questions as possible. For most cases JSDoc documentation should be added to the source files, and a pointer to the JSDoc documentation should be added to the relevant file in
docs/docs_src
. The pointer should look likedyno_jsdoc_dist/SOURCEFILEPATH|SECTIONNAME
(for example:dyno_jsdoc_dist/Model/index.js|model.name
will point to thedist/Model/index.js
source file, and use the documentation formodel.name
). All pointers should point to thedist
folder. In certain cases where the documentation does not reference a specific property or method in the code, it is fine to just write the documentation in thedocs/docs_src
folder (an example of this would be theAttribute Types
section in the Schema documentation). - Commit small & often - Please commit changes often and keep commit size to a minimum. It is highly discouraged from creating one massive commit with all of your changes in it. Every commit should also aim to pass the linter and tests. Commit messages should also be detailed enough to give a good explanation of the change made. Commit messages such as
changes
ordid stuff
are considered poor commit messages.
After
- Submit the pull request - When submitting the pull request it is important to fill out the complete pull request template. This ensures reviewers of your pull request can easily understand what is going on and make sure all guidelines and requirements have been met. It is also highly recommended to enable the
Allow edits from maintainers
option (be aware that enabling this option means that maintainers have the right to commit to your branch at any time, we do use this ability). - Be prepared for questions and suggestions - As others review your pull request it is important to be available to answer questions and promptly respond to code suggestions. Stale pull requests run the risk of being closed, even if it's a large change or a lot of effort was put into it.
- Ask others for reviews - If you know someone who is anticipating your work, ask them to test your branch and leave a detailed review on the pull request.
Release
Servable does not currently have a release schedule that we conform to. We attempt to batch work into a release every so often. If you have a need that requires us releasing a version sooner, please notify us, and we will attempt to cut a new release earlier (however this is not guaranteed, and you are still welcome to point to a branch in NPM if we are unable to release on your timeline).
Translate Servable
You can help Servable support more languages by translating our content into other languages. You can contribute by viewing our Crowdin project page and start translating today!
How do I become a project maintainer?
At this time we are pretty strict in terms of who gets write/merge access to Servable. The following are general guidelines we look for before granting those permissions, but other factors may apply depending on the situation.
- Activity - Likely the most important factor is we need to see you remain active on the project for an extended period of time. We want maintainers to be active and although we don't require maintainers to dedicated all their time to Servable, we are looking for maintainers to be active in the community.
- Contributions - We are looking for project maintainers to be active in contributing feedback, protocols, bug fixes, documentation improvements, and more to the project. Short version: we want project maintainers to show that they are dedicated to improving the project.
In short, some starting tips towards becoming a project maintainer include:
- Submit pull requests to improve the project
- Answer questions in Slack or Stack Overflow
- Reply to issues on GitHub
If you believe you have a case for becoming a project maintainer and feel as tho you meet those requirements contact me or reach out on Slack (Charlie Fish) and I'd be happy to discuss next steps with you.
It is also important to note that if you become a project maintainer, and become inactive on the project, your project maintainer status may be revoked.
What do project maintainers need to know?
The following section is unlikely to be useful to general contributors to Servable, and is reserved for project maintainers.
Release
In order to release a version of Servable you can kick off this process by running node publish
. This will kick off the release process. Following the steps it guides you through should lead to a successful release. Please contact me or message me on the Servable Slack (Charlie Fish) if you have questions or run into any issues.
It is important to note that you must have write permissions to the main
branch in order for this process to be successful.