From e9c8e612fa86d196283b0364306d46a74b609e65 Mon Sep 17 00:00:00 2001 From: pricelees Date: Thu, 2 Oct 2025 22:15:17 +0900 Subject: [PATCH] =?UTF-8?q?fix:=20=EC=8B=9C=EA=B0=84=EC=9D=B4=2000?= =?UTF-8?q?=EC=8B=9C=EB=A5=BC=20=EB=84=98=EC=96=B4=EA=B0=80=20=ED=8A=B9?= =?UTF-8?q?=EC=A0=95=20=EC=8B=9C=EA=B0=84=20=EC=9D=B4=ED=9B=84=EC=97=90?= =?UTF-8?q?=EB=8A=94=20=EC=8B=A4=ED=8C=A8=ED=95=98=EB=8A=94=20=ED=85=8C?= =?UTF-8?q?=EC=8A=A4=ED=8A=B8=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../roomescape/schedule/ScheduleApiTest.kt | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/service/src/test/kotlin/com/sangdol/roomescape/schedule/ScheduleApiTest.kt b/service/src/test/kotlin/com/sangdol/roomescape/schedule/ScheduleApiTest.kt index c5d25372..96453cff 100644 --- a/service/src/test/kotlin/com/sangdol/roomescape/schedule/ScheduleApiTest.kt +++ b/service/src/test/kotlin/com/sangdol/roomescape/schedule/ScheduleApiTest.kt @@ -1,9 +1,5 @@ package com.sangdol.roomescape.schedule -import io.kotest.matchers.shouldBe -import org.hamcrest.CoreMatchers.equalTo -import org.springframework.data.repository.findByIdOrNull -import org.springframework.http.HttpMethod import com.sangdol.common.types.web.HttpStatus import com.sangdol.roomescape.admin.infrastructure.persistence.AdminPermissionLevel import com.sangdol.roomescape.admin.infrastructure.persistence.AdminType @@ -12,6 +8,10 @@ import com.sangdol.roomescape.schedule.exception.ScheduleErrorCode import com.sangdol.roomescape.schedule.infrastructure.persistence.ScheduleRepository import com.sangdol.roomescape.schedule.infrastructure.persistence.ScheduleStatus import com.sangdol.roomescape.supports.* +import io.kotest.matchers.shouldBe +import org.hamcrest.CoreMatchers.equalTo +import org.springframework.data.repository.findByIdOrNull +import org.springframework.http.HttpMethod import java.time.LocalDate import java.time.LocalTime @@ -20,7 +20,7 @@ class ScheduleApiTest( ) : FunSpecSpringbootTest() { init { context("특정 매장 + 날짜의 일정 및 테마 정보를 조회한다.") { - test("날짜가 오늘이면 현재 시간 이후의 정보만 조회된다.") { + test("날짜가 당일이면 현재 시간 이후의 정보만 조회된다.") { val size = 3 val date = LocalDate.now() val store = dummyInitializer.createStore() @@ -31,7 +31,7 @@ class ScheduleApiTest( storeId = store.id, request = ScheduleFixture.createRequest.copy( date = date, - time = LocalTime.now().plusHours(i.toLong()) + time = LocalTime.now().plusMinutes(i.toLong()) ) ) } @@ -45,13 +45,17 @@ class ScheduleApiTest( ) } + val expectedSize = scheduleRepository.findAll().takeIf { it.isNotEmpty() } + ?.let { it.count { schedule -> schedule.date.isEqual(date) && schedule.time.isAfter(LocalTime.now()) } } + ?: throw AssertionError("initialize 작업에서 레코드가 저장되지 않음.") + runTest( on = { get("/stores/${store.id}/schedules?date=${date}") }, expect = { statusCode(HttpStatus.OK.value()) - body("data.schedules.size()", equalTo(size)) + body("data.schedules.size()", equalTo(expectedSize)) assertProperties( props = setOf("id", "startFrom", "endAt", "themeId", "themeName", "themeDifficulty", "status"), propsNameIfList = "schedules"