We love pull requests. Here's a quick guide:
- Check for existing issues for duplicates and confirm that it hasn't been fixed already in the master branch
- Fork the repo, and clone it locally
npm link
to make your cloned repo available to npm- Follow Getting Started to generate a testbot
npm link hubot
in your newly created bot to use your hubot fork- Create a new branch for your contribution
- Add tests (run with
npm test
) - Push to your fork and submit a pull request
At this point you're waiting on us. We like to at least comment on, if not accept, pull requests within a few days. We may suggest some changes or improvements or alternatives.
Some things that will increase the chance that your pull request is accepted:
-
Use CoffeeScript idioms and style guide
-
Update the documentation: code comments, example code, guides. Basically, update anything is affected by your contribution.
-
Include any information that would be relevant to reproducing bugs, use cases for new features, etc.
-
Discuss the impact on existing hubot installs, hubot adapters, and hubot scripts (e.g. backwards compatibility)
- If the change does break compatibility, how can it be updated to become backwards compatible, while directing users to the new way of doing things?
-
Your commits are associated with your GitHub user: https://help.github.com/articles/why-are-my-commits-linked-to-the-wrong-user/
-
Make pull requests against a feature branch,
-
Don't update the version in
package.json
, as the maintainers will manage that in a follow-up PR to release
Syntax:
- Two spaces, no tabs.
- No trailing whitespace. Blank lines should not have any space.
- Prefer
and
andor
over&&
and||
- Prefer single quotes over double quotes unless interpolating strings.
MyClass.myMethod(my_arg)
notmyMethod( my_arg )
ormyMethod my_arg
.a = b
and nota=b
.- Follow the conventions you see used in the source already.
This section is for maintainers of hubot. Here's the current process for releasing:
- create a
release-vX.X.X
branch to release off of - determine what version to release as:
- bug fix? patch release
- new functionality that is backwards compatible? minor version
- breaking change? major release, but think about if it can be fixed to be a minor release instead
- update
package.json
- summarize changes in
CHANGELOG.md
- create a pull request, and cc pull requests included in this release, as well as their contributors
- merge pull request
- checkout master branch, and run
script/release