This session will be fun. That's the primary objective, have fun and code ... that's it! In this session we will talk for a little bit about why XP practices are important and then we can write some code practicing two of the most fundamental ones. The code will be super easy, this is not about writing complicated code ... quite the opposite. We will get pairs of you to build really simply test driven code. It will make you rethink how you write code from now on. For those of you after more of a challenge, we have included some optional Object Oriented (calisthenics) rules to apply.
Come in pairs or make new friends on the day. Please all bring your own laptop (we dont have any to share) with your favourite IDE installed (we will have prepared using IntelliJ and trust that Eclipse will work).
Two key things to learn / practice in this Kata:
- Test Driven Development
- Pair programming
This is the Kotlin version of the kata. If you would prefer to use java, please open the tdd-bank-account-java kata.
Note: Use the Kotlin Koans to familiarise yourselves with the Kotlin language
-
Clone the repository with the following command.
git clone https://github.com/xp-dojo/tdd-bank-account-java
If you have problems with SSL, you can try the following.
git clone -c http.sslVerify=false https://github.com/xp-dojo/tdd-bank-account-java
If you have problems with a proxy, you can
unset http_proxy
andunset https_proxy
(or equivalent for your OS). -
Open the project from IntelliJ IDEA (community edition is fine) using
File -> Open
, then selectbuild.gradle
from the project and thenOpen as Project
. If given the option, please use the Gradle Wrapper option as this has been tested. -
Implement the following user requirements in a TDD fashion. Work in pairs and read the guidelines and background information below before starting.
- I can Deposit money to accounts
- I can Withdraw money from accounts
- I can Transfer amounts between accounts (if I have the funds)
- I can print out an Account balance slip (date, time, balance)
- I can print a statement of account activity (statement)
- I can apply Statement filters (include just deposits, withdrawal, date)
Test driven development is based on the principles of test-first development (where you write the test first) but goes an extra step to actually driving the code using the IDE. The basic cycle follows the Red -> Green -> Refactor model:
- Red: write a failing test. Write a test that describes (think documentation) what the function you are writing actually does. Likely this will not even compile (this is fine, not compiling IS a failing test).
- Green: now write enough of an implementation to make the test pass. You should write the simplest code possible to make the code pass and resist the urge to write more than is actually needed. Consider the YAGNI principle.
- Refactor: now we re-read the code and make sure that this is good enough to push to the world at large. You should ask yourself at this point how the next person that reads this code will experience it.
As a walkthrough consider applying TDD as a two stage process, the first phase writes the API in the test as it should be (write the code you would like someone else to have written for you). In this case the compiler IS the failing test, you rewrite it until you are happy and then to make it go green you use the IDE to create the classes and methods as per the test (dont type them, let the IDE do the work). The next phase of the cycle implements the methods to get the unit tests passing, followed by the refactoring to complete the RGR cycle described above. The key message here is that you should consider the compiler failing as a failing test to allow you to get it green (alt+enter until it all compiles).
There are many different ways to do pair programming, the most common model is the Driver-Navigator model. For this kata, try and follow as below for simplicity. There are two roles in this model (you should switch often to keep it interesting):
- The Driver is the person wiring the code (test driven) and implementing. The Driver should be explaining what they are doing in a running monologue so the Navigator understands the direction taken and can assess it (also it keeps the Navigator engaged).
- The Navigator is the person observing and thinking about the big picture. The best Navigators are those that ask why? often to check that we build the right thing, and build the thing right. For this kata, the Navigator is checking that they are really test driving (using the IDE) and that the code does what it says and says what it does. When applying object calisthenics the Navigator should be checking that the Nine rules are not being broken. Correction and learning is the key here.
Object calisthenics are a set of rules or constraints designed to challenge and stretch yourself when applied to OO coding. For an extra challenge when implementing the user requirements, consider applying rules below.
- Use only one level of indentation per method
- Don’t use the
else
keyword - Wrap all primitives and strings (in an object)
- No getters/setters/properties
- First class collections
- Use only one dot per line
- Don’t abbreviate
- Keep all entities small (50 lines)
- No classes with more than two instance variables
See the links below for more details.
- Project based on the original from Sandro Mancuso and the LSCC
- Original idea for the kata: How Object-Oriented Are You Feeling Today? - Krzysztof Jelski (Session on the Software Craftsmanship UK 2011 conference)
- Object Calisthenics pdf
- Object Calisthenics (full book), Jeff Bay in: The ThoughtWorks Anthology. Pragmatic Bookshelf 2008