From 3b9650aa56afa7c2cbf1639dc885afbeeefc258c Mon Sep 17 00:00:00 2001 From: Wo-ogie Date: Wed, 31 Jan 2024 03:35:43 +0900 Subject: [PATCH] =?UTF-8?q?fix:=20#432=20=ED=9A=8C=EC=9B=90=20=EC=A0=95?= =?UTF-8?q?=EB=B3=B4=20=EC=88=98=EC=A0=95=20=EC=8B=9C,=20=EB=8B=89?= =?UTF-8?q?=EB=84=A4=EC=9E=84=EC=9D=B4=20=EB=B3=80=EA=B2=BD=EB=90=9C=20?= =?UTF-8?q?=EA=B2=BD=EC=9A=B0=EC=97=90=EB=A7=8C=20=EB=8B=89=EB=84=A4?= =?UTF-8?q?=EC=9E=84=20=EC=A4=91=EB=B3=B5=20=ED=99=95=EC=9D=B8=20=EB=A1=9C?= =?UTF-8?q?=EC=A7=81=EC=9D=B4=20=EC=8B=A4=ED=96=89=EB=90=98=EB=8F=84?= =?UTF-8?q?=EB=A1=9D=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../member/service/MemberCommandService.java | 6 ++- .../service/MemberCommandServiceTest.java | 38 +++++++++++++++++-- 2 files changed, 40 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/zelusik/eatery/domain/member/service/MemberCommandService.java b/src/main/java/com/zelusik/eatery/domain/member/service/MemberCommandService.java index d9c8e2ea..2b53215f 100644 --- a/src/main/java/com/zelusik/eatery/domain/member/service/MemberCommandService.java +++ b/src/main/java/com/zelusik/eatery/domain/member/service/MemberCommandService.java @@ -26,6 +26,7 @@ import org.springframework.web.multipart.MultipartFile; import java.util.List; +import java.util.Objects; import java.util.Optional; @RequiredArgsConstructor @@ -80,7 +81,10 @@ public void rejoin(Long memberId) { public MemberDto update(Long memberId, MemberUpdateRequest updateRequest) { Member member = memberQueryService.getById(memberId); - validateNicknameDuplication(updateRequest.getNickname()); + // 닉네임을 변경했다면, 변경하고자 하는 닉네임이 이미 사용중이지 않은지 확인 + if (!Objects.equals(member.getNickname(), updateRequest.getNickname())) { + validateNicknameDuplication(updateRequest.getNickname()); + } MultipartFile profileImageForUpdate = updateRequest.getProfileImage(); if (profileImageForUpdate == null) { diff --git a/src/test/java/com/zelusik/eatery/unit/domain/member/service/MemberCommandServiceTest.java b/src/test/java/com/zelusik/eatery/unit/domain/member/service/MemberCommandServiceTest.java index c7b5a091..b01b974f 100644 --- a/src/test/java/com/zelusik/eatery/unit/domain/member/service/MemberCommandServiceTest.java +++ b/src/test/java/com/zelusik/eatery/unit/domain/member/service/MemberCommandServiceTest.java @@ -138,6 +138,34 @@ void givenMemberUpdateInfo_whenUpdatingMemberInfo_thenUpdate() { assertThat(updatedMemberDto.getGender()).isEqualTo(memberUpdateInfo.getGender()); } + @DisplayName("수정할 회원 정보가 주어지고, 회원 정보를 수정하면, 주어진 정보로 회원 정보가 수정된다. 이때, 닉네임이 변경되지 않았다면 닉네임 중복 확인 과정은 거치지 않는다.") + @Test + void givenMemberInfoToUpdate_whenUpdateMemberInfo_thenMemberInfoShouldBeUpdatedWithoutNicknameDuplicationCheckIfNicknameNotChanged() { + // given + long memberId = 1L; + String nickname = "nickname"; + Member member = createMember(memberId, nickname); + MemberUpdateRequest memberUpdateInfo = new MemberUpdateRequest(nickname, LocalDate.of(2020, 1, 1), Gender.ETC, createMockMultipartFile()); + ProfileImage oldProfileImage = createProfileImage(member, 2L); + given(memberQueryService.getById(memberId)).willReturn(member); + given(profileImageQueryService.findByMember(member)).willReturn(Optional.of(oldProfileImage)); + willDoNothing().given(profileImageCommandService).softDelete(oldProfileImage); + given(profileImageCommandService.upload(any(Member.class), eq(memberUpdateInfo.getProfileImage()))).willReturn(createProfileImage(member, 10L)); + + // when + MemberDto updatedMemberDto = sut.update(memberId, memberUpdateInfo); + + // then + then(memberQueryService).should().getById(memberId); + then(profileImageQueryService).should().findByMember(member); + then(profileImageCommandService).should().softDelete(oldProfileImage); + then(profileImageCommandService).should().upload(any(Member.class), eq(memberUpdateInfo.getProfileImage())); + verifyEveryMocksShouldHaveNoMoreInteractions(); + assertThat(updatedMemberDto.getNickname()).isEqualTo(memberUpdateInfo.getNickname()); + assertThat(updatedMemberDto.getBirthDay()).isEqualTo(memberUpdateInfo.getBirthDay()); + assertThat(updatedMemberDto.getGender()).isEqualTo(memberUpdateInfo.getGender()); + } + @DisplayName("수정할 회원 정보 중 이미 사용중인 닉네임이 주어지고, 회원 정보를 수정하면, 예외가 발생한다.") @Test void givenNicknameThatAlreadyExists_whenUpdatingMemberInfo_thenThrowNicknameDuplicationException() { @@ -256,10 +284,14 @@ private Member createDeletedMember(long memberId) { } private Member createMember(long memberId) { - return createMember(memberId, Set.of(RoleType.USER)); + return createMember(memberId, "nickname", Set.of(RoleType.USER)); } - private Member createMember(long memberId, Set roleTypes) { + private Member createMember(long memberId, String nickname) { + return createMember(memberId, nickname, Set.of(RoleType.USER)); + } + + private Member createMember(long memberId, String nickname, Set roleTypes) { return new Member( memberId, "profile image url", @@ -268,7 +300,7 @@ private Member createMember(long memberId, Set roleTypes) { LoginType.KAKAO, roleTypes, "email", - "nickname", + nickname, LocalDate.of(2000, 1, 1), 20, Gender.MALE,