-
Notifications
You must be signed in to change notification settings - Fork 8
feat: 유저의 멘토 지원서 신청 이력 조회 기능 추가 #603
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 3 commits
0994bb9
8895ee1
9e43bc3
c9ff45f
1d44b1e
814e4da
f22a424
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,14 @@ | ||
| package com.example.solidconnection.admin.dto; | ||
|
|
||
| import com.example.solidconnection.mentor.domain.MentorApplicationStatus; | ||
| import java.time.ZonedDateTime; | ||
|
|
||
| public record MentorApplicationHistoryResponse( | ||
| long id, | ||
| MentorApplicationStatus mentorApplicationStatus, | ||
| String rejectedReason, | ||
| ZonedDateTime createdAt, | ||
| int applicationOrder | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. id가 1, 2, 3, 4, 5, 6, 7로 생성되었으면 차라리 slice나 page로 5개씩 조회해오는 게 나을 거 같은데 어떤가요?
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 7 6 5 4 3 으로 응답되는게 맞습니다! |
||
| ) { | ||
|
|
||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,17 +1,23 @@ | ||
| package com.example.solidconnection.admin.service; | ||
|
|
||
| import static com.example.solidconnection.common.exception.ErrorCode.MENTOR_APPLICATION_NOT_FOUND; | ||
| import static com.example.solidconnection.common.exception.ErrorCode.USER_NOT_FOUND; | ||
|
|
||
| import com.example.solidconnection.admin.dto.MentorApplicationCountResponse; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationHistoryResponse; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationRejectRequest; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationSearchCondition; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationSearchResponse; | ||
| import com.example.solidconnection.common.exception.CustomException; | ||
| import com.example.solidconnection.mentor.domain.MentorApplication; | ||
| import com.example.solidconnection.mentor.domain.MentorApplicationStatus; | ||
| import com.example.solidconnection.mentor.repository.MentorApplicationRepository; | ||
| import com.example.solidconnection.siteuser.domain.SiteUser; | ||
| import com.example.solidconnection.siteuser.repository.SiteUserRepository; | ||
| import com.example.solidconnection.university.domain.University; | ||
| import com.example.solidconnection.university.repository.UniversityRepository; | ||
| import java.util.List; | ||
| import java.util.stream.IntStream; | ||
| import lombok.RequiredArgsConstructor; | ||
| import org.springframework.data.domain.Page; | ||
| import org.springframework.data.domain.Pageable; | ||
|
|
@@ -24,6 +30,7 @@ public class AdminMentorApplicationService { | |
|
|
||
| private final MentorApplicationRepository mentorApplicationRepository; | ||
| private final UniversityRepository universityRepository; | ||
| private final SiteUserRepository siteUserRepository; | ||
|
|
||
| @Transactional(readOnly = true) | ||
| public Page<MentorApplicationSearchResponse> searchMentorApplications( | ||
|
|
@@ -43,7 +50,7 @@ public void approveMentorApplication(Long mentorApplicationId) { | |
|
|
||
| @Transactional | ||
| public void rejectMentorApplication( | ||
| long mentorApplicationId, | ||
| Long mentorApplicationId, | ||
| MentorApplicationRejectRequest request | ||
| ) { | ||
| MentorApplication mentorApplication = mentorApplicationRepository.findById(mentorApplicationId) | ||
|
|
@@ -79,4 +86,26 @@ public void assignUniversity( | |
|
|
||
| mentorApplication.assignUniversity(university.getId()); | ||
| } | ||
|
|
||
| @Transactional(readOnly = true) | ||
| public List<MentorApplicationHistoryResponse> findMentorApplicationHistory(Long siteUserId) { | ||
| SiteUser siteUser = siteUserRepository.findById(siteUserId) | ||
| .orElseThrow(() -> new CustomException(USER_NOT_FOUND)); | ||
|
|
||
| long totalCount = mentorApplicationRepository.countBySiteUserId(siteUserId); | ||
|
|
||
| List<MentorApplication> mentorApplications = mentorApplicationRepository.findTop5BySiteUserIdOrderByCreatedAtDesc(siteUser.getId()); | ||
|
|
||
| return IntStream.range(0, mentorApplications.size()) | ||
| .mapToObj(index -> { | ||
| MentorApplication app = mentorApplications.get(index); | ||
| return new MentorApplicationHistoryResponse( | ||
| app.getId(), | ||
| app.getMentorApplicationStatus(), | ||
| app.getRejectedReason(), | ||
| app.getCreatedAt(), | ||
| (int) totalCount - index | ||
| ); | ||
| }).toList(); | ||
coderabbitai[bot] marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| } | ||
| } | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 여기 pr과 관련없지만 보여가지고 ㅎㅎ.. 개행 하나만 지워주실 수 있나요
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 혹시 95~97 라인 개행 말씀하시는거 맞나요? |
||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이 시크릿 해시코드는 현재 최신버전과 다른 거 같습니다.
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 서브모듈 어렵네요... 바로 되돌리겠습니다 |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -5,11 +5,13 @@ | |
| import static com.example.solidconnection.common.exception.ErrorCode.MENTOR_APPLICATION_NOT_OTHER_STATUS; | ||
| import static com.example.solidconnection.common.exception.ErrorCode.MENTOR_APPLICATION_UNIVERSITY_NOT_SELECTED; | ||
| import static com.example.solidconnection.common.exception.ErrorCode.UNIVERSITY_NOT_FOUND; | ||
| import static com.example.solidconnection.common.exception.ErrorCode.USER_NOT_FOUND; | ||
| import static org.assertj.core.api.Assertions.assertThat; | ||
| import static org.assertj.core.api.AssertionsForClassTypes.assertThatCode; | ||
| import static org.junit.jupiter.api.Assertions.assertAll; | ||
|
|
||
| import com.example.solidconnection.admin.dto.MentorApplicationCountResponse; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationHistoryResponse; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationRejectRequest; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationSearchCondition; | ||
| import com.example.solidconnection.admin.dto.MentorApplicationSearchResponse; | ||
|
|
@@ -509,4 +511,106 @@ class 멘토_지원서에_대학_매핑 { | |
| .hasMessage(UNIVERSITY_NOT_FOUND.getMessage()); | ||
| } | ||
| } | ||
|
|
||
| @Nested | ||
| class 멘토_지원서_이력_조회 { | ||
|
|
||
| @Test | ||
| void 사용자의_멘토_지원서_이력을_최신_생성_내림차순으로_조회한다() { | ||
| // given | ||
| SiteUser user = siteUserFixture.사용자(); | ||
| University university = universityFixture.메이지_대학(); | ||
| MentorApplication app1 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app2 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app3 = mentorApplicationFixture.승인된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
|
|
||
| // when | ||
| List<MentorApplicationHistoryResponse> response = adminMentorApplicationService.findMentorApplicationHistory(user.getId()); | ||
|
|
||
| // then | ||
| assertAll( | ||
| () -> assertThat(response).hasSize(3), | ||
| () -> assertThat(response) | ||
| .extracting(MentorApplicationHistoryResponse::id) | ||
| .containsExactly(app3.getId(), app2.getId(), app1.getId()), | ||
| () -> assertThat(response) | ||
| .extracting(MentorApplicationHistoryResponse::applicationOrder) | ||
| .containsExactly(3,2,1) | ||
| ); | ||
| } | ||
|
|
||
| @Test | ||
| void 지원서가_5개를_초과하면_최신_5개만_최신_생성_내림차순으로_조회한다() { | ||
| // given | ||
| SiteUser user = siteUserFixture.사용자(); | ||
| University university = universityFixture.메이지_대학(); | ||
| MentorApplication app1 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app2 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app3 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app4 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app5 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app6 = mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| MentorApplication app7 = mentorApplicationFixture.승인된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
|
|
||
| // when | ||
| List<MentorApplicationHistoryResponse> response = adminMentorApplicationService.findMentorApplicationHistory(user.getId()); | ||
|
|
||
| // then | ||
| assertAll( | ||
| () -> assertThat(response).hasSize(5), | ||
| () -> assertThat(response) | ||
| .extracting(MentorApplicationHistoryResponse::id) | ||
| .containsExactly(app7.getId(), app6.getId(), app5.getId(), app4.getId(), app3.getId()), | ||
| () -> assertThat(response) | ||
| .extracting(MentorApplicationHistoryResponse::applicationOrder) | ||
| .containsExactly(7,6,5,4,3) | ||
| ); | ||
| } | ||
|
|
||
| @Test | ||
| void 지원서_이력이_없으면_빈_목록을_반환한다() { | ||
| // given | ||
| SiteUser user = siteUserFixture.사용자(); | ||
|
|
||
| // when | ||
| List<MentorApplicationHistoryResponse> response = adminMentorApplicationService.findMentorApplicationHistory(user.getId()); | ||
|
|
||
| // then | ||
| assertThat(response).isEmpty(); | ||
| } | ||
|
|
||
| @Test | ||
| void 응답에_지원서_상태와_거절_사유가_포함된다() { | ||
| // given | ||
| SiteUser user = siteUserFixture.사용자(); | ||
| University university = universityFixture.메이지_대학(); | ||
|
||
| mentorApplicationFixture.거절된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
| mentorApplicationFixture.승인된_멘토신청(user.getId(), UniversitySelectType.CATALOG, university.getId()); | ||
|
|
||
| // when | ||
| List<MentorApplicationHistoryResponse> response = adminMentorApplicationService.findMentorApplicationHistory(user.getId()); | ||
|
|
||
| // then | ||
| assertAll( | ||
| () -> assertThat(response).hasSize(2), | ||
| () -> assertThat(response.get(0).mentorApplicationStatus()).isEqualTo(MentorApplicationStatus.APPROVED), | ||
| () -> assertThat(response.get(0).rejectedReason()).isNull(), | ||
| () -> assertThat(response.get(0).applicationOrder()).isEqualTo(2), | ||
| () -> assertThat(response.get(1).mentorApplicationStatus()).isEqualTo(MentorApplicationStatus.REJECTED), | ||
| () -> assertThat(response.get(1).rejectedReason()).isNotNull(), | ||
| () -> assertThat(response.get(1).applicationOrder()).isEqualTo(1) | ||
| ); | ||
| } | ||
|
|
||
| @Test | ||
| void 존재하지_않는_사용자_이력을_조회하면_예외_응답을_반환한다() { | ||
| // given | ||
| long nonExistentUserId = 99999L; | ||
|
|
||
| // when & then | ||
| assertThatCode(() -> adminMentorApplicationService.findMentorApplicationHistory(nonExistentUserId)) | ||
| .isInstanceOf(CustomException.class) | ||
| .hasMessage(USER_NOT_FOUND.getMessage()); | ||
| } | ||
| } | ||
| } | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
엔드포인트 이름이 조금 긴 것 같습니다 ! 어차피 prefix가
/admin/mentor-applications이므로mentor-application-history대신history를 사용하면 어떨까요 ?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
수정하겠습니다!