Spring Boot – Rest Controller Unit Test

Last updated on May 30 2022
Amarjit Malik

Table of Contents

Spring Boot – Rest Controller Unit Test

Spring Boot provides an easy way to write a Unit Test for Rest Controller file. With the help of SpringJUnit4ClassRunner and MockMvc, we can create a web application context to write Unit Test for Rest Controller file.

Unit Tests should be written under the src/test/java directory and classpath resources for writing a test should be placed under the src/test/resources directory.

For Writing a Unit Test, we need to add the Spring Boot Starter Test dependency in your build configuration file as shown below.

<dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-test</artifactId>   <scope>test</scope></dependency>

Gradle users can add the following dependency in your build.gradle file.

testCompile(‘org.springframework.boot:spring-boot-starter-test’)

Before writing a Test case, we should first build RESTful web services. For further information on building RESTful web services, please refer to the chapter on the same given in this tutorial.

Writing a Unit Test for REST Controller

In this section, let us see how to write a Unit Test for the REST Controller.

First, we need to create Abstract class file used to create web application context by using MockMvc and define the mapToJson() and mapFromJson() methods to convert the Java object into JSON string and convert the JSON string into Java object.

package com.tecklearn.demo; import java.io.IOException;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import org.springframework.test.context.web.WebAppConfiguration;import org.springframework.test.web.servlet.MockMvc;import org.springframework.test.web.servlet.setup.MockMvcBuilders;import org.springframework.web.context.WebApplicationContext; import com.fasterxml.jackson.core.JsonParseException;import com.fasterxml.jackson.core.JsonProcessingException;import com.fasterxml.jackson.databind.JsonMappingException;import com.fasterxml.jackson.databind.ObjectMapper; @RunWith(SpringJUnit4ClassRunner.class)@SpringBootTest(classes = DemoApplication.class)@WebAppConfigurationpublic abstract class AbstractTest {   protected MockMvc mvc;   @Autowired   WebApplicationContext webApplicationContext;    protected void setUp() {      mvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).build();   }   protected String mapToJson(Object obj) throws JsonProcessingException {      ObjectMapper objectMapper = new ObjectMapper();      return objectMapper.writeValueAsString(obj);   }   protected <T> T mapFromJson(String json, Class<T> clazz)      throws JsonParseException, JsonMappingException, IOException {            ObjectMapper objectMapper = new ObjectMapper();      return objectMapper.readValue(json, clazz);   }}

Next, write a class file that extends the AbstractTest class and write a Unit Test for each method such GET, POST, PUT and DELETE.

The code for GET API Test case is given below. This API is to view the list of products.

@Testpublic void getProductsList() throws Exception {   String uri = “/products”;   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.get(uri)      .accept(MediaType.APPLICATION_JSON_VALUE)).andReturn();      int status = mvcResult.getResponse().getStatus();   assertEquals(200, status);   String content = mvcResult.getResponse().getContentAsString();   Product[] productlist = super.mapFromJson(content, Product[].class);   assertTrue(productlist.length > 0);}

The code for POST API test case is given below. This API is to create a product.

@Testpublic void createProduct() throws Exception {   String uri = “/products”;   Product product = new Product();   product.setId(“3”);   product.setName(“Ginger”);      String inputJson = super.mapToJson(product);   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.post(uri)      .contentType(MediaType.APPLICATION_JSON_VALUE).content(inputJson)).andReturn();      int status = mvcResult.getResponse().getStatus();   assertEquals(201, status);   String content = mvcResult.getResponse().getContentAsString();   assertEquals(content, “Product is created successfully”);}

The code for PUT API Test case is given below. This API is to update the existing product.

@Testpublic void updateProduct() throws Exception {   String uri = “/products/2”;   Product product = new Product();   product.setName(“Lemon”);      String inputJson = super.mapToJson(product);   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.put(uri)      .contentType(MediaType.APPLICATION_JSON_VALUE).content(inputJson)).andReturn();      int status = mvcResult.getResponse().getStatus();   assertEquals(200, status);   String content = mvcResult.getResponse().getContentAsString();   assertEquals(content, “Product is updated successsfully”);}

