Jump to: navigation, search

Rally/Develop

< Rally
Revision as of 12:18, 21 May 2014 by Mikhail Dubov (talk | contribs) (Added a link to the "concepts" page)

Improve Rally

Main directions of work

  • Benchmarks. Improvements in the benchmarking engine & developing new benchmark scenarios.
  • Deployments. Making Rally able to support multiple cloud deployment facilities, e.g. Fuel.
  • CLI. Enriching the command line interface for Rally.
  • API. Work around making Rally to be a Benchmark-as-a-Service system & developing rally-pythonclient.
  • Incubation. Efforts to make Rally an integrated project in OpenStack.
  • Share system. Benchmark results visualization and paste.openstack.org-like sharing system.
  • Tempest. Integration of Tempest tests in Rally for deployment verification.


Where to begin

It is extremetly simple to participate in different Rally development lines mentioned above. The Good for start section of our Trello board contains a wide range of tasks perfectly suited for you to quickly and smoothly start contributing to Rally. As soon as you have chosen a task, just log in to Trello, join the corresponding card and move it to the In progress section.

The most Trello cards contain basic descriptions of what is to be done there; in case you have questions or want to share your ideas, be sure to contanct us at the #openstack-rally IRC channel on irc.freenode.net.

If you want to grasp a better understanding of several main design concepts used throughout the Rally code (such as benhmark scenarios, contexts etc.), please read this article.


How to contribute

1. You need a Launchpad account and need to be joined to the Openstack team. You can also join the Rally team if you want to. Make sure Launchpad has your SSH key, Gerrit (the code review system) uses this.

2. Sign the CLA as outlined in section 3 of the How To Contribute wiki page.

3. Tell git your details:

git config --global user.name "Firstname Lastname"
git config --global user.email "your_email@youremail.com"

4. Install git-review. This tool takes a lot of the pain out of remembering commands to push code up to Gerrit for review and to pull it back down to edit it. It is installed using:

pip install git-review

Several Linux distributions (notably Fedora 16 and Ubuntu 12.04) are also starting to include git-review in their repositories so it can also be installed using the standard package manager.

5. Grab the Rally repository:

git clone git@github.com:stackforge/rally.git

6. Checkout a new branch to hack on:

git checkout -b TOPIC-BRANCH

7. Start coding

8. Run the test suite locally to make sure nothing broke, e.g.:

./run_tests.sh

If you extend Rally with new functionality, make sure you also have provided unit tests for it.

9. Commit your work using:

git commit -a

or you can use the following to edit a previous commit:

git commit -a --amend

Make sure you have supplied your commit with a neat commit message, containing a link to the corresponding blueprint / bug, if appropriate.

10. Push the commit up for code review using:

git review -R

That is the awesome tool we installed earlier that does a lot of hard work for you.

11. Watch your email or review site, it will automatically send your code for a battery of tests on our Jenkins setup and the core team for the project will review your code. If there are any changes that should be made they will let you know.

12. When all is good the review site will automatically merge your code.


(This tutorial is based on: http://www.linuxjedi.co.uk/2012/03/real-way-to-start-hacking-on-openstack.html)