Active involvement from the community is essential to help make famous the most capable and performant front-end JavaScript framework out there. You can help by reporting bugs, fixing bugs, adding features, contributing new modules and by providing feedback.
Famo.us is a framework that is always testing the limits of where browsers can go. As a result, it's likely that you may encounter bugs or other issues while developing with it.
If you think you've encountered a bug, do the following:
- Make sure you are working with the latest version of the Famo.us
master
branch. - Browse through the issues to check if anyone else has already reported. If someone has, feel free to add more information to that issue to help us solve it.
- If no one has yet submitted the issue you are encountering, check the guidelines for deciding where to file your issue. Please be sure to include as much information as possible, include errors, warnings, screenshots, links to a video showing the problem or code that can reproduce the issue.
The Famo.us framework is made possible by open source contributors like you. We're very interested in getting help from the greater community, but before you start it's important that you become acquainted with our workflow. Following these guidelines below will make collaboration much smoother and increase the chances that we will accept your pull request without hiccups.
Our development process is very similar to the approach described in the well-known article A Successful Git Branching Model by Vincent Driessen. Here's an overview:
- Our
master
branch is the branch upon which Famo.us developers should be basing their work on. Themaster
branch is not guaranteed to be stable. - All commits intended for
master
should take place on your own personal fork, and be submitted via pull request when ready. - Only maintainers can accept pull requests from forks into the core Famo.us repository.
- Please squash your commits into a single commit before making a pull request.
- Make sure you have a GitHub account
- Fork famous
- Keep your fork up to date. Famo.us is a fast moving project, and things are changing all the time. It's important that any changes you make are based on the most recent version of famous, since it's possible that something may have changed that breaks your pull request or invalidates its need.
- Make sure you have a Contributor License Agreement on file.
- Read on ...
Before we can accept any contributions to Famo.us, we first require that all individuals or companies agree to our Contributor License Agreement (CLA). The e-mail address used in the pull request will be used to check if a CLA has already been filed, so be sure to list all email addresses that you might use to submit your pull requests when filling it out. Our CLA can be found here.
Travis-ci is integrated into all of our submodules to automatically run tests on our codebase. All pull requests must pass our tests before they can be merged. Currently, the only test we support is a linting test. This ensures a consistently styled codebase. Before making a pull request, please run our linter locally. From the submodule directory, execute
npm install
npm test
The created node_modules
folder will be ignored in your push by our .gitignore
file.
All pull requests submitted to Famo.us should occur on a new branch. For these
branches, we at famous use a short token indicating the nature of the branch in
question followed by a solidus (/
) and a kebab-cased string describing the
branch. We are using the following tokens:
bug // bug fixes
wip // work in progress
feat // feature
Bug fixes follow a slightly different format.
If you'd like to contribute a fix for a bug you've encountered, first read up on how to report a bug and report it so we are aware of the issue. By filing the issue first, we may be able to provide you with some insight that guides you in the right direction.