Skip to content

Latest commit

 

History

History
102 lines (70 loc) · 3.84 KB

README.adoc

File metadata and controls

102 lines (70 loc) · 3.84 KB

Coding Dojo Kata’s for TDD (Test-Driven-Development)

This repository holds the sources for the TDD Dojo Kata’s for practising TDD.

What is TDD?

TDD (Test-Driven-Development) is a software development technique, where the developers at first specify the tests, and then implement the code to satisfy the specified tests. The developers consider the requirements and edge cases more, by specifying the tests at first, rather than by implementing the code and test after.

TDD in common encourages developers to use more simple design and inspires confidence, because the code is well tested.

TDD lifecycle:

  1. Add a test
    Specify and implement the test first

  2. Run all tests
    Run all the tests, and see the newly specified test failing for expected reasons

  3. Write the simplest code that passes the new test
    Write nothing more but just the simplest solution to satisfy the requirement of the test

  4. All tests should now pass
    Run all the tests and refactor the code until the test has been satisfied and no existing and already satisfied tests fail

  5. Refactor as needed
    Refactor the code for better readability, and after each refactoring step run all the tests again and see if something breaks

  6. Repeat the steps
    Repeat these steps for each new functionality needed

As you can see, TDD is not hard to understand and not hard to achieve, so give it a try and see how it feels.

Setup

You will need the following tooling installed to get the project set up.

  • Maven 3.x

  • Java 17

  • IDE of your choice

If you want to keep the implementations you made, then just fork this repository.

Kata Description

This application represents a simple Store where a bill can be calculated for several products. This application can only be executed via unit tests and does ont need any specific runtime environment. There are junit test class skeletons where the requirements are documented via Java comments.

Developers need to implement the requirements with a TDD approach.

The unit tests are written with JUnit5 and can be asserted with AssertJ.

Scenario

The existing application can calculate the gross price of the Products which are provided to the BillCalculator. Now it has been decided that customers are treated differently depending on their loyalty to the store which is measured in days. Additionally, some constraints need to be implemented to several classes to make the application more resilient for invalid inputs, which caused problems in the past.

A developer already started to implement a calculation strategy and some classes for the different calculations. Also test classes have been created which contain the new requirements as Java comments. Unfortunately, the developer has left, and now it’s up to you to finish the Job.

Tasks

Work through the test classes and implement the documented requirements with TDD. Write at least one test for each requirement and only provide the necessary new code or refactoring to satisfy the single requirement, even if you have to refactor your own code by implementing the following requirements.

Recommendations

Name your test methods in a way so that another developer gets a pretty good feeling about what is tested under what conditions.

I recommend the naming scheme then_when e.g.:

  • throwsIllegalArgumentException_whenIdIsNull

  • activatedNewCustomerPriceStrategy_whenCustomerIsNew

  • constraintViolated_whenFoodProductCountIsLargerThan300

Additionally, you can structure the test with nested classes.
The following code snipped shows nested test classes which would lead to a test name formatted as ProductTest$CommonTest$IdTest.throwsIllegalArgumentException_whenNull.

class ProductTest {

    @Nested
    class CommonTest {

        @Nested
        class IdTest {

            @Test
            void throwsIllegalArgumentException_whenNull() {

            }
        }
    }
}