diff --git a/backend/src/main/java/corea/domain/JoinInfo.java b/backend/src/main/java/corea/domain/JoinInfo.java index 40edf1b6c..8fd570fcc 100644 --- a/backend/src/main/java/corea/domain/JoinInfo.java +++ b/backend/src/main/java/corea/domain/JoinInfo.java @@ -25,6 +25,6 @@ public class JoinInfo { private long roomId; public JoinInfo(final long memberId, final long roomId) { - this(null,memberId,roomId); + this(null, memberId, roomId); } } diff --git a/backend/src/main/java/corea/dto/JoinInfoResponse.java b/backend/src/main/java/corea/dto/JoinInfoResponse.java index 3b900f1a4..4ff5a56b6 100644 --- a/backend/src/main/java/corea/dto/JoinInfoResponse.java +++ b/backend/src/main/java/corea/dto/JoinInfoResponse.java @@ -6,8 +6,9 @@ public record JoinInfoResponse( long id, long memberId, long roomId -){ - public static JoinInfoResponse from(final JoinInfo joinInfo){ +) { + + public static JoinInfoResponse from(final JoinInfo joinInfo) { return new JoinInfoResponse( joinInfo.getId(), joinInfo.getMemberId(), diff --git a/backend/src/main/java/corea/dto/RoomCreateRequest.java b/backend/src/main/java/corea/dto/RoomCreateRequest.java index 655066263..c26d71fed 100644 --- a/backend/src/main/java/corea/dto/RoomCreateRequest.java +++ b/backend/src/main/java/corea/dto/RoomCreateRequest.java @@ -24,6 +24,7 @@ public Room toEntity() { matchingSize, keyword, submissionDeadline, - reviewDeadline); + reviewDeadline + ); } } diff --git a/backend/src/main/java/corea/dto/RoomResponse.java b/backend/src/main/java/corea/dto/RoomResponse.java index 510826de8..4d1b4387c 100644 --- a/backend/src/main/java/corea/dto/RoomResponse.java +++ b/backend/src/main/java/corea/dto/RoomResponse.java @@ -14,10 +14,9 @@ public record RoomResponse( String keyword, LocalDateTime submissionDeadline, LocalDateTime reviewDeadline - ) { - public static RoomResponse from(final Room room,final String memberEmail) { + public static RoomResponse of(final Room room, final String memberEmail) { return new RoomResponse( room.getId(), room.getTitle(), diff --git a/backend/src/main/java/corea/member/domain/Matching.java b/backend/src/main/java/corea/member/domain/Matching.java index de23b7084..8f050e23c 100644 --- a/backend/src/main/java/corea/member/domain/Matching.java +++ b/backend/src/main/java/corea/member/domain/Matching.java @@ -9,8 +9,8 @@ import static lombok.AccessLevel.PROTECTED; -@NoArgsConstructor(access = PROTECTED) @Component +@NoArgsConstructor(access = PROTECTED) public class Matching { public Map> matchGroup(final List members, final int matchingSize) { diff --git a/backend/src/main/java/corea/member/repository/MemberRepository.java b/backend/src/main/java/corea/member/repository/MemberRepository.java deleted file mode 100644 index 61c9db44e..000000000 --- a/backend/src/main/java/corea/member/repository/MemberRepository.java +++ /dev/null @@ -1,7 +0,0 @@ -package corea.member.repository; - -import corea.domain.Member; -import org.springframework.data.jpa.repository.JpaRepository; - -public interface MemberRepository extends JpaRepository { -} diff --git a/backend/src/main/java/corea/member/service/MatchingService.java b/backend/src/main/java/corea/member/service/MatchingService.java index 6ab052005..5bcd82492 100644 --- a/backend/src/main/java/corea/member/service/MatchingService.java +++ b/backend/src/main/java/corea/member/service/MatchingService.java @@ -1,8 +1,8 @@ package corea.member.service; +import corea.domain.Member; import corea.member.domain.Matching; import corea.member.entity.MatchedGroup; -import corea.domain.Member; import corea.member.repository.MatchedGroupRepository; import lombok.AllArgsConstructor; import org.springframework.stereotype.Service; diff --git a/backend/src/main/java/corea/service/RoomService.java b/backend/src/main/java/corea/service/RoomService.java index dae391660..d67353527 100644 --- a/backend/src/main/java/corea/service/RoomService.java +++ b/backend/src/main/java/corea/service/RoomService.java @@ -30,35 +30,27 @@ public class RoomService { public RoomResponse create(final RoomCreateRequest request) { final Room room = roomRepository.save(request.toEntity()); - final long memberId = request.memberId(); - final Member member = getMember(memberId); - return RoomResponse.from(room, member.getEmail()); + return toRoomResponse(room); } public RoomResponse findOne(final long id) { - final Room room = roomRepository.findById(id) - .orElseThrow(() -> new IllegalArgumentException(String.format("%d에 해당하는 방이 없습니다.", id))); - final Member member = getMember(room.getMemberId()); - - return RoomResponse.from(room, member.getEmail()); - } - - private Member getMember(final long memberId) { - return memberRepository.findById(memberId) - .orElseThrow(() -> new IllegalArgumentException(String.format("%d에 해당하는 멤버가 없습니다.", memberId))); + final Room room = getRoom(id); + return toRoomResponse(room); } public RoomResponses findAll() { final List rooms = roomRepository.findAll(); + return rooms.stream() - .map(room -> { - final long memberId = room.getMemberId(); - final Member member = getMember(memberId); - return RoomResponse.from(room, member.getEmail()); - }) + .map(this::toRoomResponse) .collect(collectingAndThen(toList(), RoomResponses::new)); } + private RoomResponse toRoomResponse(final Room room) { + final Member member = getMember(room.getMemberId()); + return RoomResponse.of(room, member.getEmail()); + } + public JoinInfoResponse join(final long roomId, final long memberId) { final Room room = getRoom(roomId); final Member member = getMember(memberId); @@ -67,8 +59,13 @@ public JoinInfoResponse join(final long roomId, final long memberId) { return JoinInfoResponse.from(joinInfoRepository.save(joinInfo)); } + private Member getMember(final long memberId) { + return memberRepository.findById(memberId) + .orElseThrow(() -> new IllegalArgumentException(String.format("해당 Id의 멤버가 없습니다. 입력된 Id=%d", memberId))); + } + public Room getRoom(final long roomId) { return roomRepository.findById(roomId) - .orElseThrow(() -> new IllegalArgumentException(String.format("%d에 해당하는 방이 없습니다.", roomId))); + .orElseThrow(() -> new IllegalArgumentException(String.format("해당 Id의 방이 없습니다. 입력된 Id=%d", roomId))); } } diff --git a/backend/src/test/java/corea/fixture/MemberFixture.java b/backend/src/test/java/corea/fixture/MemberFixture.java new file mode 100644 index 000000000..48de7d33b --- /dev/null +++ b/backend/src/test/java/corea/fixture/MemberFixture.java @@ -0,0 +1,10 @@ +package corea.fixture; + +import corea.domain.Member; + +public class MemberFixture { + + public static Member MEMBER_PORORO() { + return new Member("pororo@gmail.com"); + } +} diff --git a/backend/src/test/java/corea/fixture/RoomFixture.java b/backend/src/test/java/corea/fixture/RoomFixture.java index fcc91c74d..c5f384c1f 100644 --- a/backend/src/test/java/corea/fixture/RoomFixture.java +++ b/backend/src/test/java/corea/fixture/RoomFixture.java @@ -6,7 +6,8 @@ import java.time.LocalDateTime; public class RoomFixture { - public static RoomCreateRequest CREATE_REQUEST(final long memberId){ + + public static RoomCreateRequest ROOM_CREATE_REQUEST(final long memberId){ return new RoomCreateRequest( "레이싱 카와 함께하는 TDD", memberId, @@ -18,7 +19,8 @@ public static RoomCreateRequest CREATE_REQUEST(final long memberId){ LocalDateTime.now().plusDays(14) ); } - public static Room GET_DOMAIN(final long memberId){ + + public static Room ROOM_RACING_CAR(final long memberId){ return new Room( "레이싱 카와 함께하는 TDD", memberId, diff --git a/backend/src/test/java/corea/member/domain/MatchingTest.java b/backend/src/test/java/corea/member/domain/MatchingTest.java index 291add7b8..503847ecb 100644 --- a/backend/src/test/java/corea/member/domain/MatchingTest.java +++ b/backend/src/test/java/corea/member/domain/MatchingTest.java @@ -15,13 +15,13 @@ class MatchingTest { @Test @DisplayName("멤버 리스트를 받아서 매칭 결과를 반환한다.") - void matchGroup(){ + void matchGroup() { List members = List.of( new Member(1L, "test1@email.com"), new Member(2L, "test2@email.com"), new Member(3L, "test3@email.com"), new Member(4L, "test4@email.com") - ); + ); int matchingSize = 2; Map> results = matching.matchGroup(members, matchingSize); diff --git a/backend/src/test/java/corea/member/service/MatchingServiceTest.java b/backend/src/test/java/corea/member/service/MatchingServiceTest.java index d429f7a5e..2f7ce4885 100644 --- a/backend/src/test/java/corea/member/service/MatchingServiceTest.java +++ b/backend/src/test/java/corea/member/service/MatchingServiceTest.java @@ -1,27 +1,24 @@ package corea.member.service; +import config.ServiceTest; import corea.domain.Member; import corea.member.repository.MatchedGroupRepository; 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 java.util.List; import static org.assertj.core.api.Assertions.assertThat; -@SpringBootTest +@ServiceTest class MatchingServiceTest { - private final MatchingService matchingService; - private final MatchedGroupRepository matchedGroupRepository; + @Autowired + MatchingService matchingService; @Autowired - public MatchingServiceTest(MatchingService matchingService, MatchedGroupRepository matchedGroupRepository) { - this.matchingService = matchingService; - this.matchedGroupRepository = matchedGroupRepository; - } + MatchedGroupRepository matchedGroupRepository; @Test @DisplayName("멤버 리스트를 받아 매칭 결과를 반환한다.") @@ -38,5 +35,4 @@ void matchMaking() { assertThat(matchedGroupRepository.findAll()).hasSize(4); } - } diff --git a/backend/src/test/java/corea/service/RoomServiceTest.java b/backend/src/test/java/corea/service/RoomServiceTest.java index d9d3745d4..af55e5fa7 100644 --- a/backend/src/test/java/corea/service/RoomServiceTest.java +++ b/backend/src/test/java/corea/service/RoomServiceTest.java @@ -7,6 +7,7 @@ import corea.dto.RoomCreateRequest; import corea.dto.RoomResponse; import corea.dto.RoomResponses; +import corea.fixture.MemberFixture; import corea.fixture.RoomFixture; import corea.repository.MemberRepository; import corea.repository.RoomRepository; @@ -14,15 +15,13 @@ import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; -import java.time.LocalDateTime; - import static org.assertj.core.api.Assertions.assertThat; @ServiceTest class RoomServiceTest { @Autowired - RoomService sut; + RoomService roomService; @Autowired RoomRepository roomRepository; @@ -31,23 +30,12 @@ class RoomServiceTest { MemberRepository memberRepository; @Test - @DisplayName("요청을 통해 엔티티를 생성한다.") + @DisplayName("요청을 통해 방을 생성한다.") void create() { - final Member member = memberRepository.save(new Member( - "pororo@gmail.com" - )); - - final RoomCreateRequest request = new RoomCreateRequest( - "레이싱 카와 함께하는 TDD", - member.getId(), - "https://github.com/jcoding-play/java-racingcar", - "", - 3, - "TDD", - LocalDateTime.now().plusDays(7), - LocalDateTime.now().plusDays(14) - ); - final RoomResponse response = sut.create(request); + final Member member = memberRepository.save(MemberFixture.MEMBER_PORORO()); + + final RoomCreateRequest request = RoomFixture.ROOM_CREATE_REQUEST(member.getId()); + final RoomResponse response = roomService.create(request); assertThat(response.memberEmail()).isEqualTo("pororo@gmail.com"); } @@ -55,23 +43,11 @@ void create() { @Test @DisplayName("방을 조회한다.") void findOne() { - final Member member = memberRepository.save(new Member( - "pororo@gmail.com" - )); - - final RoomCreateRequest request = new RoomCreateRequest( - "레이싱 카와 함께하는 TDD", - member.getId(), - "https://github.com/jcoding-play/java-racingcar", - "", - 3, - "TDD", - LocalDateTime.now().plusDays(7), - LocalDateTime.now().plusDays(14) - ); - final RoomResponse response = sut.create(request); - - final RoomResponse findRoom = sut.findOne(response.id()); + final Member member = memberRepository.save(MemberFixture.MEMBER_PORORO()); + final RoomCreateRequest request = RoomFixture.ROOM_CREATE_REQUEST(member.getId()); + final RoomResponse response = roomService.create(request); + + final RoomResponse findRoom = roomService.findOne(response.id()); assertThat(findRoom).isEqualTo(response); } @@ -79,27 +55,22 @@ void findOne() { @Test @DisplayName("전체 방을 조회한다.") void findAll() { - final Member member = memberRepository.save(new Member( - "pororo@gmail.com" - )); - - final RoomCreateRequest request = RoomFixture.CREATE_REQUEST(member.getId()); - sut.create(request); + final Member member = memberRepository.save(MemberFixture.MEMBER_PORORO()); + final RoomCreateRequest request = RoomFixture.ROOM_CREATE_REQUEST(member.getId()); + roomService.create(request); - final RoomResponses response = sut.findAll(); + final RoomResponses response = roomService.findAll(); assertThat(response.rooms()).hasSize(1); } @Test @DisplayName("방에 참가한다.") - void join(){ - final Member member = memberRepository.save(new Member( - "pororo@gmail.com" - )); - final Room room = roomRepository.save(RoomFixture.GET_DOMAIN(member.getId())); + void join() { + final Member member = memberRepository.save(MemberFixture.MEMBER_PORORO()); + final Room room = roomRepository.save(RoomFixture.ROOM_RACING_CAR(member.getId())); - final JoinInfoResponse response = sut.join(room.getId(),member.getId()); + final JoinInfoResponse response = roomService.join(room.getId(), member.getId()); assertThat(response.memberId()).isEqualTo(member.getId()); assertThat(response.roomId()).isEqualTo(room.getId());