diff --git a/backend/docs/README.md b/backend/docs/README.md index 54684f71c..4834bd968 100644 --- a/backend/docs/README.md +++ b/backend/docs/README.md @@ -39,19 +39,19 @@ - 핀 상세 조회 -#### 유저 핀 +#### 회원 핀 -- 유저 핀 생성 +- 회원 핀 생성 -- 유저 핀 정보 수정 +- 회원 핀 정보 수정 - name, description 만 수정 가능하다. - description 은 1000자 까지만 가능하다. -- 유저 핀 삭제 +- 회원 핀 삭제 - Delete 는 Soft Delete --- -- 유저 핀 목록 조회 +- 회원 핀 목록 조회 - 페이지 네이션 (무한 스크롤, 일단 15개) diff --git a/backend/src/docs/asciidoc/bookmark.adoc b/backend/src/docs/asciidoc/bookmark.adoc index d416a87d8..64acd65e7 100644 --- a/backend/src/docs/asciidoc/bookmark.adoc +++ b/backend/src/docs/asciidoc/bookmark.adoc @@ -1,10 +1,10 @@ == 즐겨찾기 -=== 토픽을 유저의 즐겨찾기에 추가 +=== 토픽을 회원의 즐겨찾기에 추가 operation::bookmark-controller-test/add-topic-in-bookmark[snippets='http-request,http-response'] -=== 유저의 토픽 즐겨찾기 삭제 +=== 회원의 토픽 즐겨찾기 삭제 operation::bookmark-controller-test/delete-topic-in-bookmark[snippets='http-request,http-response'] diff --git a/backend/src/docs/asciidoc/member.adoc b/backend/src/docs/asciidoc/member.adoc index 94ffcb6e0..114112e4d 100644 --- a/backend/src/docs/asciidoc/member.adoc +++ b/backend/src/docs/asciidoc/member.adoc @@ -1,25 +1,25 @@ -== 유저 +== 회원 -=== 유저 목록 조회 +=== 회원 목록 조회 operation::member-controller-test/find-all-member[snippets='http-request,http-response'] -=== 유저 단일 조회 +=== 회원 단일 조회 operation::member-controller-test/find-member-by-id[snippets='http-request,http-response'] -=== 유저의 나의 지도 목록 조회 +=== 회원의 나의 지도 목록 조회 operation::member-controller-test/find-my-all-topics[snippets='http-request,http-response'] -=== 유저의 나의 핀 목록 조회 +=== 회원의 나의 핀 목록 조회 operation::member-controller-test/find-my-all-pins[snippets='http-request,http-response'] -=== 유저의 모아보기 조회 +=== 회원의 모아보기 조회 operation::member-controller-test/find-all-topics-in-atlas[snippets='http-request,http-response'] -=== 유저의 즐겨찾기 조회 +=== 회원의 즐겨찾기 조회 operation::member-controller-test/find-all-topics-in-bookmark[snippets='http-request,http-response'] diff --git a/backend/src/docs/asciidoc/permission.adoc b/backend/src/docs/asciidoc/permission.adoc index c704d7ed3..4b232e68c 100644 --- a/backend/src/docs/asciidoc/permission.adoc +++ b/backend/src/docs/asciidoc/permission.adoc @@ -8,10 +8,10 @@ operation::permission-controller-test/add-permission[snippets='http-request,http operation::permission-controller-test/delete-permission[snippets='http-request,http-response'] -=== 토픽에 권한을 가진 유저 목록 조회 +=== 토픽에 권한을 가진 회원 목록 조회 operation::permission-controller-test/find-all-topic-permissions[snippets='http-request,http-response'] -=== 토픽에 권한을 가진 유저 단일 조회 +=== 토픽에 권한을 가진 회원 단일 조회 operation::permission-controller-test/find-permission-by-id[snippets='http-request,http-response'] diff --git a/backend/src/docs/asciidoc/pin.adoc b/backend/src/docs/asciidoc/pin.adoc index 244d156ee..33b15e36b 100644 --- a/backend/src/docs/asciidoc/pin.adoc +++ b/backend/src/docs/asciidoc/pin.adoc @@ -8,7 +8,7 @@ operation::pin-controller-test/find-all[snippets='http-request,http-response'] operation::pin-controller-test/find-by-id[snippets='http-request,http-response'] -=== 멤버별 핀 목록 조회 +=== 회원별 핀 목록 조회 operation::pin-controller-test/find-all-pins-by-member-id[snippets='http-request,http-response'] diff --git a/backend/src/docs/asciidoc/topic.adoc b/backend/src/docs/asciidoc/topic.adoc index 524f94a34..423568377 100644 --- a/backend/src/docs/asciidoc/topic.adoc +++ b/backend/src/docs/asciidoc/topic.adoc @@ -12,7 +12,7 @@ operation::topic-controller-test/find-all-by-order-by-updated-at-desc[snippets=' operation::topic-controller-test/find-all-best-topics[snippets='http-request,http-response'] -=== 멤버별 토픽 목록 조회 +=== 회원별 토픽 목록 조회 operation::topic-controller-test/find-all-topics-by-member-id[snippets='http-request,http-response'] diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/application/MemberCommandService.java b/backend/src/main/java/com/mapbefine/mapbefine/member/application/MemberCommandService.java new file mode 100644 index 000000000..d7c315f4d --- /dev/null +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/application/MemberCommandService.java @@ -0,0 +1,43 @@ +package com.mapbefine.mapbefine.member.application; + +import com.mapbefine.mapbefine.auth.domain.AuthMember; +import com.mapbefine.mapbefine.member.domain.Member; +import com.mapbefine.mapbefine.member.domain.MemberRepository; +import com.mapbefine.mapbefine.member.dto.request.MemberUpdateRequest; +import com.mapbefine.mapbefine.member.exception.MemberErrorCode; +import com.mapbefine.mapbefine.member.exception.MemberException.MemberConflictException; +import java.util.NoSuchElementException; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +@Service +@Transactional +public class MemberCommandService { + + private final MemberRepository memberRepository; + + public MemberCommandService(MemberRepository memberRepository) { + this.memberRepository = memberRepository; + } + + public void updateInfoById(AuthMember authMember, MemberUpdateRequest request) { + Member member = findMemberById(authMember.getMemberId()); + String nickName = request.nickName(); + + validateNicknameDuplicated(nickName); + + member.update(nickName); + } + + private Member findMemberById(Long memberId) { + return memberRepository.findById(memberId) + .orElseThrow(() -> new NoSuchElementException("findMemberById; memberId=" + memberId)); + } + + private void validateNicknameDuplicated(String nickName) { + if (memberRepository.existsByMemberInfoNickName(nickName)) { + throw new MemberConflictException(MemberErrorCode.ILLEGAL_NICKNAME_ALREADY_EXISTS, nickName); + } + } + +} diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Member.java b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Member.java index 1d64325ef..31ebf2431 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Member.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Member.java @@ -100,22 +100,14 @@ private static String createNickname(String nickname) { private static String createNicknameSuffix() { return randomUUID() .toString() - .replaceAll("-", "") + .replace("-", "") .substring(0, DEFAULT_NICKNAME_SUFFIX_LENGTH); } public void update( - String nickName, - String email, - String imageUrl + String nickName ) { - memberInfo = MemberInfo.of( - nickName, - email, - imageUrl, - memberInfo.getRole(), - memberInfo.getStatus() - ); + memberInfo = memberInfo.createUpdatedMemberInfo(nickName); } public void addTopic(Topic topic) { diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberInfo.java b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberInfo.java index 082761579..ee36d80a1 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberInfo.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberInfo.java @@ -28,7 +28,7 @@ public class MemberInfo { @Column(nullable = false, length = 20, unique = true) private String nickName; - @Column(nullable = false, unique = true) + @Column(nullable = false) private String email; @Column(nullable = false) @@ -108,6 +108,11 @@ private static void validateStatus(Status status) { } } + public MemberInfo createUpdatedMemberInfo(String nickName) { + + return MemberInfo.of(nickName, this.email, this.imageUrl.getImageUrl(), this.role, this.status); + } + public String getImageUrl() { return imageUrl.getImageUrl(); } diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberRepository.java b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberRepository.java index 65125aa19..05be31d27 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberRepository.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/MemberRepository.java @@ -6,14 +6,12 @@ public interface MemberRepository extends JpaRepository { - Optional findByMemberInfoEmail(String email); - - boolean existsByMemberInfoEmail(String email); - - Optional findByOauthIdOauthServerId(Long oauthServerId); + Optional findById(Long id); Optional findByOauthId(OauthId oauthId); + boolean existsByMemberInfoNickName(String nickName); + List findAllByMemberInfoRole(Role role); } diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Role.java b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Role.java index 9222f5248..96b749832 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Role.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/domain/Role.java @@ -9,7 +9,7 @@ public enum Role { ADMIN("ROLE_ADMIN", "운영자"), - USER("ROLE_USER", "로그인 유저"), + USER("ROLE_USER", "로그인 회원"), GUEST("ROLE_GUEST", "손님"); private final String key; diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/dto/request/MemberUpdateRequest.java b/backend/src/main/java/com/mapbefine/mapbefine/member/dto/request/MemberUpdateRequest.java new file mode 100644 index 000000000..bada64c97 --- /dev/null +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/dto/request/MemberUpdateRequest.java @@ -0,0 +1,6 @@ +package com.mapbefine.mapbefine.member.dto.request; + +public record MemberUpdateRequest( + String nickName +) { +} diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberErrorCode.java b/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberErrorCode.java index b0c5d0340..98c42af4e 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberErrorCode.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberErrorCode.java @@ -11,6 +11,7 @@ public enum MemberErrorCode { ILLEGAL_EMAIL_PATTERN("05003", "올바르지 않은 이메일 형식입니다."), FORBIDDEN_MEMBER_STATUS("05100", "탈퇴 혹은 차단된 회원입니다."), MEMBER_NOT_FOUND("05400", "존재하지 않는 회원입니다."), + ILLEGAL_NICKNAME_ALREADY_EXISTS("05900", "이미 존재하는 닉네임입니다."), ; private final String code; diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberException.java b/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberException.java index 89a68948b..b582c64c7 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberException.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/exception/MemberException.java @@ -1,6 +1,7 @@ package com.mapbefine.mapbefine.member.exception; import com.mapbefine.mapbefine.common.exception.BadRequestException; +import com.mapbefine.mapbefine.common.exception.ConflictException; import com.mapbefine.mapbefine.common.exception.ErrorCode; import com.mapbefine.mapbefine.common.exception.ForbiddenException; import com.mapbefine.mapbefine.common.exception.NotFoundException; @@ -25,5 +26,11 @@ public MemberForbiddenException(MemberErrorCode errorCode, Long id) { } } + public static class MemberConflictException extends ConflictException { + public MemberConflictException(MemberErrorCode errorCode, String value) { + super(new ErrorCode<>(errorCode.getCode(), errorCode.getMessage(), value)); + } + } + } diff --git a/backend/src/main/java/com/mapbefine/mapbefine/member/presentation/MemberController.java b/backend/src/main/java/com/mapbefine/mapbefine/member/presentation/MemberController.java index 119ab4fd1..a9e63c5e9 100644 --- a/backend/src/main/java/com/mapbefine/mapbefine/member/presentation/MemberController.java +++ b/backend/src/main/java/com/mapbefine/mapbefine/member/presentation/MemberController.java @@ -2,7 +2,9 @@ import com.mapbefine.mapbefine.auth.domain.AuthMember; import com.mapbefine.mapbefine.common.interceptor.LoginRequired; +import com.mapbefine.mapbefine.member.application.MemberCommandService; import com.mapbefine.mapbefine.member.application.MemberQueryService; +import com.mapbefine.mapbefine.member.dto.request.MemberUpdateRequest; import com.mapbefine.mapbefine.member.dto.response.MemberDetailResponse; import com.mapbefine.mapbefine.member.dto.response.MemberResponse; import com.mapbefine.mapbefine.pin.dto.response.PinResponse; @@ -10,7 +12,9 @@ import java.util.List; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PatchMapping; import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @@ -18,9 +22,11 @@ @RequestMapping("/members") public class MemberController { + private final MemberCommandService memberCommandService; private final MemberQueryService memberQueryService; - public MemberController(MemberQueryService memberQueryService) { + public MemberController(MemberCommandService memberCommandService, MemberQueryService memberQueryService) { + this.memberCommandService = memberCommandService; this.memberQueryService = memberQueryService; } @@ -72,4 +78,12 @@ public ResponseEntity> findAllTopicsInBookmark(AuthMember au return ResponseEntity.ok(responses); } + @LoginRequired + @PatchMapping("/my/profiles") + public ResponseEntity updateMyInfo(AuthMember authMember, @RequestBody MemberUpdateRequest request) { + memberCommandService.updateInfoById(authMember, request); + + return ResponseEntity.ok().build(); + } + } diff --git a/backend/src/main/resources/config b/backend/src/main/resources/config index 9842778b9..0b448b778 160000 --- a/backend/src/main/resources/config +++ b/backend/src/main/resources/config @@ -1 +1 @@ -Subproject commit 9842778b9712e4c1eb5c918e2fa254edbafb8a04 +Subproject commit 0b448b7781204387184f5ce47a575a5b2d955128 diff --git a/backend/src/main/resources/data-default.sql b/backend/src/main/resources/data-default.sql new file mode 100644 index 000000000..75f9969c1 --- /dev/null +++ b/backend/src/main/resources/data-default.sql @@ -0,0 +1,16 @@ +INSERT INTO member (nick_name, email, image_url, role, + oauth_server_id, oauth_server_type, + created_at, updated_at) +VALUES ('dummyMember', 'dummy@gmail.com', 'https://map-befine-official.github.io/favicon.png', 'USER', + 1L, 'KAKAO', + now(), now()); + +INSERT INTO topic (name, image_url, description, + permission_type, publicity, + member_id, + created_at, updated_at) +VALUES ('dummyTopic', 'https://map-befine-official.github.io/favicon.png', 'description', + 'ALL_MEMBERS', 'PUBLIC', + 1L, + now(), now()) +; diff --git a/backend/src/main/resources/logback-spring.xml b/backend/src/main/resources/logback-spring.xml index 4bbde1b2d..944c99dd5 100644 --- a/backend/src/main/resources/logback-spring.xml +++ b/backend/src/main/resources/logback-spring.xml @@ -9,7 +9,7 @@ value="%green(%d{yyyy-MM-dd HH:mm:ss.SSS}) [%thread] ${PID} %highlight(%-5level) %cyan(%logger) - %msg%n"/> - + @@ -17,10 +17,10 @@ - - - - + + + + @@ -36,10 +36,10 @@ - - - - + + + + diff --git a/backend/src/main/resources/console-appender.xml b/backend/src/main/resources/logback/console-appender.xml similarity index 100% rename from backend/src/main/resources/console-appender.xml rename to backend/src/main/resources/logback/console-appender.xml diff --git a/backend/src/main/resources/file-debug-appender.xml b/backend/src/main/resources/logback/file-debug-appender.xml similarity index 100% rename from backend/src/main/resources/file-debug-appender.xml rename to backend/src/main/resources/logback/file-debug-appender.xml diff --git a/backend/src/main/resources/file-error-appender.xml b/backend/src/main/resources/logback/file-error-appender.xml similarity index 100% rename from backend/src/main/resources/file-error-appender.xml rename to backend/src/main/resources/logback/file-error-appender.xml diff --git a/backend/src/main/resources/file-hibernate-appender.xml b/backend/src/main/resources/logback/file-hibernate-appender.xml similarity index 100% rename from backend/src/main/resources/file-hibernate-appender.xml rename to backend/src/main/resources/logback/file-hibernate-appender.xml diff --git a/backend/src/main/resources/file-info-appender.xml b/backend/src/main/resources/logback/file-info-appender.xml similarity index 100% rename from backend/src/main/resources/file-info-appender.xml rename to backend/src/main/resources/logback/file-info-appender.xml diff --git a/backend/src/main/resources/file-warn-appender.xml b/backend/src/main/resources/logback/file-warn-appender.xml similarity index 100% rename from backend/src/main/resources/file-warn-appender.xml rename to backend/src/main/resources/logback/file-warn-appender.xml diff --git a/backend/src/main/resources/slack-error-appender.xml b/backend/src/main/resources/logback/slack-error-appender.xml similarity index 100% rename from backend/src/main/resources/slack-error-appender.xml rename to backend/src/main/resources/logback/slack-error-appender.xml diff --git a/backend/src/test/java/com/mapbefine/mapbefine/atlas/application/AtlasCommandServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/atlas/application/AtlasCommandServiceTest.java index ba20c8b53..28b4975cb 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/atlas/application/AtlasCommandServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/atlas/application/AtlasCommandServiceTest.java @@ -105,7 +105,7 @@ void validateReadPermission_fail() { } @Test - @DisplayName("멤버 ID와 TopicId가 있을 경우, atlas에서 해당 topic을 비운다.") + @DisplayName("회원 ID와 TopicId가 있을 경우, atlas에서 해당 topic을 비운다.") void remove_Success() { Long topicId = topic.getId(); Long memberId = authMember.getMemberId(); diff --git a/backend/src/test/java/com/mapbefine/mapbefine/auth/infrastructure/JwtTokenProviderTest.java b/backend/src/test/java/com/mapbefine/mapbefine/auth/infrastructure/JwtTokenProviderTest.java new file mode 100644 index 000000000..8081cf844 --- /dev/null +++ b/backend/src/test/java/com/mapbefine/mapbefine/auth/infrastructure/JwtTokenProviderTest.java @@ -0,0 +1,29 @@ +package com.mapbefine.mapbefine.auth.infrastructure; + +import static org.assertj.core.api.Assertions.assertThat; + +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.TestPropertySource; + +@SpringBootTest(classes = JwtTokenProvider.class) +@TestPropertySource(locations = "classpath:application.yml") +class JwtTokenProviderTest { + + @Autowired + private JwtTokenProvider jwtTokenProvider; + + @Test + @DisplayName("payload를 받아 JWT 토큰을 생성한다.") + void createToken() { + String payload = "1"; + + String token = jwtTokenProvider.createToken(payload); + + assertThat(jwtTokenProvider.getPayload(token)) + .isEqualTo(payload); + } + +} diff --git a/backend/src/test/java/com/mapbefine/mapbefine/bookmark/BookmarkIntegrationTest.java b/backend/src/test/java/com/mapbefine/mapbefine/bookmark/BookmarkIntegrationTest.java index bbe7e6ff1..022fefba2 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/bookmark/BookmarkIntegrationTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/bookmark/BookmarkIntegrationTest.java @@ -33,7 +33,7 @@ public class BookmarkIntegrationTest extends IntegrationTest { private BookmarkRepository bookmarkRepository; @Test - @DisplayName("유저가 토픽을 즐겨찾기 목록에 추가하면, 201을 반환한다.") + @DisplayName("회원이 토픽을 즐겨찾기 목록에 추가하면, 201을 반환한다.") void addTopicInBookmark_Success() { //given Member creator = MemberFixture.create("member", "member@naver.com", Role.USER); @@ -63,7 +63,7 @@ void addTopicInBookmark_Success() { } @Test - @DisplayName("유저의 즐겨찾기 토픽을 삭제하면, 204를 반환한다.") + @DisplayName("회원의 즐겨찾기 토픽을 삭제하면, 204를 반환한다.") void deleteTopicInBookmark_Success() { //given Member creator = MemberFixture.create("member", "member@naver.com", Role.USER); diff --git a/backend/src/test/java/com/mapbefine/mapbefine/bookmark/application/BookmarkCommandServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/bookmark/application/BookmarkCommandServiceTest.java index 76429f976..4db118c86 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/bookmark/application/BookmarkCommandServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/bookmark/application/BookmarkCommandServiceTest.java @@ -39,7 +39,7 @@ class BookmarkCommandServiceTest { private TestEntityManager testEntityManager; @Test - @DisplayName("다른 유저의 토픽을 즐겨찾기에 추가할 수 있다.") + @DisplayName("다른 회원의 토픽을 즐겨찾기에 추가할 수 있다.") public void addTopicInBookmark_Success() { //given Member creator = MemberFixture.create( @@ -72,7 +72,7 @@ public void addTopicInBookmark_Success() { } @Test - @DisplayName("권한이 없는 다른 유저의 토픽을 즐겨찾기에 추가할 수 없다.") + @DisplayName("권한이 없는 다른 회원의 토픽을 즐겨찾기에 추가할 수 없다.") public void addTopicInBookmark_Fail1() { //given Member creator = MemberFixture.create( diff --git a/backend/src/test/java/com/mapbefine/mapbefine/bookmark/presentation/BookmarkControllerTest.java b/backend/src/test/java/com/mapbefine/mapbefine/bookmark/presentation/BookmarkControllerTest.java index ff3e23076..b65443d93 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/bookmark/presentation/BookmarkControllerTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/bookmark/presentation/BookmarkControllerTest.java @@ -19,7 +19,7 @@ class BookmarkControllerTest extends RestDocsIntegration { @Test - @DisplayName("토픽을 유저의 즐겨찾기에 추가") + @DisplayName("토픽을 회원의 즐겨찾기에 추가") public void addTopicInBookmark() throws Exception { given(bookmarkCommandService.addTopicInBookmark(any(), any())).willReturn(1L); @@ -31,7 +31,7 @@ public void addTopicInBookmark() throws Exception { } @Test - @DisplayName("유저의 토픽 즐겨찾기 목록 삭제") + @DisplayName("회원의 토픽 즐겨찾기 목록 삭제") public void deleteTopicInBookmark() throws Exception { doNothing().when(bookmarkCommandService).deleteTopicInBookmark(any(), any()); @@ -42,4 +42,4 @@ public void deleteTopicInBookmark() throws Exception { ).andDo(restDocs.document()); } -} \ No newline at end of file +} diff --git a/backend/src/test/java/com/mapbefine/mapbefine/member/MemberIntegrationTest.java b/backend/src/test/java/com/mapbefine/mapbefine/member/MemberIntegrationTest.java index afdbad42d..aaf288b23 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/member/MemberIntegrationTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/member/MemberIntegrationTest.java @@ -1,7 +1,7 @@ package com.mapbefine.mapbefine.member; import static com.mapbefine.mapbefine.oauth.domain.OauthServerType.KAKAO; -import static io.restassured.RestAssured.given; +import static io.restassured.RestAssured.*; import static org.apache.http.HttpHeaders.AUTHORIZATION; import static org.assertj.core.api.Assertions.assertThat; @@ -10,12 +10,12 @@ import com.mapbefine.mapbefine.member.domain.MemberRepository; import com.mapbefine.mapbefine.member.domain.OauthId; import com.mapbefine.mapbefine.member.domain.Role; +import com.mapbefine.mapbefine.member.dto.request.MemberUpdateRequest; import com.mapbefine.mapbefine.member.dto.response.MemberDetailResponse; import com.mapbefine.mapbefine.member.dto.response.MemberResponse; -import io.restassured.RestAssured; -import io.restassured.common.mapper.TypeRef; -import io.restassured.response.ExtractableResponse; -import io.restassured.response.Response; +import io.restassured.*; +import io.restassured.common.mapper.*; +import io.restassured.response.*; import java.util.List; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.DisplayName; @@ -69,7 +69,7 @@ public void setUp() { } @Test - @DisplayName("유저 목록을 조회한다.") + @DisplayName("회원 목록을 조회한다.") void findAllMember() { // given, when ExtractableResponse response = given().log().all() @@ -94,7 +94,7 @@ void findAllMember() { } @Test - @DisplayName("유저를 단일 조회한다.") + @DisplayName("회원을 단일 조회한다.") void findMemberById() { // given, when ExtractableResponse response = given().log().all() @@ -115,7 +115,7 @@ void findMemberById() { } @Test - @DisplayName("로그인 유저가 내 지도 목록을 조회하면, 200을 반환한다.") + @DisplayName("로그인 회원이 내 지도 목록을 조회하면, 200을 반환한다.") void findMyAllTopics_Success() { //when ExtractableResponse response = given().log().all() @@ -131,7 +131,7 @@ void findMyAllTopics_Success() { @Test - @DisplayName("로그인 유저가 내 지도 목록을 조회하면, 200을 반환한다.") + @DisplayName("로그인 회원이 내 지도 목록을 조회하면, 200을 반환한다.") void findMyAllPins_Success() { //when ExtractableResponse response = given().log().all() @@ -147,14 +147,13 @@ void findMyAllPins_Success() { @Test - @DisplayName("유저의 즐겨찾기 토픽 목록을 조회하면, 200을 반환한다.") + @DisplayName("회원의 즐겨찾기 토픽 목록을 조회하면, 200을 반환한다.") void findTopicsInBookmarks_Success() { //when ExtractableResponse response = given().log().all() .header(AUTHORIZATION, creatorAuthHeader) .accept(MediaType.APPLICATION_JSON_VALUE) .when().get("/members/my/bookmarks") - .then().log().all() .extract(); @@ -170,7 +169,6 @@ void findTopicsFromAtlas_Success() { .log().all() .header(HttpHeaders.AUTHORIZATION, creatorAuthHeader) .when().get("/members/my/atlas") - .then().log().all() .extract(); @@ -178,5 +176,21 @@ void findTopicsFromAtlas_Success() { assertThat(response.statusCode()).isEqualTo(HttpStatus.OK.value()); } + @Test + @DisplayName("회원 정보를 정상적으로 수정하면, 200을 반환한다") + void updateMemberInfo_Success() { + // when + ExtractableResponse response = RestAssured.given() + .log().all() + .header(HttpHeaders.AUTHORIZATION, creatorAuthHeader) + .contentType(MediaType.APPLICATION_JSON_VALUE) + .body(new MemberUpdateRequest("new nickname")) + .when().patch("/members/my/profiles") + .then().log().all() + .extract(); + // then + assertThat(response.statusCode()).isEqualTo(HttpStatus.OK.value()); + } + } diff --git a/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberCommandServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberCommandServiceTest.java new file mode 100644 index 000000000..388a52b93 --- /dev/null +++ b/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberCommandServiceTest.java @@ -0,0 +1,89 @@ +package com.mapbefine.mapbefine.member.application; + +import static java.util.Collections.emptyList; +import static org.assertj.core.api.Assertions.assertThat; +import static org.assertj.core.api.AssertionsForClassTypes.assertThatThrownBy; + +import com.mapbefine.mapbefine.auth.domain.AuthMember; +import com.mapbefine.mapbefine.auth.domain.member.User; +import com.mapbefine.mapbefine.common.annotation.ServiceTest; +import com.mapbefine.mapbefine.member.MemberFixture; +import com.mapbefine.mapbefine.member.domain.Member; +import com.mapbefine.mapbefine.member.domain.MemberInfo; +import com.mapbefine.mapbefine.member.domain.MemberRepository; +import com.mapbefine.mapbefine.member.domain.Role; +import com.mapbefine.mapbefine.member.dto.request.MemberUpdateRequest; +import com.mapbefine.mapbefine.member.exception.MemberException.MemberConflictException; +import java.util.NoSuchElementException; +import org.junit.jupiter.api.Assertions; +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; + +@ServiceTest +class MemberCommandServiceTest { + + @Autowired + private MemberCommandService memberCommandService; + @Autowired + private MemberRepository memberRepository; + private Member member; + private AuthMember authMember; + + @BeforeEach + void setUp() { + member = memberRepository.save(MemberFixture.create("member", "member@gmail.com", Role.USER)); + authMember = new User(member.getId(), emptyList(), emptyList()); + } + + @Test + @DisplayName("회원 정보를 수정한다.") + void updateInfoById_Success() { + // given + String expected = "new nickname"; + MemberUpdateRequest request = new MemberUpdateRequest(expected); + + // when + memberCommandService.updateInfoById(authMember, request); + memberRepository.flush(); + + // then + memberRepository.findById(member.getId()) + .map(Member::getMemberInfo) + .ifPresentOrElse( + actual -> { + assertThat(actual).usingRecursiveComparison() + .ignoringFields("nickName") + .isEqualTo(member.getMemberInfo()); + assertThat(actual.getNickName()).isEqualTo(expected); + }, + Assertions::fail + ); + } + + @Test + @DisplayName("존재하지 않는 회원의 정보를 수정하면 예외가 발생한다.") + void updateInfoById_FailByNotExistingMember() { + // given + MemberUpdateRequest request = new MemberUpdateRequest("new nickname"); + User notExistingMember = new User(100L, emptyList(), emptyList()); + + // when, then + assertThatThrownBy(() -> memberCommandService.updateInfoById(notExistingMember, request)) + .isInstanceOf(NoSuchElementException.class); + } + + @Test + @DisplayName("회원 정보 수정 시, 이미 존재하는 닉네임을 설정하면 예외가 발생한다.") + void updateInfoById_FailByDuplicatedNickName() { + // given + MemberInfo memberInfo = member.getMemberInfo(); + MemberUpdateRequest request = new MemberUpdateRequest(memberInfo.getNickName()); + + // when, then + assertThatThrownBy(() -> memberCommandService.updateInfoById(authMember, request)) + .isInstanceOf(MemberConflictException.class); + } + +} diff --git a/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberQueryServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberQueryServiceTest.java index 7152ad0c5..2e0d8a4c3 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberQueryServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/member/application/MemberQueryServiceTest.java @@ -52,7 +52,6 @@ class MemberQueryServiceTest { @Autowired private LocationRepository locationRepository; - private AuthMember authMember; private Member member; private List topics; @@ -78,7 +77,7 @@ private void createTopics(Member member) { } @Test - @DisplayName("유저 목록을 조회한다.") + @DisplayName("회원 목록을 조회한다.") void findAllMember() { // given Member member2 = memberRepository.save( @@ -101,7 +100,7 @@ void findAllMember() { } @Test - @DisplayName("유저를 단일 조회한다.") + @DisplayName("회원을 단일 조회한다.") void findMemberById() { // given Member member = memberRepository.save( @@ -117,7 +116,7 @@ void findMemberById() { } @Test - @DisplayName("조회하려는 유저가 없는 경우 예외를 반환한다.") + @DisplayName("조회하려는 회원이 없는 경우 예외를 반환한다.") void findMemberById_whenNoneExists_thenFail() { // given when then assertThatThrownBy(() -> memberQueryService.findById(Long.MAX_VALUE)) @@ -127,7 +126,7 @@ void findMemberById_whenNoneExists_thenFail() { @Test @DisplayName("즐겨찾기 목록에 추가 된 토픽을 조회할 수 있다") - public void findAllTopicsInBookmark_success() { + void findAllTopicsInBookmark_success() { // when List allTopicsInBookmark = memberQueryService.findAllTopicsInBookmark(authMember); @@ -143,7 +142,7 @@ public void findAllTopicsInBookmark_success() { @Test - @DisplayName("멤버 ID를 이용해 모아보기할 모든 Topic들을 가져올 수 있다.") + @DisplayName("회원 ID를 이용해 모아보기할 모든 Topic들을 가져올 수 있다.") void findAtlasByMember_Success() { // when List allTopicsInAtlas = memberQueryService.findAllTopicsInAtlas(authMember); @@ -175,7 +174,7 @@ void findMyAllTopics_Success() { } @Test - @DisplayName("로그인한 유저가 생성한 모든 핀을 가져올 수 있다.") + @DisplayName("로그인한 회원이 생성한 모든 핀을 가져올 수 있다.") void findMyAllPins_Success() { // given Location location = locationRepository.save(LocationFixture.create()); @@ -199,4 +198,5 @@ void findMyAllPins_Success() { .isEqualTo(pinIds); } + } diff --git a/backend/src/test/java/com/mapbefine/mapbefine/member/domain/MemberInfoTest.java b/backend/src/test/java/com/mapbefine/mapbefine/member/domain/MemberInfoTest.java index 1ed6e7371..d19079318 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/member/domain/MemberInfoTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/member/domain/MemberInfoTest.java @@ -2,6 +2,7 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; +import static org.assertj.core.api.SoftAssertions.assertSoftly; import com.mapbefine.mapbefine.common.exception.BadRequestException.ImageBadRequestException; import com.mapbefine.mapbefine.member.exception.MemberException.MemberBadRequestException; @@ -25,8 +26,8 @@ class Validate { private final Status VALID_STATUS = Status.NORMAL; @Test - @DisplayName("정확한 값을 입력하면 객체가 생성된다") - void success() { + @DisplayName("유효한 정보를 입력했을 때 객체를 생성할 수 있다.") + void create_Success() { //given when MemberInfo memberInfo = MemberInfo.of( VALID_NICK_NAME, @@ -44,11 +45,35 @@ void success() { assertThat(memberInfo.getRole()).isEqualTo(VALID_ROLE); } + @Test + @DisplayName("일부 정보(닉네임)만 변경한 회원 정보를 생성할 수 있다.") + void createUpdatedMemberInfo() { + // given + MemberInfo before = MemberInfo.of( + "member", + "member@naver.com", + "https://map-befine-official.github.io/favicon.png", + Role.ADMIN, + Status.NORMAL); + + // when + String expected = "newNickName"; + MemberInfo patched = before.createUpdatedMemberInfo(expected); + + // then + assertSoftly(softly -> { + assertThat(patched).usingRecursiveComparison() + .ignoringFields("nickName") + .isEqualTo(before); + assertThat(patched.getNickName()).isEqualTo(expected); + }); + } + @ParameterizedTest @NullSource @ValueSource(strings = {"", "aaaaaaaaaaaaaaaaaaaaa"}) - @DisplayName("유효한 이름이 아닌 경우 예외가 발생한다") - void whenNameIsInvalid_thenFail(String invalidNickName) { + @DisplayName("유효한 닉네임이 아닌 경우 예외가 발생한다") + void validateNickName(String invalidNickName) { //given when then assertThatThrownBy(() -> MemberInfo.of( invalidNickName, @@ -64,7 +89,7 @@ void whenNameIsInvalid_thenFail(String invalidNickName) { @EmptySource @ValueSource(strings = "member") @DisplayName("유효한 이메일이 아닌 경우 예외가 발생한다") - void whenEmailIsInvalid_thenFail(String invalidEmail) { + void validateEmail(String invalidEmail) { //given when then assertThatThrownBy(() -> MemberInfo.of( VALID_NICK_NAME, @@ -77,7 +102,7 @@ void whenEmailIsInvalid_thenFail(String invalidEmail) { @Test @DisplayName("올바르지 않은 형식의 Image Url 이 들어오는 경우 예외가 발생한다.") - void whenImageUrlIsInvalid_thenFail() { + void validateImageUrl() { String invalidImageUrl = "image.png"; //given when then @@ -92,7 +117,7 @@ void whenImageUrlIsInvalid_thenFail() { @Test @DisplayName("유효하지 않은 Role 이 들어오는 경우 예외가 발생한다.") - void whenRoleIsInvalid_thenFail() { + void validateRole() { //given when then assertThatThrownBy(() -> MemberInfo.of( VALID_NICK_NAME, diff --git a/backend/src/test/java/com/mapbefine/mapbefine/member/presentation/MemberControllerTest.java b/backend/src/test/java/com/mapbefine/mapbefine/member/presentation/MemberControllerTest.java index 7efbf8c36..df12531d6 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/member/presentation/MemberControllerTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/member/presentation/MemberControllerTest.java @@ -7,6 +7,7 @@ import com.mapbefine.mapbefine.common.RestDocsIntegration; import com.mapbefine.mapbefine.location.LocationFixture; import com.mapbefine.mapbefine.member.application.MemberQueryService; +import com.mapbefine.mapbefine.member.dto.request.MemberUpdateRequest; import com.mapbefine.mapbefine.member.dto.response.MemberDetailResponse; import com.mapbefine.mapbefine.member.dto.response.MemberResponse; import com.mapbefine.mapbefine.pin.dto.response.PinResponse; @@ -16,6 +17,7 @@ import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import org.springframework.boot.test.mock.mockito.MockBean; +import org.springframework.http.MediaType; import org.springframework.test.web.servlet.request.MockMvcRequestBuilders; class MemberControllerTest extends RestDocsIntegration { @@ -24,7 +26,7 @@ class MemberControllerTest extends RestDocsIntegration { private MemberQueryService memberQueryService; @Test - @DisplayName("유저 목록 조회") + @DisplayName("회원 목록 조회") void findAllMember() throws Exception { List memberResponses = List.of( new MemberResponse( @@ -48,7 +50,7 @@ void findAllMember() throws Exception { } @Test - @DisplayName("유저 단일 조회") + @DisplayName("회원 단일 조회") void findMemberById() throws Exception { MemberDetailResponse memberDetailResponse = new MemberDetailResponse( 1L, @@ -67,7 +69,7 @@ void findMemberById() throws Exception { } @Test - @DisplayName("유저의 모아보기 목록 조회") + @DisplayName("회원의 모아보기 목록 조회") void findAllTopicsInAtlas() throws Exception { List responses = List.of( new TopicResponse( @@ -102,7 +104,7 @@ void findAllTopicsInAtlas() throws Exception { } @Test - @DisplayName("유저의 즐겨찾기 목록 조회") + @DisplayName("회원의 즐겨찾기 목록 조회") void findAllTopicsInBookmark() throws Exception { List responses = List.of( new TopicResponse( @@ -137,7 +139,7 @@ void findAllTopicsInBookmark() throws Exception { } @Test - @DisplayName("유저의 지도 목록 조회") + @DisplayName("회원의 지도 목록 조회") void findMyAllTopics() throws Exception { List responses = List.of( new TopicResponse( @@ -172,7 +174,7 @@ void findMyAllTopics() throws Exception { } @Test - @DisplayName("유저의 핀 목록 조회") + @DisplayName("회원의 핀 목록 조회") void findMyAllPins() throws Exception { List responses = List.of( new PinResponse( @@ -202,4 +204,17 @@ void findMyAllPins() throws Exception { ).andDo(restDocs.document()); } + @Test + @DisplayName("회원의 정보 수정") + void updateMyInfo() throws Exception { + MemberUpdateRequest request = new MemberUpdateRequest("새로운 닉네임"); + + mockMvc.perform( + MockMvcRequestBuilders.patch("/members/my/profiles") + .header(AUTHORIZATION, testAuthHeaderProvider.createAuthHeaderById(1L)) + .contentType(MediaType.APPLICATION_JSON) + .content(objectMapper.writeValueAsString(request)) + ).andDo(restDocs.document()); + } + } diff --git a/backend/src/test/java/com/mapbefine/mapbefine/oauth/application/OauthServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/oauth/application/OauthServiceTest.java index 2d5c71227..be752de19 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/oauth/application/OauthServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/oauth/application/OauthServiceTest.java @@ -97,7 +97,7 @@ void getAuthCodeRequestUrl_success() { void loginAndRegister_success() { // when LoginInfoResponse response = oauthService.login(KAKAO, "auth"); - Member savedMember = memberRepository.findByMemberInfoEmail("yshert@naver.com") + Member savedMember = memberRepository.findById(response.member().id()) .orElseThrow(NoSuchElementException::new); // then @@ -114,7 +114,7 @@ void loginAndRegister_success() { void login() { // given LoginInfoResponse firstLogin = oauthService.login(KAKAO, "auth"); - Member savedMember = memberRepository.findByMemberInfoEmail(firstLogin.member().email()) + Member savedMember = memberRepository.findById(firstLogin.member().id()) .orElseThrow(NoSuchElementException::new); // when diff --git a/backend/src/test/java/com/mapbefine/mapbefine/oauth/presentation/OauthControllerTest.java b/backend/src/test/java/com/mapbefine/mapbefine/oauth/presentation/OauthControllerTest.java index 0ed9e5d1d..60fc1b565 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/oauth/presentation/OauthControllerTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/oauth/presentation/OauthControllerTest.java @@ -37,7 +37,7 @@ void redirection() throws Exception { } @Test - @DisplayName("소셜 로그인 성공시 로그인한 유저 정보 반환") + @DisplayName("소셜 로그인 성공시 로그인한 회원 정보 반환") void login() throws Exception { // given String code = "auth_code"; diff --git a/backend/src/test/java/com/mapbefine/mapbefine/permission/PermissionIntegrationTest.java b/backend/src/test/java/com/mapbefine/mapbefine/permission/PermissionIntegrationTest.java index 983dd8e0c..cfa164f3c 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/permission/PermissionIntegrationTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/permission/PermissionIntegrationTest.java @@ -79,7 +79,7 @@ public void setUp() { } @Test - @DisplayName("Topic 을 만든자가 특정 유저에게 권한을 준다.") + @DisplayName("Topic 을 만든자가 특정 회원에게 권한을 준다.") void addPermission() { // given Topic topic = topicRepository.save(TopicFixture.createByName("topicName", creator)); @@ -100,7 +100,7 @@ void addPermission() { } @Test - @DisplayName("Topic 을 만든자가 특정 유저에게 권한을 삭제한다.") + @DisplayName("Topic 을 만든자가 특정 회원에게 권한을 삭제한다.") void deletePermission() { // given Topic topic = topicRepository.save(TopicFixture.createByName("topicName", creator)); diff --git a/backend/src/test/java/com/mapbefine/mapbefine/permission/application/PermissionCommandServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/permission/application/PermissionCommandServiceTest.java index 9fe7ec610..73a86dc30 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/permission/application/PermissionCommandServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/permission/application/PermissionCommandServiceTest.java @@ -99,7 +99,7 @@ void saveMemberTopicPermissionByCreator() { } @Test - @DisplayName("Creator 가 아닌 유저가 권한을 주려는 경우 예외가 발생한다.") + @DisplayName("Creator 가 아닌 회원이 권한을 주려는 경우 예외가 발생한다.") void saveMemberTopicPermissionByUser() { // given Member creator = memberRepository.save( @@ -127,7 +127,7 @@ void saveMemberTopicPermissionByUser() { } @Test - @DisplayName("Guest 가 유저에게 권한을 주려는 경우 예외가 발생한다.") + @DisplayName("Guest 가 회원에게 권한을 주려는 경우 예외가 발생한다.") void saveMemberTopicPermissionByGuest() { // given Member creator = memberRepository.save( @@ -262,7 +262,7 @@ void deleteMemberTopicPermissionByCreator() { } @Test - @DisplayName("creator 가 아닌 유저가 권한을 삭제하는 경우 예외가 발생한다.") + @DisplayName("creator 가 아닌 회원이 권한을 삭제하는 경우 예외가 발생한다.") void deleteMemberTopicPermissionByUser() { // given Member creator = memberRepository.save( @@ -289,7 +289,7 @@ void deleteMemberTopicPermissionByUser() { } @Test - @DisplayName("존재하지 않는 유저의 권한을 삭제하려 하려는 경우 예외가 발생한다.") + @DisplayName("존재하지 않는 회원의 권한을 삭제하려 하려는 경우 예외가 발생한다.") void deleteMemberTopicPermissionByCreator_whenNoneExistsPermission_thenFail() { // given Member creator = memberRepository.save( diff --git a/backend/src/test/java/com/mapbefine/mapbefine/pin/PinIntegrationTest.java b/backend/src/test/java/com/mapbefine/mapbefine/pin/PinIntegrationTest.java index f69a1e2d7..c154156b7 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/pin/PinIntegrationTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/pin/PinIntegrationTest.java @@ -242,7 +242,7 @@ void removeImage_Success() { @Test - @DisplayName("멤버별 Pin 목록을 조회하면 200을 반환한다") + @DisplayName("회원별 Pin 목록을 조회하면 200을 반환한다") void findAllPinsByMemberId_Success() { //given createPinAndGetId(createRequestDuplicateLocation); diff --git a/backend/src/test/java/com/mapbefine/mapbefine/pin/application/PinQueryServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/pin/application/PinQueryServiceTest.java index d1b3537f9..25d0f59e9 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/pin/application/PinQueryServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/pin/application/PinQueryServiceTest.java @@ -131,7 +131,7 @@ void findDetailById_FailByForbidden() { } @Test - @DisplayName("멤버 Id를 이용하여 그 멤버가 만든 모든 Pin을 확인할 수 있다.") + @DisplayName("회원 Id를 이용하여 그 회원이 만든 모든 Pin을 확인할 수 있다.") void findAllPinsByMemberId_success() { // given List expected = pinRepository.saveAll(List.of( diff --git a/backend/src/test/java/com/mapbefine/mapbefine/pin/presentation/PinControllerTest.java b/backend/src/test/java/com/mapbefine/mapbefine/pin/presentation/PinControllerTest.java index 88876fbd2..b5c9eafc3 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/pin/presentation/PinControllerTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/pin/presentation/PinControllerTest.java @@ -188,7 +188,7 @@ void removeImage() throws Exception { @Test - @DisplayName("멤버 Id를 입력하면 해당 멤버가 만든 핀 목록을 조회할 수 있다.") + @DisplayName("회원 Id를 입력하면 해당 회원이 만든 핀 목록을 조회할 수 있다.") void findAllPinsByMemberId() throws Exception { List pinResponses = List.of( new PinResponse( diff --git a/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicFixture.java b/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicFixture.java index ed8a196a4..a8c4d93c3 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicFixture.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicFixture.java @@ -16,8 +16,8 @@ public class TopicFixture { public static Topic createPrivateAndGroupOnlyTopic(Member member) { return Topic.createTopicAssociatedWithCreator( - "토픽 멤버만 읽을 수 있는 토픽", - "토픽 멤버만 읽을 수 있습니다.", + "토픽 회원만 읽을 수 있는 토픽", + "토픽 회원만 읽을 수 있습니다.", IMAGE_URL, Publicity.PRIVATE, PermissionType.GROUP_ONLY, diff --git a/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicIntegrationTest.java b/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicIntegrationTest.java index f344ce9a4..80c13a9f3 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicIntegrationTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/topic/TopicIntegrationTest.java @@ -404,7 +404,7 @@ void findAllByOrderByUpdatedAtDesc_Success() { } @Test - @DisplayName("멤버별 Topic 목록을 조회하면 200을 반환한다") + @DisplayName("회원별 Topic 목록을 조회하면 200을 반환한다") void findAllTopicsByMemberId_Success() { // when ExtractableResponse response = RestAssured diff --git a/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicCommandServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicCommandServiceTest.java index be5266088..813ba6e77 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicCommandServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicCommandServiceTest.java @@ -303,8 +303,8 @@ public void updateTopicInfo_Success() { topicRepository.save(topic); //when - assertThat(topic.getTopicInfo().getName()).isEqualTo("토픽 멤버만 읽을 수 있는 토픽"); - assertThat(topic.getTopicInfo().getDescription()).isEqualTo("토픽 멤버만 읽을 수 있습니다."); + assertThat(topic.getTopicInfo().getName()).isEqualTo("토픽 회원만 읽을 수 있는 토픽"); + assertThat(topic.getTopicInfo().getDescription()).isEqualTo("토픽 회원만 읽을 수 있습니다."); AuthMember user = MemberFixture.createUser(member); TopicUpdateRequest request = new TopicUpdateRequest( diff --git a/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicQueryServiceTest.java b/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicQueryServiceTest.java index 302d7aac1..5196a7f6c 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicQueryServiceTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/topic/application/TopicQueryServiceTest.java @@ -80,8 +80,8 @@ void findAllReadable_Success1() { assertThat(topics).extractingResultOf("name") .containsExactlyInAnyOrder( "아무나 읽을 수 있는 토픽", - "토픽 멤버만 읽을 수 있는 토픽", - "토픽 멤버만 읽을 수 있는 토픽" + "토픽 회원만 읽을 수 있는 토픽", + "토픽 회원만 읽을 수 있는 토픽" ); } @@ -194,7 +194,7 @@ void findDetailByIds_Success2() { //then assertThat(details).hasSize(2); assertThat(details).extractingResultOf("name") - .containsExactlyInAnyOrder("아무나 읽을 수 있는 토픽", "토픽 멤버만 읽을 수 있는 토픽"); + .containsExactlyInAnyOrder("아무나 읽을 수 있는 토픽", "토픽 회원만 읽을 수 있는 토픽"); } @Test @@ -257,7 +257,7 @@ void findAllReadableWithBookmark_Success() { } @Test - @DisplayName("모든 토픽을 조회할 때, 로그인 유저가 아니면 즐겨찾기 여부가 항상 False다") + @DisplayName("모든 토픽을 조회할 때, 로그인 회원이 아니면 즐겨찾기 여부가 항상 False다") void findAllReadableWithoutBookmark_Success() { //given Topic topic1 = TopicFixture.createPublicAndAllMembersTopic(member); @@ -300,7 +300,7 @@ void findWithBookmarkStatus_Success() { } @Test - @DisplayName("토픽 상세조회시, 로그인 유저가 아니라면 즐겨찾기 여부, 모아보기 여부, 수정 권한 여부가 항상 False다.") + @DisplayName("토픽 상세조회시, 로그인 회원이 아니라면 즐겨찾기 여부, 모아보기 여부, 수정 권한 여부가 항상 False다.") void findWithoutBookmarkStatus_Success() { //given Topic topic = TopicFixture.createPublicAndAllMembersTopic(member); @@ -344,7 +344,7 @@ void findDetailsWithBookmarkStatus_Success() { } @Test - @DisplayName("여러 토픽 조회시, 로그인 유저가 아니라면 즐겨 찾기 여부가 항상 False다.") + @DisplayName("여러 토픽 조회시, 로그인 회원이 아니라면 즐겨 찾기 여부가 항상 False다.") void findDetailsWithoutBookmarkStatus_Success() { //given Topic topic1 = TopicFixture.createPublicAndAllMembersTopic(member); @@ -368,7 +368,7 @@ void findDetailsWithoutBookmarkStatus_Success() { } @Test - @DisplayName("멤버 Id를 이용하여 그 멤버가 만든 모든 Topic을 확인할 수 있다.") + @DisplayName("회원 Id를 이용하여 그 회원이 만든 모든 Topic을 확인할 수 있다.") void findAllTopicsByMemberId_Success() { //given AuthMember authMember = new Admin(member.getId()); diff --git a/backend/src/test/java/com/mapbefine/mapbefine/topic/domain/TopicStatusTest.java b/backend/src/test/java/com/mapbefine/mapbefine/topic/domain/TopicStatusTest.java index 74667963f..bde0c8064 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/topic/domain/TopicStatusTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/topic/domain/TopicStatusTest.java @@ -104,7 +104,7 @@ public void whenPermissionIsNull_Fail() { class Update { @Test - @DisplayName("권한 범위가 모든 멤버이면, 공개 범위를 혼자 볼 지도로 설정할 때 예외가 발생한다") + @DisplayName("권한 범위가 모든 회원이면, 공개 범위를 혼자 볼 지도로 설정할 때 예외가 발생한다") void whenAllMembersAndPrivate_thenFail() { //given TopicStatus topicStatus = TopicStatus.of(Publicity.PUBLIC, PermissionType.ALL_MEMBERS); diff --git a/backend/src/test/java/com/mapbefine/mapbefine/topic/presentation/TopicControllerTest.java b/backend/src/test/java/com/mapbefine/mapbefine/topic/presentation/TopicControllerTest.java index ba19dc2b5..da72796fe 100644 --- a/backend/src/test/java/com/mapbefine/mapbefine/topic/presentation/TopicControllerTest.java +++ b/backend/src/test/java/com/mapbefine/mapbefine/topic/presentation/TopicControllerTest.java @@ -219,7 +219,7 @@ void findAllByOrderByUpdatedAtDesc() throws Exception { } @Test - @DisplayName("멤버 Id를 입력하면 해당 멤버가 만든 지도 목록을 조회할 수 있다.") + @DisplayName("회원 Id를 입력하면 해당 회원이 만든 지도 목록을 조회할 수 있다.") void findAllTopicsByMemberId() throws Exception { given(topicQueryService.findAllTopicsByMemberId(any(), any())).willReturn(RESPONSES);