We value any contribution to cartage-rack you can provide: a bug report, a feature request, or code contributions. cartage-rack is reasonably complex code, so there are a few contribution guidelines:
- Changes will not be accepted without tests. The test suite is written with Minitest.
- Match our coding style.
- Use a thoughtfully-named topic branch that contains your change. Rebase your commits into logical chunks as necessary.
- Use quality commit messages.
- Do not change the version number; when your patch is accepted and a release is made, the version will be updated at that point.
- Submit a GitHub pull request with your changes.
cartage-rack uses Ryan Davis’s Hoe to manage the release process, which adds a number of rake tasks. You will mostly be interested in:
$ rake
which runs the tests the same way that:
$ rake test
$ rake travis
will do.
To assist with the installation of the development dependencies for
cartage-rack, I have provided the simplest possible Gemfile pointing to the
(generated) cartage-rack.gemspec
file. This will permit you to do:
$ bundle install
to get the development dependencies. If you aleady have hoe
installed, you
can accomplish the same thing with:
$ rake newb
This task will install any missing dependencies, run the tests/specs, and generate the RDoc.
Here's the most direct way to get your work merged into the project:
- Fork the project.
- Clone down your fork (
git clone git://github.com/KineticCafe/cartage-rack.git
). - Create a topic branch to contain your change (
git checkout -b my_awesome_feature
). - Hack away, add tests. Not necessarily in that order.
- Make sure everything still passes by running
rake
. - If necessary, rebase your commits into logical chunks, without errors.
- Push the branch up (
git push origin my_awesome_feature
). - Create a pull request against KineticCafe/cartage-rack and describe what your change does and the why you think it should be merged.
- Austin Ziegler created cartage-rack.
- Jesse Mignac added support for
$APP_ENV
.