From 36f6a577b110dbe0f7a25453564b41597112264a Mon Sep 17 00:00:00 2001 From: Shyam Vishwakarma <144812100+Shyam-Vishwakarma@users.noreply.github.com> Date: Wed, 23 Oct 2024 18:15:58 +0530 Subject: [PATCH] Add integration tests for GET v1/skills route (#161) * add integration tests for GET v1/skills, add test DB configuration * fix format violation --- .../resources/application-test.properties | 8 ++ .../skills/GetAllSkillsIntegrationTest.java | 95 +++++++++++++++++++ 2 files changed, 103 insertions(+) create mode 100644 skill-tree/src/main/resources/application-test.properties create mode 100644 skill-tree/src/test/java/com/RDS/skilltree/skills/GetAllSkillsIntegrationTest.java diff --git a/skill-tree/src/main/resources/application-test.properties b/skill-tree/src/main/resources/application-test.properties new file mode 100644 index 00000000..02c453f3 --- /dev/null +++ b/skill-tree/src/main/resources/application-test.properties @@ -0,0 +1,8 @@ +cookieName=rds-session-v2-development + +spring.datasource.url=jdbc:mysql://${MYSQL_HOST:localhost}:${MYSQL_PORT:3306}/skilltreetestdb +spring.datasource.username=${MYSQL_DB_USERNAME} +spring.datasource.password=${MYSQL_DB_PASSWORD} +spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver +spring.jpa.hibernate.ddl-auto=create-drop +spring.jpa.show-sql=true diff --git a/skill-tree/src/test/java/com/RDS/skilltree/skills/GetAllSkillsIntegrationTest.java b/skill-tree/src/test/java/com/RDS/skilltree/skills/GetAllSkillsIntegrationTest.java new file mode 100644 index 00000000..b16ac200 --- /dev/null +++ b/skill-tree/src/test/java/com/RDS/skilltree/skills/GetAllSkillsIntegrationTest.java @@ -0,0 +1,95 @@ +package com.RDS.skilltree.skills; + +import com.RDS.skilltree.enums.SkillTypeEnum; +import com.RDS.skilltree.models.Skill; +import com.RDS.skilltree.repositories.SkillRepository; +import com.RDS.skilltree.services.SkillService; +import jakarta.servlet.http.Cookie; +import java.util.Arrays; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +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.http.MediaType; +import org.springframework.test.context.ActiveProfiles; +import org.springframework.test.web.servlet.MockMvc; +import org.springframework.test.web.servlet.request.MockMvcRequestBuilders; +import org.springframework.test.web.servlet.result.MockMvcResultHandlers; +import org.springframework.test.web.servlet.result.MockMvcResultMatchers; + +@SpringBootTest +@AutoConfigureMockMvc +@ActiveProfiles("test") +public class GetAllSkillsIntegrationTest { + + @Autowired private SkillService skillService; + + @Autowired private SkillRepository skillRepository; + + @Autowired private MockMvc mockMvc; + + private Cookie authCookie; + + @BeforeEach + public void setUp() { + authCookie = + new Cookie( + "rds-session-v2-development", + "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiJzOXpRVW00WGJWRXo3eHpSa2FadiIsInJvbGUiOiJzdXBlcl91c2VyIiwiaWF0IjoxNzI4NjY0NjA2LCJleHAiOjE3MzEyNTY2MDZ9.EyOFKrVcbleuTjUGic3GzOzYRDoLU4IShyoboe0MHlvWFOAfU2pchpXLE4NcyvdGUZ_tvoUecHd4kUkR8MkhxnkRNU3HE7N-1c1tFeYXZL0KfScJE9YzDXAl113Hx3eZVvYbhNjNUttbDlH4s_kR6YABC3sdbLGKEiLfmp9VeAs"); + + skillRepository.deleteAll(); + Skill skill1 = new Skill(); + skill1.setName("Java"); + skill1.setType(SkillTypeEnum.ATOMIC); + skill1.setCreatedBy("s9zQUm4XbVEz7xzRkaZv"); + + Skill skill2 = new Skill(); + skill2.setName("Springboot"); + skill2.setType(SkillTypeEnum.ATOMIC); + skill2.setCreatedBy("s9zQUm4XbVEz7xzRkaZv"); + + skillRepository.saveAll(Arrays.asList(skill1, skill2)); + } + + @Test + @DisplayName("happy flow - returns all skills that are in db") + public void getAllSkillsHappyFlow() throws Exception { + + mockMvc + .perform( + MockMvcRequestBuilders.get("/v1/skills") + .cookie(authCookie) + .accept(MediaType.APPLICATION_JSON)) + .andExpect(MockMvcResultMatchers.status().isOk()) + .andExpect(MockMvcResultMatchers.jsonPath("$[0].name").value("Java")) + .andExpect(MockMvcResultMatchers.jsonPath("$[1].name").value("Springboot")) + .andDo(MockMvcResultHandlers.print()); + } + + @Test + @DisplayName("if no skills available, return empty list") + public void noSkillsAvailable_shouldReturnEmptyList() throws Exception { + skillRepository.deleteAll(); + + mockMvc + .perform( + MockMvcRequestBuilders.get("/v1/skills") + .cookie(authCookie) + .accept(MediaType.APPLICATION_JSON)) + .andExpect(MockMvcResultMatchers.status().isOk()) + .andExpect(MockMvcResultMatchers.jsonPath("$").isEmpty()); + } + + @Test + @DisplayName("if invalid cookie, return 401") + public void ifInvalidCoolie_returnUnauthorized() throws Exception { + mockMvc + .perform( + MockMvcRequestBuilders.get("/v1/skills") + .cookie(new Cookie("cookie1", "eyJhbGciOiJSUz.eyJhbGciOiJSUz.EyJhbGciOiJSUz")) + .accept(MediaType.APPLICATION_JSON)) + .andExpect(MockMvcResultMatchers.status().isUnauthorized()); + } +}