The code for Delete API Test case is given below. This API will delete the existing product.

@Testpublic void deleteProduct() throws Exception {   String uri = “/products/2”;   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.delete(uri)).andReturn();   int status = mvcResult.getResponse().getStatus();   assertEquals(200, status);   String content = mvcResult.getResponse().getContentAsString();   assertEquals(content, “Product is deleted successsfully”);}

The full Controller Test class file is given below −

package com.tecklearn.demo; import static org.junit.Assert.assertEquals;import static org.junit.Assert.assertTrue; import org.junit.Before;import org.junit.Test;import org.springframework.http.MediaType;import org.springframework.test.web.servlet.MvcResult;import org.springframework.test.web.servlet.request.MockMvcRequestBuilders; import com.tecklearn.demo.model.Product; public class ProductServiceControllerTest extends AbstractTest {   @Override   @Before   public void setUp() {      super.setUp();   }   @Test   public void getProductsList() throws Exception {      String uri = “/products”;      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.get(uri)         .accept(MediaType.APPLICATION_JSON_VALUE)).andReturn();            int status = mvcResult.getResponse().getStatus();      assertEquals(200, status);      String content = mvcResult.getResponse().getContentAsString();      Product[] productlist = super.mapFromJson(content, Product[].class);      assertTrue(productlist.length > 0);   }   @Test   public void createProduct() throws Exception {      String uri = “/products”;      Product product = new Product();      product.setId(“3”);      product.setName(“Ginger”);      String inputJson = super.mapToJson(product);      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.post(uri)         .contentType(MediaType.APPLICATION_JSON_VALUE)         .content(inputJson)).andReturn();            int status = mvcResult.getResponse().getStatus();      assertEquals(201, status);      String content = mvcResult.getResponse().getContentAsString();      assertEquals(content, “Product is created successfully”);   }   @Test   public void updateProduct() throws Exception {      String uri = “/products/2”;      Product product = new Product();      product.setName(“Lemon”);      String inputJson = super.mapToJson(product);      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.put(uri)         .contentType(MediaType.APPLICATION_JSON_VALUE)         .content(inputJson)).andReturn();            int status = mvcResult.getResponse().getStatus();      assertEquals(200, status);      String content = mvcResult.getResponse().getContentAsString();      assertEquals(content, “Product is updated successsfully”);   }   @Test   public void deleteProduct() throws Exception {      String uri = “/products/2”;      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.delete(uri)).andReturn();      int status = mvcResult.getResponse().getStatus();      assertEquals(200, status);      String content = mvcResult.getResponse().getContentAsString();      assertEquals(content, “Product is deleted successsfully”);   }}

You can create an executable JAR file, and run the Spring Boot application by using the Maven or Gradle commands given below −

For Maven, you can use the command given below −

mvn clean install

Now, you can see the test results in console window.

Page 5 Image 1
mvncleaninstall

For Gradle, you can use the command as shown below −

gradle clean build

You can see the rest results in console window as shown below.

Page 6 Image 2 2
results

So, this brings us to the end of blog. This Tecklearn ‘Spring Boot – Rest Controller Unit Test’ blog helps you with commonly asked questions if you are looking out for a job in Java Programming. If you wish to learn Spring Boot and build a career Java Programming domain, then check out our interactive, Java and JEE Training, that comes with 24*7 support to guide you throughout your learning period. Please find the link for course details:

https://www.tecklearn.com/course/java-and-jee-training/

Java and JEE Training

About the Course

Java and JEE Certification Training is designed by professionals as per the industrial requirements and demands. This training encompasses comprehensive knowledge on basic and advanced concepts of core Java & J2EE along with popular frameworks like Hibernate, Spring & SOA. In this course, you will gain expertise in concepts like Java Array, Java OOPs, Java Function, Java Loops, Java Collections, Java Thread, Java Servlet, and Web Services using industry use-cases and this will help you to become a certified Java expert.

