Opleiding: Unit Testing in Java

Be more productive by practicing Test-Driven Development (TDD), leveraging advanced tools and frameworks, and applying specialized code patterns.

Description

This practical course will teach you everything you need to know to write effective and maintainable unit tests using Java.

  You'll learn how to use Test-driven development (TDD) to catch bugs early, as well as when to use black-box vs. white-box testing. We'll also dive into the 'world of mocking' with the Mockito mocking library, showing you why and how to use it effectively. You'll learn about coverage metrics like code coverage and mutation testing, and we'll explore best practices to help you write efficient and high-quality tests. We will end by implementing integration testing with Testcontainers, so you can be confident that your code works seamlessly with other parts of your system.

At the end of this course, you'll be well-equipped to write unit tests that catch bugs early, reduce maintenance costs, and help you become a better Java developer.

AI-Boosted: You'll learn how to generate unit tests with Github Copilot, and how to influence generation results using a Github Copilot instruction file.

Learning Goals

  • Construct effective basic unit tests. [Apply]
  • Understand the principles of the testing pyramid and its role in shaping an effective testing strategy. [Understand]
  • Apply the Test-driven development (TDD) methodology when creating unit tests and production code. [Apply]
  • Apply the concept of mocking in your unit tests with a common mock framework. [Apply]
  • Investigate the different ways of how to measure the quality of your test code. [Analyze]
  • Construct unit tests using the de facto frameworks. [Apply]
  • Construct integration tests using TestContainers. [Apply]
  • Explain best practices for maintainable tests. [Understand]

Subjects

  1. About testing
  2. Unit testing basics
  3. Test-driven development (TDD)
  4. Concept of mocking
  5. Code coverage
  6. Mocking with Mockito
  7. JUnit 5
  8. Best practices
  9. Mutation testing
  10. Integration testing
About testing

In this chapter, you will learn the basics of testing. Why we test and what kind of tests there are.

Goals:

  • Know the difference between linting and testing.
  • Learn how to categorize all the different kinds of tests.
  • Know the testing pyramid and how it can help you to reason about test levels.
  • Learn the common anti-patterns and how to recognize them
Unit testing basics

In this chapter, we'll learn the basics of unit testing using the practical example.

Goals:

  • Learn how to define the 'unit' to test.
  • Learn the difference between white-box and black-box testing.
  • Learn to recognize and use naming strategies for our tests.
  • Know how to determine when you are 'done' with unit testing.
  • Learn basic best practices
  • Lab: implement unit tests for a simple library.
Test-driven development (TDD)

In this chapter, you will learn what TDD is by example.

Goals:

  • Learn TDD using the red-green-refactor cycle.
  • Lab: Implement a simple library function in a TDD way
Concept of mocking

In this chapter, you will learn what 'mocking' entails and identify where you should use it by identifying your 'system under test' (SUT) and splitting from your 'dependencies'

Goals:

  • Learn to identify the SUT from its dependencies
  • Learn how to write a mock by hand
  • Understand the need for dependency injection when working with mocks.
  • Lab: implement dependency injection and setup mocking using classes.
Code Coverage

In this chapter, we will focus on testing metrics, namely code coverage. Goals:

  • Know what the difference is between code coverage and mutation testing.
  • Know what kinds of coverage metrics there are and how to choose between them.
  • Learn the benefits of a quick feedback cycle with code coverage.
  • Learn how to run code coverage on our code using the command line.
  • Know how to 'break the build' when coverage is too low.
  • Lab: use code coverage to improve our tests.
Mocking with Mockito

In this chapter, you will learn to use a mocking library. We will focus on Mockity, the most popular mocking library.

Goals:

  • Learn how to install Mockito in your project
  • Learn the API; how to create mocks, configure them using when() and verify behavior using verify()
  • Know to use argument matchers.
  • Lab: Implement your tests using Mockito
JUnit 5

In this chapter, we look closely at JUnit, Java's most popular testing framework.

Goals:

  • Know the different parts that make up the JUnit platform
  • Learn to work with the assertions API.
  • Learn how 'assumptions' can help in advanced scenarios.
  • Learn the test lifecycle and how to use it to improve our tests.
  • Lab: Improve our test maintainability using features of JUnit
Best practices

In this chapter, we will look at some best practices we can use to improve the maintainability of our tests further.

Goals:

  • Know how to identify tests that are too DRY (Don't Repeat Yourself) or too WET (We Like Typing).
  • Learn to prefer DAMP tests (Descriptive and Meaningful Phrases).
  • Know when to use a builder pattern
  • Know where to find more best practices
  • Lab: Implement DAMP tests using the builder pattern.
Mutation testing

In this chapter, we will focus on testing metrics, namely mutation testing.

Goals:

  • Know what the difference is between code coverage and mutation testing
  • Understand how mutation testing works conceptually.
  • Learn what the "mutation score" metric is
  • Learn how to use Pitest to run mutation testing on Java code.
  • Know how to read a mutation testing report.
  • Know how to 'break the build' when the mutation score is too low.
  • Lab: Improve the effectiveness of your tests using Pitest.
Integration testing

In this chapter, we'll be 'scaling up the pyramid': Welcome to integration testing.

Goals:

  • Be able to identify where an integration test is needed.
  • Learn to identify 'shared state' in dependencies.
  • Learn how to use Testcontainers to create dependencies on the fly.
  • Know what the benefits are of using Testcontainers
  • Learn to organize integration tests inside your project structure.
  • Lab: Implement integration tests for a database using Testcontainers
Meer...
€1.530
ex. BTW
Aangeboden door
Info Support
Onderwerp
Unit Testing
Java
Software Testing
Niveau
Duur
2 dagen
Looptijd
14 dagen
Taal
en
Type product
training
Lesvorm
Klassikaal
Aantal deelnemers
Min: 1
Max: 12
Tijdstip
Overdag
Tijden en locaties
Veenendaal
ma 12 jan. 2026
Keurmerken aanbieder
Microsoft Learning Partner
Cedeo
Cedeo Open
Cedeo Maatwerk