From 530887b7d9b8a7fd7e7cfa4bc74bfa4d4a0b363f Mon Sep 17 00:00:00 2001 From: xxeol2 Date: Thu, 5 Oct 2023 10:29:05 +0900 Subject: [PATCH] =?UTF-8?q?[BE]=20refactor:=20assertThatThrownBy.hasMessag?= =?UTF-8?q?e()=EC=97=90=EC=84=9C=20ErrorCode=EB=A5=BC=20=ED=99=9C=EC=9A=A9?= =?UTF-8?q?=ED=95=98=EB=8F=84=EB=A1=9D=20=EC=88=98=EC=A0=95=20(#476)=20(#4?= =?UTF-8?q?77)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * refactor: AdminAuthServiceTest 네이밍 수정 * refactor: assertThatThrownBy hasMessage ErrorCode.getMessage로 수정 * refactor: 잘못된 ErrorCode 수정 --- .../festago/application/EntryServiceTest.java | 11 +++++++---- .../application/FestivalServiceTest.java | 9 ++++++--- .../application/MemberTicketServiceTest.java | 13 ++++++++----- .../application/StudentServiceTest.java | 17 +++++++++++------ .../StageServiceIntegrationTest.java | 3 ++- .../TicketServiceIntegrationTest.java | 3 ++- .../TicketingServiceIntegrationTest.java | 3 ++- ...viceTest.java => AdminAuthServiceTest.java} | 13 ++++++++----- .../auth/application/AuthServiceTest.java | 3 ++- .../festago/auth/domain/OAuth2ClientsTest.java | 6 ++++-- .../HeaderTokenExtractorTest.java | 3 ++- .../infrastructure/JwtAuthExtractorTest.java | 13 ++++++++----- .../KakaoOAuth2UserInfoClientTest.java | 8 +++++--- .../presentation/RoleArgumentResolverTest.java | 5 +++-- .../java/com/festago/domain/EntryCodeTest.java | 6 ++++-- .../com/festago/domain/EntryStateTest.java | 5 +++-- .../java/com/festago/domain/FestivalTest.java | 3 ++- .../java/com/festago/domain/StageTest.java | 8 +++++--- .../com/festago/domain/TicketAmountTest.java | 3 ++- .../festago/domain/TicketEntryTimeTest.java | 3 ++- .../java/com/festago/domain/TicketTest.java | 18 ++++++++++++------ .../JwtEntryCodeExtractorTest.java | 16 ++++++++++------ .../JwtEntryCodeProviderTest.java | 3 ++- .../application/TicketingServiceTest.java | 3 ++- 24 files changed, 114 insertions(+), 64 deletions(-) rename backend/src/test/java/com/festago/auth/application/{AdminAuthFacadeServiceTest.java => AdminAuthServiceTest.java} (89%) diff --git a/backend/src/test/java/com/festago/application/EntryServiceTest.java b/backend/src/test/java/com/festago/application/EntryServiceTest.java index 4da22514a..8786f8de6 100644 --- a/backend/src/test/java/com/festago/application/EntryServiceTest.java +++ b/backend/src/test/java/com/festago/application/EntryServiceTest.java @@ -1,5 +1,8 @@ package com.festago.application; +import static com.festago.common.exception.ErrorCode.MEMBER_TICKET_NOT_FOUND; +import static com.festago.common.exception.ErrorCode.NOT_ENTRY_TIME; +import static com.festago.common.exception.ErrorCode.NOT_MEMBER_TICKET_OWNER; import static org.assertj.core.api.AssertionsForClassTypes.assertThatThrownBy; import static org.assertj.core.api.SoftAssertions.assertSoftly; import static org.mockito.ArgumentMatchers.any; @@ -98,7 +101,7 @@ class 티켓의_QR_생성_요청 { // when & then assertThatThrownBy(() -> entryService.createEntryCode(memberId, memberTicketId)) .isInstanceOf(BadRequestException.class) - .hasMessage("입장 가능한 시간이 아닙니다."); + .hasMessage(NOT_ENTRY_TIME.getMessage()); } @Test @@ -129,7 +132,7 @@ class 티켓의_QR_생성_요청 { // when & then assertThatThrownBy(() -> entryService.createEntryCode(memberId, memberTicketId)) .isInstanceOf(BadRequestException.class) - .hasMessage("입장 가능한 시간이 아닙니다."); + .hasMessage(NOT_ENTRY_TIME.getMessage()); } @Test @@ -151,7 +154,7 @@ class 티켓의_QR_생성_요청 { // when & then assertThatThrownBy(() -> entryService.createEntryCode(memberId, memberTicketId)) .isInstanceOf(BadRequestException.class) - .hasMessage("해당 예매 티켓의 주인이 아닙니다."); + .hasMessage(NOT_MEMBER_TICKET_OWNER.getMessage()); } @Test @@ -164,7 +167,7 @@ class 티켓의_QR_생성_요청 { // when & then assertThatThrownBy(() -> entryService.createEntryCode(1L, memberTicketId)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않은 멤버 티켓입니다."); + .hasMessage(MEMBER_TICKET_NOT_FOUND.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/application/FestivalServiceTest.java b/backend/src/test/java/com/festago/application/FestivalServiceTest.java index cbd460b26..3a1fb9e4f 100644 --- a/backend/src/test/java/com/festago/application/FestivalServiceTest.java +++ b/backend/src/test/java/com/festago/application/FestivalServiceTest.java @@ -1,5 +1,8 @@ package com.festago.application; +import static com.festago.common.exception.ErrorCode.FESTIVAL_NOT_FOUND; +import static com.festago.common.exception.ErrorCode.INVALID_FESTIVAL_START_DATE; +import static com.festago.common.exception.ErrorCode.SCHOOL_NOT_FOUND; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.ArgumentMatchers.any; @@ -85,7 +88,7 @@ class 축제_생성 { // when & then assertThatThrownBy(() -> festivalService.create(request)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 학교입니다."); + .hasMessage(SCHOOL_NOT_FOUND.getMessage()); } @Test @@ -101,7 +104,7 @@ class 축제_생성 { // when & then assertThatThrownBy(() -> festivalService.create(request)) .isInstanceOf(BadRequestException.class) - .hasMessage("축제 시작 일자는 과거일 수 없습니다."); + .hasMessage(INVALID_FESTIVAL_START_DATE.getMessage()); } @Test @@ -140,7 +143,7 @@ class 축제_상세_조회 { // when & then assertThatThrownBy(() -> festivalService.findDetail(festivalId)).isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 축제입니다."); + .hasMessage(FESTIVAL_NOT_FOUND.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/application/MemberTicketServiceTest.java b/backend/src/test/java/com/festago/application/MemberTicketServiceTest.java index 4fa00125e..31f515d3f 100644 --- a/backend/src/test/java/com/festago/application/MemberTicketServiceTest.java +++ b/backend/src/test/java/com/festago/application/MemberTicketServiceTest.java @@ -1,5 +1,8 @@ package com.festago.application; +import static com.festago.common.exception.ErrorCode.MEMBER_NOT_FOUND; +import static com.festago.common.exception.ErrorCode.MEMBER_TICKET_NOT_FOUND; +import static com.festago.common.exception.ErrorCode.NOT_MEMBER_TICKET_OWNER; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.ArgumentMatchers.any; @@ -67,7 +70,7 @@ class 사용자의_멤버티켓_전체_조회 { // when & then assertThatThrownBy(() -> memberTicketService.findAll(memberId, PageRequest.ofSize(1))) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 멤버입니다."); + .hasMessage(MEMBER_NOT_FOUND.getMessage()); } } @@ -85,7 +88,7 @@ class 현재_멤버티켓_조회 { // when & then assertThatThrownBy(() -> memberTicketService.findCurrent(memberId, Pageable.ofSize(10))) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 멤버입니다."); + .hasMessage(MEMBER_NOT_FOUND.getMessage()); } @Test @@ -188,7 +191,7 @@ class 멤버_티켓_아이디로_단건_조회 { // when & then assertThatThrownBy(() -> memberTicketService.findById(memberId, 1L)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 멤버입니다."); + .hasMessage(MEMBER_NOT_FOUND.getMessage()); } @Test @@ -205,7 +208,7 @@ class 멤버_티켓_아이디로_단건_조회 { // when & then assertThatThrownBy(() -> memberTicketService.findById(memberId, memberTicketId)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않은 멤버 티켓입니다."); + .hasMessage(MEMBER_TICKET_NOT_FOUND.getMessage()); } @Test @@ -230,7 +233,7 @@ class 멤버_티켓_아이디로_단건_조회 { // when & then assertThatThrownBy(() -> memberTicketService.findById(memberId, otherTicketId)) .isInstanceOf(BadRequestException.class) - .hasMessage("해당 예매 티켓의 주인이 아닙니다."); + .hasMessage(NOT_MEMBER_TICKET_OWNER.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/application/StudentServiceTest.java b/backend/src/test/java/com/festago/application/StudentServiceTest.java index 41e94d388..d7e6d0a79 100644 --- a/backend/src/test/java/com/festago/application/StudentServiceTest.java +++ b/backend/src/test/java/com/festago/application/StudentServiceTest.java @@ -1,5 +1,10 @@ package com.festago.application; +import static com.festago.common.exception.ErrorCode.ALREADY_STUDENT_VERIFIED; +import static com.festago.common.exception.ErrorCode.DUPLICATE_STUDENT_EMAIL; +import static com.festago.common.exception.ErrorCode.INVALID_STUDENT_VERIFICATION_CODE; +import static com.festago.common.exception.ErrorCode.MEMBER_NOT_FOUND; +import static com.festago.common.exception.ErrorCode.SCHOOL_NOT_FOUND; import static org.assertj.core.api.Assertions.assertThatNoException; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.ArgumentMatchers.any; @@ -74,7 +79,7 @@ class 인증_메일_전송 { // when & then assertThatThrownBy(() -> studentService.sendVerificationMail(memberId, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("이미 학교 인증이 완료된 사용자입니다."); + .hasMessage(ALREADY_STUDENT_VERIFIED.getMessage()); } @Test @@ -93,7 +98,7 @@ class 인증_메일_전송 { // when & then assertThatThrownBy(() -> studentService.sendVerificationMail(memberId, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("이미 인증된 이메일입니다."); + .hasMessage(DUPLICATE_STUDENT_EMAIL.getMessage()); } @Test @@ -114,7 +119,7 @@ class 인증_메일_전송 { // when & then assertThatThrownBy(() -> studentService.sendVerificationMail(memberId, request)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 멤버입니다."); + .hasMessage(MEMBER_NOT_FOUND.getMessage()); } @Test @@ -142,7 +147,7 @@ class 인증_메일_전송 { // when & then assertThatThrownBy(() -> studentService.sendVerificationMail(memberId, request)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 학교입니다."); + .hasMessage(SCHOOL_NOT_FOUND.getMessage()); } @@ -188,7 +193,7 @@ class 학생_인증 { // when & then assertThatThrownBy(() -> studentService.verificate(memberId, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("이미 학교 인증이 완료된 사용자입니다."); + .hasMessage(ALREADY_STUDENT_VERIFIED.getMessage()); } @Test @@ -204,7 +209,7 @@ class 학생_인증 { // when & then assertThatThrownBy(() -> studentService.verificate(memberId, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("올바르지 않은 학생 인증 코드입니다."); + .hasMessage(INVALID_STUDENT_VERIFICATION_CODE.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/application/integration/StageServiceIntegrationTest.java b/backend/src/test/java/com/festago/application/integration/StageServiceIntegrationTest.java index 25f471e8e..31ecc5b58 100644 --- a/backend/src/test/java/com/festago/application/integration/StageServiceIntegrationTest.java +++ b/backend/src/test/java/com/festago/application/integration/StageServiceIntegrationTest.java @@ -1,5 +1,6 @@ package com.festago.application.integration; +import static com.festago.common.exception.ErrorCode.FESTIVAL_NOT_FOUND; import static org.assertj.core.api.Assertions.assertThatThrownBy; import com.festago.common.exception.NotFoundException; @@ -37,6 +38,6 @@ class StageServiceIntegrationTest extends ApplicationIntegrationTest { // when && then assertThatThrownBy(() -> stageService.create(request)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 축제입니다."); + .hasMessage(FESTIVAL_NOT_FOUND.getMessage()); } } diff --git a/backend/src/test/java/com/festago/application/integration/TicketServiceIntegrationTest.java b/backend/src/test/java/com/festago/application/integration/TicketServiceIntegrationTest.java index a53181663..8f50652b7 100644 --- a/backend/src/test/java/com/festago/application/integration/TicketServiceIntegrationTest.java +++ b/backend/src/test/java/com/festago/application/integration/TicketServiceIntegrationTest.java @@ -1,5 +1,6 @@ package com.festago.application.integration; +import static com.festago.common.exception.ErrorCode.STAGE_NOT_FOUND; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.Mockito.doReturn; @@ -68,7 +69,7 @@ class TicketServiceIntegrationTest extends ApplicationIntegrationTest { // when && then assertThatThrownBy(() -> ticketService.create(request)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않은 공연입니다."); + .hasMessage(STAGE_NOT_FOUND.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/application/integration/TicketingServiceIntegrationTest.java b/backend/src/test/java/com/festago/application/integration/TicketingServiceIntegrationTest.java index f2560661f..78fc657a8 100644 --- a/backend/src/test/java/com/festago/application/integration/TicketingServiceIntegrationTest.java +++ b/backend/src/test/java/com/festago/application/integration/TicketingServiceIntegrationTest.java @@ -1,5 +1,6 @@ package com.festago.application.integration; +import static com.festago.common.exception.ErrorCode.RESERVE_TICKET_OVER_AMOUNT; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.ArgumentMatchers.any; @@ -90,6 +91,6 @@ class TicketingServiceIntegrationTest extends ApplicationIntegrationTest { // when & then assertThatThrownBy(() -> ticketingService.ticketing(memberId, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("예매 가능한 수량을 초과했습니다."); + .hasMessage(RESERVE_TICKET_OVER_AMOUNT.getMessage()); } } diff --git a/backend/src/test/java/com/festago/auth/application/AdminAuthFacadeServiceTest.java b/backend/src/test/java/com/festago/auth/application/AdminAuthServiceTest.java similarity index 89% rename from backend/src/test/java/com/festago/auth/application/AdminAuthFacadeServiceTest.java rename to backend/src/test/java/com/festago/auth/application/AdminAuthServiceTest.java index 0a232719a..94e621354 100644 --- a/backend/src/test/java/com/festago/auth/application/AdminAuthFacadeServiceTest.java +++ b/backend/src/test/java/com/festago/auth/application/AdminAuthServiceTest.java @@ -1,5 +1,8 @@ package com.festago.auth.application; +import static com.festago.common.exception.ErrorCode.DUPLICATE_ACCOUNT_USERNAME; +import static com.festago.common.exception.ErrorCode.INCORRECT_PASSWORD_OR_ACCOUNT; +import static com.festago.common.exception.ErrorCode.NOT_ENOUGH_PERMISSION; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.BDDMockito.any; @@ -28,7 +31,7 @@ @DisplayNameGeneration(ReplaceUnderscores.class) @SuppressWarnings("NonAsciiCharacters") @ExtendWith(MockitoExtension.class) -class AdminAuthFacadeServiceTest { +class AdminAuthServiceTest { @Mock AuthProvider authProvider; @@ -52,7 +55,7 @@ class 로그인 { // when & then assertThatThrownBy(() -> adminAuthService.login(request)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("비밀번호가 틀렸거나, 해당 계정이 없습니다."); + .hasMessage(INCORRECT_PASSWORD_OR_ACCOUNT.getMessage()); } @Test @@ -66,7 +69,7 @@ class 로그인 { // when & then assertThatThrownBy(() -> adminAuthService.login(request)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("비밀번호가 틀렸거나, 해당 계정이 없습니다."); + .hasMessage(INCORRECT_PASSWORD_OR_ACCOUNT.getMessage()); } @Test @@ -102,7 +105,7 @@ class 가입 { // when & then assertThatThrownBy(() -> adminAuthService.signup(1L, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("해당 계정이 존재합니다."); + .hasMessage(DUPLICATE_ACCOUNT_USERNAME.getMessage()); } @Test @@ -115,7 +118,7 @@ class 가입 { // when & then assertThatThrownBy(() -> adminAuthService.signup(1L, request)) .isInstanceOf(ForbiddenException.class) - .hasMessage("해당 권한이 없습니다."); + .hasMessage(NOT_ENOUGH_PERMISSION.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/auth/application/AuthServiceTest.java b/backend/src/test/java/com/festago/auth/application/AuthServiceTest.java index e7f30e34b..36893f550 100644 --- a/backend/src/test/java/com/festago/auth/application/AuthServiceTest.java +++ b/backend/src/test/java/com/festago/auth/application/AuthServiceTest.java @@ -1,5 +1,6 @@ package com.festago.auth.application; +import static com.festago.common.exception.ErrorCode.MEMBER_NOT_FOUND; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatNoException; import static org.assertj.core.api.Assertions.assertThatThrownBy; @@ -92,7 +93,7 @@ class 회원탈퇴 { // then assertThatThrownBy(() -> authService.deleteMember(memberId)) .isInstanceOf(NotFoundException.class) - .hasMessage("존재하지 않는 멤버입니다."); + .hasMessage(MEMBER_NOT_FOUND.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/auth/domain/OAuth2ClientsTest.java b/backend/src/test/java/com/festago/auth/domain/OAuth2ClientsTest.java index 2eadd9f77..f1df89a40 100644 --- a/backend/src/test/java/com/festago/auth/domain/OAuth2ClientsTest.java +++ b/backend/src/test/java/com/festago/auth/domain/OAuth2ClientsTest.java @@ -1,5 +1,7 @@ package com.festago.auth.domain; +import static com.festago.common.exception.ErrorCode.DUPLICATE_SOCIAL_TYPE; +import static com.festago.common.exception.ErrorCode.OAUTH2_NOT_SUPPORTED_SOCIAL_TYPE; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.Mockito.mock; @@ -32,7 +34,7 @@ class OAuth2ClientsTest { // when & then assertThatThrownBy(() -> builder.add(new FestagoOAuth2Client())) .isInstanceOf(InternalServerException.class) - .hasMessage("중복된 OAuth2 제공자 입니다."); + .hasMessage(DUPLICATE_SOCIAL_TYPE.getMessage()); } @Test @@ -44,7 +46,7 @@ class OAuth2ClientsTest { // when & then assertThatThrownBy(() -> oAuth2Clients.getClient(SocialType.FESTAGO)) .isInstanceOf(BadRequestException.class) - .hasMessage("해당 OAuth2 제공자는 지원되지 않습니다."); + .hasMessage(OAUTH2_NOT_SUPPORTED_SOCIAL_TYPE.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/auth/infrastructure/HeaderTokenExtractorTest.java b/backend/src/test/java/com/festago/auth/infrastructure/HeaderTokenExtractorTest.java index 3f15dc7d2..c6d997676 100644 --- a/backend/src/test/java/com/festago/auth/infrastructure/HeaderTokenExtractorTest.java +++ b/backend/src/test/java/com/festago/auth/infrastructure/HeaderTokenExtractorTest.java @@ -1,5 +1,6 @@ package com.festago.auth.infrastructure; +import static com.festago.common.exception.ErrorCode.NOT_BEARER_TOKEN_TYPE; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.BDDMockito.given; @@ -43,7 +44,7 @@ class HeaderTokenExtractorTest { // when & then assertThatThrownBy(() -> headerTokenExtractor.extract(request)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("Bearer 타입의 토큰이 아닙니다."); + .hasMessage(NOT_BEARER_TOKEN_TYPE.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/auth/infrastructure/JwtAuthExtractorTest.java b/backend/src/test/java/com/festago/auth/infrastructure/JwtAuthExtractorTest.java index 3be793412..2af3d66f8 100644 --- a/backend/src/test/java/com/festago/auth/infrastructure/JwtAuthExtractorTest.java +++ b/backend/src/test/java/com/festago/auth/infrastructure/JwtAuthExtractorTest.java @@ -1,5 +1,8 @@ package com.festago.auth.infrastructure; +import static com.festago.common.exception.ErrorCode.EXPIRED_AUTH_TOKEN; +import static com.festago.common.exception.ErrorCode.INVALID_AUTH_TOKEN; +import static com.festago.common.exception.ErrorCode.INVALID_ROLE_NAME; import static org.assertj.core.api.Assertions.assertThatThrownBy; import com.festago.auth.domain.AuthPayload; @@ -36,7 +39,7 @@ class JwtAuthExtractorTest { // when & then assertThatThrownBy(() -> jwtAuthExtractor.extract(token)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("올바르지 않은 로그인 토큰입니다."); + .hasMessage(INVALID_AUTH_TOKEN.getMessage()); } @Test @@ -51,7 +54,7 @@ class JwtAuthExtractorTest { // when & then assertThatThrownBy(() -> jwtAuthExtractor.extract(token)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("만료된 로그인 토큰입니다."); + .hasMessage(EXPIRED_AUTH_TOKEN.getMessage()); } @Test @@ -68,7 +71,7 @@ class JwtAuthExtractorTest { // when & then assertThatThrownBy(() -> jwtAuthExtractor.extract(token)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("올바르지 않은 로그인 토큰입니다."); + .hasMessage(INVALID_AUTH_TOKEN.getMessage()); } @Test @@ -83,7 +86,7 @@ class JwtAuthExtractorTest { // when & then assertThatThrownBy(() -> jwtAuthExtractor.extract(token)) .isInstanceOf(InternalServerException.class) - .hasMessage("해당하는 Role이 없습니다."); + .hasMessage(INVALID_ROLE_NAME.getMessage()); } @Test @@ -91,7 +94,7 @@ class JwtAuthExtractorTest { // when & then assertThatThrownBy(() -> jwtAuthExtractor.extract(null)) .isInstanceOf(UnauthorizedException.class) - .hasMessage("올바르지 않은 로그인 토큰입니다."); + .hasMessage(INVALID_AUTH_TOKEN.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/auth/infrastructure/KakaoOAuth2UserInfoClientTest.java b/backend/src/test/java/com/festago/auth/infrastructure/KakaoOAuth2UserInfoClientTest.java index d2ef9f418..12958a788 100644 --- a/backend/src/test/java/com/festago/auth/infrastructure/KakaoOAuth2UserInfoClientTest.java +++ b/backend/src/test/java/com/festago/auth/infrastructure/KakaoOAuth2UserInfoClientTest.java @@ -1,5 +1,7 @@ package com.festago.auth.infrastructure; +import static com.festago.common.exception.ErrorCode.OAUTH2_INVALID_TOKEN; +import static com.festago.common.exception.ErrorCode.OAUTH2_PROVIDER_NOT_RESPONSE; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.assertj.core.api.SoftAssertions.assertSoftly; import static org.springframework.test.web.client.match.MockRestRequestMatchers.requestTo; @@ -49,7 +51,7 @@ class KakaoOAuth2UserInfoClientTest { // when & then assertThatThrownBy(() -> kakaoOAuth2UserInfoClient.getUserInfo("accessToken")) .isInstanceOf(BadRequestException.class) - .hasMessage("잘못된 OAuth2 토큰입니다."); + .hasMessage(OAUTH2_INVALID_TOKEN.getMessage()); } @Test @@ -62,7 +64,7 @@ class KakaoOAuth2UserInfoClientTest { // when & then assertThatThrownBy(() -> kakaoOAuth2UserInfoClient.getUserInfo("accessToken")) .isInstanceOf(BadRequestException.class) - .hasMessage("잘못된 OAuth2 토큰입니다."); + .hasMessage(OAUTH2_INVALID_TOKEN.getMessage()); } @Test @@ -75,7 +77,7 @@ class KakaoOAuth2UserInfoClientTest { // when & then assertThatThrownBy(() -> kakaoOAuth2UserInfoClient.getUserInfo("accessToken")) .isInstanceOf(InternalServerException.class) - .hasMessage("OAuth2 제공자 서버에 문제가 발생했습니다."); + .hasMessage(OAUTH2_PROVIDER_NOT_RESPONSE.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/auth/presentation/RoleArgumentResolverTest.java b/backend/src/test/java/com/festago/auth/presentation/RoleArgumentResolverTest.java index e66c993dd..c1b1b2514 100644 --- a/backend/src/test/java/com/festago/auth/presentation/RoleArgumentResolverTest.java +++ b/backend/src/test/java/com/festago/auth/presentation/RoleArgumentResolverTest.java @@ -1,5 +1,6 @@ package com.festago.auth.presentation; +import static com.festago.common.exception.ErrorCode.NOT_ENOUGH_PERMISSION; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; @@ -37,7 +38,7 @@ void setUp() { // when & then assertThatThrownBy(() -> roleArgumentResolver.resolveArgument(null, null, null, null)) .isInstanceOf(ForbiddenException.class) - .hasMessage("해당 권한이 없습니다."); + .hasMessage(NOT_ENOUGH_PERMISSION.getMessage()); } @Test @@ -63,7 +64,7 @@ void setUp() { // when & then assertThatThrownBy(() -> roleArgumentResolver.resolveArgument(null, null, null, null)) .isInstanceOf(ForbiddenException.class) - .hasMessage("해당 권한이 없습니다."); + .hasMessage(NOT_ENOUGH_PERMISSION.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/domain/EntryCodeTest.java b/backend/src/test/java/com/festago/domain/EntryCodeTest.java index f8444ca41..b85b744ad 100644 --- a/backend/src/test/java/com/festago/domain/EntryCodeTest.java +++ b/backend/src/test/java/com/festago/domain/EntryCodeTest.java @@ -1,5 +1,7 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_CODE_OFFSET; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_CODE_PERIOD; import static org.assertj.core.api.Assertions.assertThatNoException; import static org.assertj.core.api.AssertionsForClassTypes.assertThatThrownBy; @@ -21,7 +23,7 @@ class EntryCodeTest { // when & then assertThatThrownBy(() -> new EntryCode("code", period, 0)) .isInstanceOf(InternalServerException.class) - .hasMessage("올바르지 않은 입장코드 유효기간입니다."); + .hasMessage(INVALID_ENTRY_CODE_PERIOD.getMessage()); } @Test @@ -29,7 +31,7 @@ class EntryCodeTest { // when & tehn assertThatThrownBy(() -> new EntryCode("code", 30, -1)) .isInstanceOf(InternalServerException.class) - .hasMessage("올바르지 않은 입장코드 오프셋입니다."); + .hasMessage(INVALID_ENTRY_CODE_OFFSET.getMessage()); } @ParameterizedTest diff --git a/backend/src/test/java/com/festago/domain/EntryStateTest.java b/backend/src/test/java/com/festago/domain/EntryStateTest.java index 5060e890d..1ea7bc851 100644 --- a/backend/src/test/java/com/festago/domain/EntryStateTest.java +++ b/backend/src/test/java/com/festago/domain/EntryStateTest.java @@ -1,5 +1,6 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_STATE_INDEX; import static org.assertj.core.api.Assertions.assertThatNoException; import static org.assertj.core.api.Assertions.assertThatThrownBy; @@ -21,7 +22,7 @@ class EntryStateTest { // when & then assertThatThrownBy(() -> EntryState.from(index)) .isInstanceOf(InternalServerException.class) - .hasMessage("올바르지 않은 입장상태 인덱스입니다."); + .hasMessage(INVALID_ENTRY_STATE_INDEX.getMessage()); } @Test @@ -29,7 +30,7 @@ class EntryStateTest { // when & then assertThatThrownBy(() -> EntryState.from(null)) .isInstanceOf(InternalServerException.class) - .hasMessage("올바르지 않은 입장상태 인덱스입니다."); + .hasMessage(INVALID_ENTRY_STATE_INDEX.getMessage()); } @ParameterizedTest diff --git a/backend/src/test/java/com/festago/domain/FestivalTest.java b/backend/src/test/java/com/festago/domain/FestivalTest.java index 90d3a36f7..a31915e01 100644 --- a/backend/src/test/java/com/festago/domain/FestivalTest.java +++ b/backend/src/test/java/com/festago/domain/FestivalTest.java @@ -1,5 +1,6 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.INVALID_FESTIVAL_DURATION; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; @@ -28,7 +29,7 @@ class FestivalTest { // when & then assertThatThrownBy(() -> new Festival("테코대학교", today.plusDays(1), today, school)) .isInstanceOf(BadRequestException.class) - .hasMessage("축제 시작 일자는 종료일자 이전이어야합니다."); + .hasMessage(INVALID_FESTIVAL_DURATION.getMessage()); } @Nested diff --git a/backend/src/test/java/com/festago/domain/StageTest.java b/backend/src/test/java/com/festago/domain/StageTest.java index b1873ef1d..850410a2b 100644 --- a/backend/src/test/java/com/festago/domain/StageTest.java +++ b/backend/src/test/java/com/festago/domain/StageTest.java @@ -1,5 +1,7 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.INVALID_STAGE_START_TIME; +import static com.festago.common.exception.ErrorCode.INVALID_TICKET_OPEN_TIME; import static org.assertj.core.api.Assertions.assertThatNoException; import static org.assertj.core.api.Assertions.assertThatThrownBy; @@ -36,7 +38,7 @@ class StageTest { .build() ) .isInstanceOf(BadRequestException.class) - .hasMessage("공연은 축제 기간 중에만 진행될 수 있습니다."); + .hasMessage(INVALID_STAGE_START_TIME.getMessage()); } @Test @@ -57,7 +59,7 @@ class StageTest { .build() ) .isInstanceOf(BadRequestException.class) - .hasMessage("공연은 축제 기간 중에만 진행될 수 있습니다."); + .hasMessage(INVALID_STAGE_START_TIME.getMessage()); } @ParameterizedTest @@ -78,7 +80,7 @@ class StageTest { .build() ) .isInstanceOf(BadRequestException.class) - .hasMessage("티켓은 공연 시작 전에 오픈되어야 합니다."); + .hasMessage(INVALID_TICKET_OPEN_TIME.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/domain/TicketAmountTest.java b/backend/src/test/java/com/festago/domain/TicketAmountTest.java index 5260a1889..167eff3c6 100644 --- a/backend/src/test/java/com/festago/domain/TicketAmountTest.java +++ b/backend/src/test/java/com/festago/domain/TicketAmountTest.java @@ -1,5 +1,6 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.TICKET_SOLD_OUT; import static org.assertj.core.api.Assertions.assertThatThrownBy; import com.festago.common.exception.BadRequestException; @@ -25,6 +26,6 @@ class TicketAmountTest { // then assertThatThrownBy(ticketAmount::increaseReservedAmount) .isInstanceOf(BadRequestException.class) - .hasMessage("매진된 티켓입니다."); + .hasMessage(TICKET_SOLD_OUT.getMessage()); } } diff --git a/backend/src/test/java/com/festago/domain/TicketEntryTimeTest.java b/backend/src/test/java/com/festago/domain/TicketEntryTimeTest.java index 647042a4f..3c2025d6b 100644 --- a/backend/src/test/java/com/festago/domain/TicketEntryTimeTest.java +++ b/backend/src/test/java/com/festago/domain/TicketEntryTimeTest.java @@ -1,5 +1,6 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.INVALID_MIN_TICKET_AMOUNT; import static org.assertj.core.api.Assertions.assertThatThrownBy; import com.festago.common.exception.BadRequestException; @@ -32,6 +33,6 @@ class TicketEntryTimeTest { // when & then assertThatThrownBy(() -> new TicketEntryTime(now, 0)) .isInstanceOf(BadRequestException.class) - .hasMessage("티켓은 적어도 한장 이상 발급해야합니다."); + .hasMessage(INVALID_MIN_TICKET_AMOUNT.getMessage()); } } diff --git a/backend/src/test/java/com/festago/domain/TicketTest.java b/backend/src/test/java/com/festago/domain/TicketTest.java index e972aa9d4..d22c54593 100644 --- a/backend/src/test/java/com/festago/domain/TicketTest.java +++ b/backend/src/test/java/com/festago/domain/TicketTest.java @@ -1,5 +1,11 @@ package com.festago.domain; +import static com.festago.common.exception.ErrorCode.EARLY_TICKET_ENTRY_THAN_OPEN; +import static com.festago.common.exception.ErrorCode.EARLY_TICKET_ENTRY_TIME; +import static com.festago.common.exception.ErrorCode.INVALID_TICKET_CREATE_TIME; +import static com.festago.common.exception.ErrorCode.LATE_TICKET_ENTRY_TIME; +import static com.festago.common.exception.ErrorCode.TICKET_CANNOT_RESERVE_STAGE_START; +import static com.festago.common.exception.ErrorCode.TICKET_SOLD_OUT; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.AssertionsForClassTypes.assertThatThrownBy; import static org.assertj.core.api.SoftAssertions.assertSoftly; @@ -46,7 +52,7 @@ class 입장시간_추가_검증 { assertThatThrownBy( () -> ticket.addTicketEntryTime(now.minusMinutes(10), now.minusMinutes(minute), 100)) .isInstanceOf(BadRequestException.class) - .hasMessage("입장 시간은 티켓 오픈 시간 이후여야합니다."); + .hasMessage(EARLY_TICKET_ENTRY_THAN_OPEN.getMessage()); } @ParameterizedTest @@ -64,7 +70,7 @@ class 입장시간_추가_검증 { // when & then assertThatThrownBy(() -> ticket.addTicketEntryTime(ticketOpenTime.minusMinutes(10), entryTime, 100)) .isInstanceOf(BadRequestException.class) - .hasMessage("입장 시간은 공연 시간보다 빨라야합니다."); + .hasMessage(LATE_TICKET_ENTRY_TIME.getMessage()); } @Test @@ -81,7 +87,7 @@ class 입장시간_추가_검증 { // when & then assertThatThrownBy(() -> ticket.addTicketEntryTime(ticketOpenTime.minusMinutes(10), entryTime, 100)) .isInstanceOf(BadRequestException.class) - .hasMessage("입장 시간은 공연 시작 12시간 이내여야 합니다."); + .hasMessage(EARLY_TICKET_ENTRY_TIME.getMessage()); } @Test @@ -98,7 +104,7 @@ class 입장시간_추가_검증 { // when & then assertThatThrownBy(() -> ticket.addTicketEntryTime(LocalDateTime.now(), startTime.minusHours(3), 100)) .isInstanceOf(BadRequestException.class) - .hasMessage("티켓 예매 시작 후 새롭게 티켓을 발급할 수 없습니다."); + .hasMessage(INVALID_TICKET_CREATE_TIME.getMessage()); } @Test @@ -151,7 +157,7 @@ class 예매_티켓_생성 { // when & then assertThatThrownBy(() -> ticket.createMemberTicket(member, 101, now)) .isInstanceOf(BadRequestException.class) - .hasMessage("매진된 티켓입니다."); + .hasMessage(TICKET_SOLD_OUT.getMessage()); } @Test @@ -179,7 +185,7 @@ class 예매_티켓_생성 { // when & then assertThatThrownBy(() -> ticket.createMemberTicket(member, 1, now)) .isInstanceOf(BadRequestException.class) - .hasMessage("공연의 시작 시간 이후로 예매할 수 없습니다."); + .hasMessage(TICKET_CANNOT_RESERVE_STAGE_START.getMessage()); } @ParameterizedTest diff --git a/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeExtractorTest.java b/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeExtractorTest.java index 45fb0f6bf..cd362d593 100644 --- a/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeExtractorTest.java +++ b/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeExtractorTest.java @@ -1,5 +1,9 @@ package com.festago.infrastructure; +import static com.festago.common.exception.ErrorCode.EXPIRED_ENTRY_CODE; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_CODE; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_CODE_PAYLOAD; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_STATE_INDEX; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.assertj.core.api.SoftAssertions.assertSoftly; @@ -36,7 +40,7 @@ class JwtEntryCodeExtractorTest { // when & then assertThatThrownBy(() -> jwtEntryCodeExtractor.extract(code)) .isInstanceOf(BadRequestException.class) - .hasMessage("올바르지 않은 입장코드입니다."); + .hasMessage(INVALID_ENTRY_CODE.getMessage()); } @Test @@ -46,7 +50,7 @@ class JwtEntryCodeExtractorTest { // when & then assertThatThrownBy(() -> jwtEntryCodeExtractor.extract(code)) .isInstanceOf(BadRequestException.class) - .hasMessage("올바르지 않은 입장코드입니다."); + .hasMessage(INVALID_ENTRY_CODE.getMessage()); } @Test @@ -62,7 +66,7 @@ class JwtEntryCodeExtractorTest { // when & then assertThatThrownBy(() -> jwtEntryCodeExtractor.extract(code)) .isInstanceOf(BadRequestException.class) - .hasMessage("만료된 입장 코드입니다."); + .hasMessage(EXPIRED_ENTRY_CODE.getMessage()); } @Test @@ -80,7 +84,7 @@ class JwtEntryCodeExtractorTest { // when & then assertThatThrownBy(() -> jwtEntryCodeExtractor.extract(code)) .isInstanceOf(BadRequestException.class) - .hasMessage("올바르지 않은 입장코드입니다."); + .hasMessage(INVALID_ENTRY_CODE.getMessage()); } @Test @@ -95,7 +99,7 @@ class JwtEntryCodeExtractorTest { // when & then assertThatThrownBy(() -> jwtEntryCodeExtractor.extract(code)) .isInstanceOf(InternalServerException.class) - .hasMessage("유효하지 않은 입장코드 payload 입니다."); + .hasMessage(INVALID_ENTRY_CODE_PAYLOAD.getMessage()); } @Test @@ -110,7 +114,7 @@ class JwtEntryCodeExtractorTest { // when & then assertThatThrownBy(() -> jwtEntryCodeExtractor.extract(code)) .isInstanceOf(InternalServerException.class) - .hasMessage("올바르지 않은 입장상태 인덱스입니다."); + .hasMessage(INVALID_ENTRY_STATE_INDEX.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeProviderTest.java b/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeProviderTest.java index 6152092ae..f1509b032 100644 --- a/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeProviderTest.java +++ b/backend/src/test/java/com/festago/infrastructure/JwtEntryCodeProviderTest.java @@ -1,5 +1,6 @@ package com.festago.infrastructure; +import static com.festago.common.exception.ErrorCode.INVALID_ENTRY_CODE_EXPIRATION_TIME; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.assertj.core.api.SoftAssertions.assertSoftly; @@ -37,7 +38,7 @@ class JwtEntryCodeProviderTest { // when & then assertThatThrownBy(() -> entryCodeProvider.provide(entryCodePayload, expiredAt)) .isInstanceOf(InternalServerException.class) - .hasMessage("올바르지 않은 입장코드 만료 일자입니다."); + .hasMessage(INVALID_ENTRY_CODE_EXPIRATION_TIME.getMessage()); } @Test diff --git a/backend/src/test/java/com/festago/ticketing/application/TicketingServiceTest.java b/backend/src/test/java/com/festago/ticketing/application/TicketingServiceTest.java index 87a62e0e1..a3da48bbc 100644 --- a/backend/src/test/java/com/festago/ticketing/application/TicketingServiceTest.java +++ b/backend/src/test/java/com/festago/ticketing/application/TicketingServiceTest.java @@ -1,5 +1,6 @@ package com.festago.ticketing.application; +import static com.festago.common.exception.ErrorCode.NEED_STUDENT_VERIFICATION; import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.anyLong; @@ -77,6 +78,6 @@ void setUp() { // when & then assertThatThrownBy(() -> ticketingService.ticketing(1L, request)) .isInstanceOf(BadRequestException.class) - .hasMessage("학생 인증이 필요합니다."); + .hasMessage(NEED_STUDENT_VERIFICATION.getMessage()); } }