generated from pricelees/issue-pr-template
<!-- 제목 양식 --> <!-- [이슈번호] 작업 요약 (예시: [#10] Gitea 템플릿 생성) --> ## 📝 관련 이슈 및 PR **PR과 관련된 이슈 번호** - #3 ## ✨ 작업 내용 <!-- 어떤 작업을 했는지 알려주세요! --> ### 0. 공통 - 패키지 구조 수정(web, business, infrastructure 구조) - Swagger-UI 어노테이션을 별도의 인터페이스를 만들어 컨트롤러에서 분리 - 결합도 높은 클래스 통합(ex: Member 엔티티와 Role enum 등) ### 1. 회원 도메인 - 기능 자체가 적어서 변화된 내용이 크게 없음. 패키지 구조 수정과 클래스 통합 정도의 과정이 대부분이었음. ### 2. 인증 도메인 - 전체적으로 코드 중복이 많아, 확장함수 및 클래스 통합으로 중복 코드를 상당히 많이 제거하였음. - JwtHandler와 Interceptor에서 모두 이뤄지던 null 예외 처리를 JwtHandler에서만 처리하도록 수정 ## 🧪 테스트 <!-- 어떤 테스트를 생각했고 진행했는지 알려주세요! --> - 모든 테스트는 Kotest 기반으로 수정 & 로그인 및 토큰 처리가 필요한 API 테스트는 mocking을 활용하도록 수정 - 향후 테스트도 꼭 필요하다고 느껴지는 테스트가 아니라면 DB 사용보다는 mocking을 활용할 예정 ## 📚 참고 자료 및 기타 <!-- 참고한 자료, 또는 논의할 사항이 있다면 알려주세요! --> Reviewed-on: #4 Co-authored-by: pricelees <priceelees@gmail.com> Co-committed-by: pricelees <priceelees@gmail.com>
56 lines
1.9 KiB
Java
56 lines
1.9 KiB
Java
package roomescape.reservation.domain;
|
|
|
|
import java.time.LocalDate;
|
|
import java.time.LocalTime;
|
|
import java.util.stream.Stream;
|
|
|
|
import org.assertj.core.api.Assertions;
|
|
import org.junit.jupiter.api.DisplayName;
|
|
import org.junit.jupiter.params.ParameterizedTest;
|
|
import org.junit.jupiter.params.provider.Arguments;
|
|
import org.junit.jupiter.params.provider.MethodSource;
|
|
|
|
import roomescape.member.infrastructure.persistence.Member;
|
|
import roomescape.member.infrastructure.persistence.Role;
|
|
import roomescape.system.exception.RoomEscapeException;
|
|
import roomescape.theme.domain.Theme;
|
|
|
|
public class ReservationTest {
|
|
|
|
@ParameterizedTest
|
|
@MethodSource("validateConstructorParameterBlankSource")
|
|
@DisplayName("객체 생성 시, null 또는 공백이 존재하면 예외를 발생한다.")
|
|
void validateConstructorParameterBlank(LocalDate date, ReservationTime reservationTime, Theme theme,
|
|
Member member) {
|
|
|
|
// when & then
|
|
Assertions.assertThatThrownBy(
|
|
() -> new Reservation(date, reservationTime, theme, member, ReservationStatus.CONFIRMED))
|
|
.isInstanceOf(RoomEscapeException.class);
|
|
}
|
|
|
|
static Stream<Arguments> validateConstructorParameterBlankSource() {
|
|
return Stream.of(
|
|
Arguments.of(null,
|
|
new ReservationTime(LocalTime.now().plusHours(1)),
|
|
new Theme("테마명", "설명", "썸네일URI"),
|
|
new Member(null, "name", "email@email.com", "password", Role.MEMBER)),
|
|
Arguments.of(
|
|
LocalDate.now(),
|
|
null,
|
|
new Theme("테마명", "설명", "썸네일URI"),
|
|
new Member(null, "name", "email@email.com", "password", Role.MEMBER)),
|
|
Arguments.of(
|
|
LocalDate.now(),
|
|
new ReservationTime(LocalTime.now().plusHours(1)),
|
|
null,
|
|
new Member(null, "name", "email@email.com", "password", Role.MEMBER)),
|
|
Arguments.of(
|
|
LocalDate.now(),
|
|
new ReservationTime(LocalTime.now().plusHours(1)),
|
|
new Theme("테마명", "설명", "썸네일URI"),
|
|
null)
|
|
);
|
|
}
|
|
}
|