Sensei runs your dojo for you. You start with a single failing cucumber feature. As you make each feature pass, the next feature is brought into play. While you have failing features, you have the opportunity to write rspec specifications. Sensei will encourage you to refactor at appropriate moments, showing you your flog score as encouragement.
This should replicate an outside-in development style, where the cucumber features represent acceptance/integration tests and the specs are lower level unit tests that help you develop the individual methods and classes.
Running a dojo
gem install sensei git clone git://github.com/alexscordellis/kata-minesweeper.git (or other dojo repository) cd kata-minesweeper sensei
Then follow the instructions. Each time you get to green, sensei will make a commit to git. This way you'll have a history of all your implementation and refactorings. You could then push those changes to a github fork of the dojo repository and compare your solution to others'.
- Try to write the simplest code that will make the next cucumber scenario pass. Try not to anticipate future requirements.
- If the jump from one scenario to the next is too big, or affects more than one behaviour of your program, consider writing rspec specifications that make smaller steps.
- If the cucumber scenario requires a significant change in the implementation, consider refactoring before implementing the new scenario. Make sure that all the previous scenarios are still passing after your refactoring and before you add support for the new scenario.
- Make sure you refactor each time you get to green, to make sure that you're in a good state for the net scenario. Use the flog score to guide your refactoring - a lower flog score is better.
Source is on github. This is a simple implementation of the classic Windows minesweeper game. The features currently available specify how the completed board should appear given the size and the mine locations. This is the original dojo from Matt's session.
Source is on github. This is an interpretation of Uncle Bob's classic Bowling Game kata.
You will need the following gems
Preparing your own dojo
Your project must respond to the commands
rake spec and
cucumber features, issued from the command line in the root directory. Only code matching
./lib/*.rb will be included in the flog score.
The original idea came from Matt Wynne's session at the September 2009 London Ruby Users Group. I've added the rspec part of the workflow and I'm working on the packaging. The features for the minesweeper kata are his.
- Get gem published somewhere
- Provide online repository of known katas
- Add reset functionality (reset current iteration, or reset whole kata, cleaning up branches).
- Autodetect number of iterations (currently assumes 5).
Ultimately the user should be able to do something like:
gem install sensei sensei init minesweeper (downloads dojo code for minesweeper) cd minesweeper sensei start