Why Should you take Java and JEE Training?

  • Java developers are in great demand in the job market. With average pay going between $90,000/- to $120,000/- depending on your experience and the employers.
  • Used by more than 10 Million developers worldwide to develop applications for 15 Billion devices.
  • Java is one of the most popular programming languages in the software world. Rated #1 in TIOBE Popular programming languages index (15th Consecutive Year)

What you will Learn in this Course?

Introduction to Java

  • Java Fundamentals
  • Introduction to Java Basics
  • Features of Java
  • Various components of Java language
  • Benefits of Java over other programming languages
  • Key Benefits of Java

Installation and IDE’s for Java Programming Language

  • Installation of Java
  • Setting up of Eclipse IDE
  • Components of Java Program
  • Editors and IDEs used for Java Programming
  • Writing a Simple Java Program

Data Handling and Functions

  • Data types, Operations, Compilation process, Class files, Loops, Conditions
  • Using Loop Constructs
  • Arrays- Single Dimensional and Multi-Dimensional
  • Functions
  • Functions with Arguments

OOPS in Java: Concept of Object Orientation

  • Object Oriented Programming in Java
  • Implement classes and objects in Java
  • Create Class Constructors
  • Overload Constructors
  • Inheritance
  • Inherit Classes and create sub-classes
  • Implement abstract classes and methods
  • Use static keyword
  • Implement Interfaces and use it

Polymorphism, Packages and String Handling

  • Concept of Static and Run time Polymorphism
  • Function Overloading
  • String Handling –String Class
  • Java Packages

Exception Handling and Multi-Threading

  • Exception handling
  • Various Types of Exception Handling
  • Introduction to multi-threading in Java
  • Extending the thread class
  • Synchronizing the thread

File Handling in Java

  • Input Output Streams
  • io Package
  • File Handling in Java

Java Collections

  • Wrapper Classes and Inner Classes: Integer, Character, Boolean, Float etc
  • Applet Programs: How to write UI programs with Applet, Java.lang, Java.io, Java.util
  • Collections: ArrayList, Vector, HashSet, TreeSet, HashMap, HashTable

Java Database Connectivity (JDBC)

  • Introduction to SQL: Connect, Insert, Update, Delete, Select
  • Introduction to JDBC and Architecture of JDBC
  • Insert/Update/Delete/Select Operations using JDBC
  • Batch Processing Transaction
  • Management: Commit and Rollback

Java Enterprise Edition – Servlets

  • Introduction to J2EE
  • Client Server architecture
  • URL, Port Number, Request, Response
  • Need for servlets
  • Servlet fundamentals
  • Setting up a web project in Eclipse
  • Configuring and running the web app with servlets
  • GET and POST request in web application with demo
  • Servlet lifecycle
  • Servlets Continued
  • Session tracking and filter
  • Forward and include Servlet request dispatchers

Java Server Pages (JSP)

  • Fundamentals of Java Server Page
  • Writing a code using JSP
  • The architecture of JSP
  • JSP Continued
  • JSP elements: Scriptlets, expressions, declaration
  • JSP standard actions
  • JSP directives
  • Introduction to JavaBeans
  • ServletConfig and ServletContext
  • Servlet Chaining
  • Cookies Management
  • Session Management

Hibernate

  • Introduction to Hibernate
  • Introduction to ORM
  • ORM features
  • Hibernate as an ORM framework
  • Hibernate features
  • Setting up a project with Hibernate framework
  • Basic APIs needed to do CRUD operations with Hibernate
  • Hibernate Architecture

POJO (Plain Old Java Object)

  • POJO (Plain Old Java Object)
  • Persistent Objects
  • Lifecycle of Persistent Object

Spring

  • Introduction to Spring
  • Spring Fundamentals
  • Advanced Spring

Got a question for us? Please mention it in the comments section and we will get back to you.

 

 

 

0 responses on "Spring Boot - Rest Controller Unit Test"

Leave a Message

Your email address will not be published. Required fields are marked *