From 367513705e25d7906a4ff4035ec706afaf002213 Mon Sep 17 00:00:00 2001 From: Miseong Kim Date: Fri, 15 Nov 2024 21:35:10 +0900 Subject: [PATCH] =?UTF-8?q?fix:=20=EB=9E=9C=EB=8D=A4=20=EB=B3=B4=ED=8B=80?= =?UTF-8?q?=20=EC=97=AC=EB=9F=AC=EA=B0=9C=20=EB=B0=9B=EC=95=84=EC=A7=80?= =?UTF-8?q?=EB=8A=94=20=EB=AC=B8=EC=A0=9C=20=ED=95=B4=EA=B2=B0=20(#570)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../app/bottle/service/BottleService.kt | 30 +++++++++++++++---- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/app/src/main/kotlin/com/nexters/bottles/app/bottle/service/BottleService.kt b/app/src/main/kotlin/com/nexters/bottles/app/bottle/service/BottleService.kt index 1398fc3..8873740 100644 --- a/app/src/main/kotlin/com/nexters/bottles/app/bottle/service/BottleService.kt +++ b/app/src/main/kotlin/com/nexters/bottles/app/bottle/service/BottleService.kt @@ -188,7 +188,13 @@ class BottleService( val matchingUsers = userRepository.findByIdInAndDeletedFalse(matchingUserDtos.map { it.willMatchUserId }) val now = LocalDateTime.now() - var bottles = matchingUsers.map { matchingUser -> Bottle(targetUser = user, sourceUser = matchingUser, expiredAt = now.plusDays(1)) } + var bottles = matchingUsers.map { matchingUser -> + Bottle( + targetUser = user, + sourceUser = matchingUser, + expiredAt = now.plusDays(1) + ) + } val savedBottles = bottleRepository.saveAll(bottles) user.updateLastRandomMatchedAt(LocalDateTime.now()) @@ -225,7 +231,13 @@ class BottleService( val matchingUsers = userRepository.findByIdInAndDeletedFalse(matchingUserDtos.map { it.willMatchUserId }) val now = LocalDateTime.now() - var bottles = matchingUsers.map { matchingUser -> Bottle(targetUser = user, sourceUser = matchingUser, expiredAt = now.plusDays(1)) } + var bottles = matchingUsers.map { matchingUser -> + Bottle( + targetUser = user, + sourceUser = matchingUser, + expiredAt = now.plusDays(1) + ) + } val savedBottles = bottleRepository.saveAll(bottles) user.updateLastRandomMatchedAt(LocalDateTime.now()) @@ -255,7 +267,7 @@ class BottleService( // 필터링된 사용자가 count에 도달하지 못하면 추가로 사용자 채우기 - return if (canBeMatchedDtos.size < count) { + val result = if (canBeMatchedDtos.size < count) { val additionalDtos = usersCanBeMatchedDtos.shuffled() .filter { it !in canBeMatchedDtos } // 이미 선택된 항목을 제외 .take(count - canBeMatchedDtos.size) // 모자란 개수만큼 추가 @@ -263,6 +275,8 @@ class BottleService( } else { canBeMatchedDtos } + + return result.take(count) // 결과에서 count만큼만 반환 } @Transactional(readOnly = true) @@ -301,14 +315,20 @@ class BottleService( fun matchFirstRandomBottle(userId: Long, count: Int): List { val user = userRepository.findByIdOrNull(userId) ?: throw IllegalStateException("회원가입 상태를 문의해주세요") - val usersCanBeMatched = bottleMatchingRepository.findAllUserCanBeMatched(user.id, user.gender!!).take(count) + val usersCanBeMatched = bottleMatchingRepository.findAllUserCanBeMatched(user.id, user.gender!!) if (usersCanBeMatched.isEmpty()) return emptyList() val matchingUserDtos = findUserSameRegionOrRandom(usersCanBeMatched, user, count) val matchingUsers = userRepository.findByIdInAndDeletedFalse(matchingUserDtos.map { it.willMatchUserId }) val now = LocalDateTime.now() - var bottles = matchingUsers.map { matchingUser -> Bottle(targetUser = user, sourceUser = matchingUser, expiredAt = now.plusDays(1)) } + var bottles = matchingUsers.map { matchingUser -> + Bottle( + targetUser = user, + sourceUser = matchingUser, + expiredAt = now.plusDays(1) + ) + } val savedBottles = bottleRepository.saveAll(bottles) user.updateLastRandomMatchedAt(now)