Skip to content

marcingrzejszczak/mockito-cookbook

Repository files navigation

"Mockito Cookbook" Code Repository

This repository contains code present in my "Mockito Cookbook" published by Packt Publishing. You can buy the book here

The structure

Project structure

It's a multimodule project where each module represents a particular chapter of the book

  • chapter01
  • chapter02
  • ...
  • chapter10
  • common (classes used by all modules)
  • common test (test classes used by all modules)

Module structure

Each chapter contains the following package structure (example for chapter01):

chapter01
    src
        main
            java
                com
                    blogspot
                        toomuchcoding
                            chapter1
        test
            java
                com
                    blogspot
                        toomuchcoding
                            chapter1

The contents of chapters differ so in each "chapter" package (in the example above it's "chapter1" package) you will have packags related to the given chapter in the book. To make it easier for you to find the desired class I've named the chapter related packages in the following manner (example for Chapter 1):

_1_MockitoAnnotationsJunitRunner
_2_MockitoAnnotationsJunit
_3_MockitoAnnotationsTestNg
_4_MockitoGoodPractices
_5_AddingMockitoHintsToExceptionMessages

The prefix is given to sort packages in the order presented in the book. After the prefix you have the name of the recipe inside the chapter. Now let's take a look at the structure of a recipe inside this code repository:

_4_MockitoGoodPractices
    assertj
        TaxFactorCalculatorTest.java
        TaxFactorCalculatorTestNgTest.java
    fancy
        assertj
            TaxFactorCalculatorTest.java
            TaxFactorCalculatorTestNgTest.java
        hamcrest
            TaxFactorCalculatorTest.java
            TaxFactorCalculatorTestNgTest.java
    hamcrest
        TaxFactorCalculatorTest.java
        TaxFactorCalculatorTestNgTest.java

In the book in the majority of examples I'm using AssertJ for asserting objects. Since not everyone is using it and there are people who prefer to use Hamcrest that's why you can find (almost in every recipe) two packages assertj and hamcrest where you can find the same examples using two different libraries for assertions. The fancy package in the 1st chapter 4th recipe means that there is an additional example in the book. It's related to a fancy way of creating code that's why the package is named fancy. Inside that package yet again you have to approaches of asserting objects - with assertj and hamcrest. Last but not least each of the tests (almost in every recipe) is written once for JUnit and once for TestNG.

How to build it

You can build the app using gradle

    ./gradlew build

or maven

   mvn clean install

Contact

In case of any issues, doubts or if you need help with understanding sth just contact me either via email - marcin(at)grzejszczak.pl or via my blog at http://toomuchcoding.blogspot.com, or my homepage http://www.marcin.grzejszczak.pl, or Twitter - @MGrzejszczak.

Mockito Cookbook Google Group

There is also the Mockito Cookbook Google Group where you can share your thoughts on whatever is related to the book or any topic related to Mockito.

Build status

Build Status

Bitdeli Badge