From f106857e17e7a6a8b70084c6a7a5c2b476c6bc76 Mon Sep 17 00:00:00 2001 From: rayankonecny Date: Sat, 13 Dec 2025 13:19:51 +0000 Subject: [PATCH] add integration test to find by id user controller --- .../impl/UserControllerImpTest.java | 46 +++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 user-service-api/src/test/java/br/com/rayankonecny/userserviceapi/controller/impl/UserControllerImpTest.java diff --git a/user-service-api/src/test/java/br/com/rayankonecny/userserviceapi/controller/impl/UserControllerImpTest.java b/user-service-api/src/test/java/br/com/rayankonecny/userserviceapi/controller/impl/UserControllerImpTest.java new file mode 100644 index 0000000..466c3fc --- /dev/null +++ b/user-service-api/src/test/java/br/com/rayankonecny/userserviceapi/controller/impl/UserControllerImpTest.java @@ -0,0 +1,46 @@ +package br.com.rayankonecny.userserviceapi.controller.impl; + +import static br.com.rayankonecny.userserviceapi.creator.CreatorUtils.generateMock; + +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.ActiveProfiles; +import org.springframework.test.web.servlet.MockMvc; + +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; + +import br.com.rayankonecny.userserviceapi.entity.User; +import br.com.rayankonecny.userserviceapi.repository.UserRepository; + +@SpringBootTest +@AutoConfigureMockMvc +@ActiveProfiles("test") +public class UserControllerImpTest { + + @Autowired + private MockMvc mockMvc; + + @Autowired + private UserRepository userRepository; + + @Test + void testFindByIdWithSucces() throws Exception { + final var entity = generateMock(User.class); + final var userId = userRepository.save(entity).getId(); + + mockMvc.perform(get("/api/users/{id}", userId)) + .andExpect(status().isOk()) + .andExpect(jsonPath("$.id").value(userId)) + .andExpect(jsonPath("$.name").value(entity.getName())) + .andExpect(jsonPath("$.email").value(entity.getEmail())) + .andExpect(jsonPath("$.password").value(entity.getPassword())) + .andExpect(jsonPath("$.profiles").isArray()); + + userRepository.deleteById(userId); + } + +}