Welcome to the testing workshop, a practical guide into testing in the Java world!
Is this a complete testing bible? No! This is a workshop into how to test your (or someone else's) code with practical tips how to write code that is easier to test and what tools can be used to do it.
Your task is to get to know testing tools and the goal is to get a high test coverage.
There are a few sessions that you can go through, either all in a row or one at a time. Read the readme.md for each session to get the details. Every session has a specific task and each session has its own branch. To get the code and session practices, checkout the branch and start coding!
There are several ways to get test coverage. For these exercises JaCoCo (Java Code Coverage) is already configured and you can get the result locally. JaCoCo creates a binary report, to be able to read it as a human being we need to create the report:
any-user$ mvn clean test jacoco:report
Note that the JaCoCo report itself is created in the test phase, the jacoco:report
command generates an html based report from the binary analysis. To run the test only, without the report creation, just remove the jacoco
statement.
Now there is an index.html that can be opened in your favourite web browser:
mac-user$ open target/site/jacoco/index.html
or for a Linux user:
linux-user$ xdg-open target/site/jacoco/index.html
Here follows a brief explanation of the sessions in this workshop.
How do we deal with code that already exists which is untested? Write tests! First session and introduction to some test tools.
To continue with the Test On Existing Code session, do a checkout on the branch and open this file again:
git pull
git checkout create-tests-on-existing-code
Mock it, and mock some more. When code relies on other methods, classes, requests we have the power to fake them away, even spy on them.
To continue with the Deal With External Code session, do a checkout on the branch and open this file again:
git pull
git checkout deal-with-external-code
Dream Scenario, you have the power to be the first developer and your spec is clear as whisky. Hello TDD!
To continue with the Test Driven Development session, do a checkout on the branch and open this file again:
git pull
git checkout test-driven-development
Spring Boot (2) comes with a lot of testing tools. If you are going to code and test in Spring Boot, check this chapter.
To continue with the Spring Boot 2 session, do a checkout on the branch and open this file again:
TODO: Move from another workshop into this. Out of scope right now.
git pull
git checkout spring-boot-2
There are test tools and then there are test tools. This is the test tool for a developer. Why? Well, check it out.
To continue with the Another Language session, do a checkout on the branch and open this file again:
git pull
git checkout another-language-groovy
For a deeper and automatic analysis there are some great server side tools. SonarQube and Codecov both run triggered by a build server (Jenkins, Travis etc). As a side note, SonarQube gives more than code coverage like Code Smell, Vulnerabilities, Build Statistics. There is also a very powerful and free plugin called SonarLint that can be installed in your IDE and it will give you direct feedback. You don't need a Sonar server to run the plugin. Use it!
Unfortunately a great tool died when Java 9 arrived. The Maven Corbetura plugin doesn't work any longer because of the missing tools jar that no longer exists. If you still are on Java 8, try it out. The plugin can be executed without changes to the POM file.
This workshop is based on Maven and also Spring Boot but there is no need to use the Spring Boot test support until later in the workshop. You can use standard libraries for testing until it's time to check in the Spring Boot test support.