All contributions are welcome.
There are different ways in which you can contribute to Tracks.
You can contribute documentation in the wiki.
For example:
- tutorials on installing Tracks in various environments
- tutorials on using Tracks (user manual)
If you think having found a problem with Tracks, first search in the existing issues. If you cannot find it, open a new issue and try providing information on your setup and what steps are needed to reproduce the problem.
It would be great to first discuss them on the mailing list so you can figure out if it could be merged or not. You may use the wiki too to describe your change if it is too big for an email.
If you want to contribute an enhancement or a fix, you can:
- fork the project
- create a topic branch.
- install docker-compose
- copy
app/config/site.yml.tmpl
toapp/config/site.yml
and customize as needed - then with
./bin/setup
you will prepare for the first run - start the server with
./script/server
which will start everything you need in Docker and present Tracks at http://0.0.0.0:3000 - if you need, you can launch a Rails console with
./bin/rails c
(will run inside Docker) - make your changes and add/update relevant tests
- run the test suite with
./bin/rake test
(will run inside Docker) - commit the changes
- send a pull request.
Make sure that you've added the necessary tests for any new functionality and preferably also for any bugs and that your contribution conforms to the coding style defined by the CodeClimate checks. The coding style definition should be approximately the same as the Shopify Ruby Style Guide.