|
1 | | -package com.somemore.domains.center.controller; |
| 1 | +package com.somemore.center.controller; |
2 | 2 |
|
3 | 3 | import static com.somemore.global.exception.ExceptionMessage.NOT_EXISTS_CENTER; |
4 | 4 | import static org.mockito.Mockito.times; |
|
8 | 8 | import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath; |
9 | 9 | import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; |
10 | 10 |
|
11 | | -import com.somemore.domains.center.dto.response.CenterProfileResponseDto; |
12 | | -import com.somemore.domains.center.usecase.query.CenterQueryUseCase; |
| 11 | +import com.somemore.center.dto.response.CenterProfileResponseDto; |
| 12 | +import com.somemore.center.usecase.NEWCenterQueryUseCase; |
13 | 13 | import com.somemore.global.exception.BadRequestException; |
14 | 14 | import com.somemore.support.ControllerTestSupport; |
15 | 15 | import java.util.List; |
|
23 | 23 | class CenterQueryApiControllerTest extends ControllerTestSupport { |
24 | 24 |
|
25 | 25 | @MockBean |
26 | | - protected CenterQueryUseCase centerQueryUseCase; |
| 26 | + protected NEWCenterQueryUseCase centerQueryUseCase; |
27 | 27 |
|
28 | | - private UUID centerId; |
| 28 | + private UUID userId; |
29 | 29 | private CenterProfileResponseDto responseDto; |
30 | 30 |
|
31 | 31 | @BeforeEach |
32 | 32 | void setUp() { |
33 | | - centerId = UUID.randomUUID(); |
| 33 | + userId = UUID.randomUUID(); |
34 | 34 | responseDto = CenterProfileResponseDto.builder() |
35 | | - .centerId(centerId) |
| 35 | + .id(userId) // id로 수정 |
| 36 | + .userId(UUID.randomUUID()) // userId 추가 |
| 37 | + .homepageUrl("http://example.com") |
36 | 38 | .name("Test Center") |
37 | 39 | .contactNumber("010-1234-5678") |
38 | 40 | .imgUrl("http://example.com/image.jpg") |
39 | 41 | .introduce("This is a test center.") |
40 | | - .homepageLink("http://example.com") |
41 | | - .preferItems(List.of()) |
| 42 | + .preferItems(List.of()) // preferItems 추가 |
42 | 43 | .build(); |
43 | 44 | } |
44 | 45 |
|
45 | | - @DisplayName("기관 ID로 기관 프로필을 조회할 수 있다. (controller)") |
| 46 | + @DisplayName("유저 ID로 기관 유저 프로필을 조회할 수 있다. (controller)") |
46 | 47 | @Test |
47 | 48 | void getCenterProfile() throws Exception { |
48 | 49 | // given |
49 | | - when(centerQueryUseCase.getCenterProfileByCenterId(centerId)).thenReturn(responseDto); |
| 50 | + when(centerQueryUseCase.getCenterProfileByUserId(userId)).thenReturn(responseDto); |
50 | 51 |
|
51 | | - // when // then |
| 52 | + // when & then |
52 | 53 | mockMvc.perform( |
53 | | - get("/api/center/profile/{centerId}", centerId) |
| 54 | + get("/api/center/profile/{userId}", userId) |
54 | 55 | .contentType(MediaType.APPLICATION_JSON) |
55 | 56 | ) |
56 | 57 | .andExpect(status().isOk()) |
57 | 58 | .andExpect(jsonPath("$.code").value("200")) |
58 | 59 | .andExpect(jsonPath("$.message").value("기관 프로필 조회 성공")) |
59 | | - .andExpect(jsonPath("$.data.center_id").value(centerId.toString())) // center_id로 수정 |
60 | | - .andExpect(jsonPath("$.data.name").value("Test Center")) |
61 | | - .andExpect(jsonPath("$.data.contact_number").value( |
62 | | - "010-1234-5678")) // contact_number로 수정 |
63 | | - .andExpect(jsonPath("$.data.img_url").value( |
64 | | - "http://example.com/image.jpg")) // img_url로 수정 |
65 | | - .andExpect(jsonPath("$.data.introduce").value("This is a test center.")) |
66 | | - .andExpect(jsonPath("$.data.homepage_link").value( |
67 | | - "http://example.com")) // homepage_link로 수정 |
68 | | - .andExpect(jsonPath("$.data.prefer_items").isArray()); // prefer_items로 수정 |
| 60 | + .andExpect(jsonPath("$.data.id").value(userId.toString())) |
| 61 | + .andExpect(jsonPath("$.data.user_id").value(responseDto.userId().toString())) |
| 62 | + .andExpect(jsonPath("$.data.homepage_url").value(responseDto.homepageUrl())) |
| 63 | + .andExpect(jsonPath("$.data.name").value(responseDto.name())) |
| 64 | + .andExpect(jsonPath("$.data.contact_number").value(responseDto.contactNumber())) |
| 65 | + .andExpect(jsonPath("$.data.img_url").value(responseDto.imgUrl())) |
| 66 | + .andExpect(jsonPath("$.data.introduce").value(responseDto.introduce())) |
| 67 | + .andExpect(jsonPath("$.data.prefer_items").isArray()); |
69 | 68 |
|
70 | | - verify(centerQueryUseCase, times(1)).getCenterProfileByCenterId(centerId); |
| 69 | + verify(centerQueryUseCase, times(1)).getCenterProfileByUserId(userId); |
71 | 70 | } |
72 | 71 |
|
73 | | - @DisplayName("존재하지 않는 기관 ID로 조회 시 예외가 발생한다. (controller)") |
| 72 | + @DisplayName("존재하지 않는 유저 ID로 조회 시 예외가 발생한다. (controller)") |
74 | 73 | @Test |
75 | 74 | void getCenterProfile_NotFound() throws Exception { |
76 | 75 | // given |
77 | | - UUID nonExistentCenterId = UUID.randomUUID(); |
78 | | - when(centerQueryUseCase.getCenterProfileByCenterId(nonExistentCenterId)) |
| 76 | + UUID nonExistentuserId = UUID.randomUUID(); |
| 77 | + when(centerQueryUseCase.getCenterProfileByUserId(nonExistentuserId)) |
79 | 78 | .thenThrow(new BadRequestException(NOT_EXISTS_CENTER.getMessage())); |
80 | 79 |
|
81 | | - // when // then |
| 80 | + // when & then |
82 | 81 | mockMvc.perform( |
83 | | - get("/api/center/profile/{centerId}", nonExistentCenterId) |
| 82 | + get("/api/center/profile/{userId}", nonExistentuserId) |
84 | 83 | .contentType(MediaType.APPLICATION_JSON) |
85 | 84 | ) |
86 | 85 | .andExpect(status().isBadRequest()) |
87 | 86 | .andExpect(jsonPath("$.status").value("400")) |
88 | 87 | .andExpect(jsonPath("$.detail").value("존재하지 않는 기관입니다.")); |
89 | 88 |
|
90 | | - verify(centerQueryUseCase, times(1)).getCenterProfileByCenterId(nonExistentCenterId); |
| 89 | + verify(centerQueryUseCase, times(1)).getCenterProfileByUserId(nonExistentuserId); |
91 | 90 | } |
92 | 91 |
|
93 | 92 | } |
94 | | - |
0 commit comments