generated from pricelees/issue-pr-template
<!-- 제목 양식 --> <!-- [이슈번호] 작업 요약 (예시: [#10] Gitea 템플릿 생성) --> ## 📝 관련 이슈 및 PR **PR과 관련된 이슈 번호** - #30 ## ✨ 작업 내용 <!-- 어떤 작업을 했는지 알려주세요! --> - ReservationService를 읽기(Find) / 쓰기(Write) 서비스로 분리 - 모든 도메인에 repository를 사용하는 Finder, Writer, Validator 도입 -> ReservationService에 있는 조회, 검증, 쓰기 작업을 별도의 클래스로 분리하기 위함이었고, 이 과정에서 다른 도메인에도 도입함. ## 🧪 테스트 <!-- 어떤 테스트를 생각했고 진행했는지 알려주세요! --> 새로 추가된 기능 & 클래스는 모두 테스트 추가하였고, 작업 후 전체 테스트 완료 ## 📚 참고 자료 및 기타 <!-- 참고한 자료, 또는 논의할 사항이 있다면 알려주세요! --> Reviewed-on: #31 Co-authored-by: pricelees <priceelees@gmail.com> Co-committed-by: pricelees <priceelees@gmail.com>
101 lines
3.2 KiB
Kotlin
101 lines
3.2 KiB
Kotlin
package roomescape.member.business
|
|
|
|
import io.kotest.assertions.assertSoftly
|
|
import io.kotest.assertions.throwables.shouldThrow
|
|
import io.kotest.core.spec.style.FunSpec
|
|
import io.kotest.matchers.collections.shouldContainExactly
|
|
import io.kotest.matchers.collections.shouldHaveSize
|
|
import io.kotest.matchers.shouldBe
|
|
import io.mockk.every
|
|
import io.mockk.mockk
|
|
import roomescape.member.exception.MemberErrorCode
|
|
import roomescape.member.exception.MemberException
|
|
import roomescape.member.implement.MemberFinder
|
|
import roomescape.member.implement.MemberWriter
|
|
import roomescape.member.infrastructure.persistence.MemberEntity
|
|
import roomescape.member.infrastructure.persistence.Role
|
|
import roomescape.member.web.SignupRequest
|
|
import roomescape.util.MemberFixture
|
|
|
|
class MemberServiceTest : FunSpec({
|
|
val memberWriter: MemberWriter = mockk()
|
|
val memberFinder: MemberFinder = mockk()
|
|
|
|
val memberService = MemberService(memberWriter, memberFinder)
|
|
|
|
context("findMembers") {
|
|
test("정상 응답") {
|
|
val members: List<MemberEntity> = listOf(
|
|
MemberFixture.create(name = "user1"),
|
|
MemberFixture.create(name = "user2"),
|
|
)
|
|
|
|
every { memberFinder.findAll() } returns members
|
|
|
|
val response = memberService.findMembers()
|
|
|
|
// then
|
|
assertSoftly(response.members) {
|
|
it shouldHaveSize 2
|
|
it.map { member -> member.name } shouldContainExactly listOf("user1", "user2")
|
|
}
|
|
}
|
|
}
|
|
|
|
context("findById") {
|
|
val id = 1L
|
|
|
|
test("정상 응답") {
|
|
every {
|
|
memberFinder.findById(id)
|
|
} returns MemberFixture.create(id = id)
|
|
|
|
memberService.findById(id).id shouldBe id
|
|
}
|
|
|
|
test("회원을 찾을 수 없으면 예외 응답") {
|
|
every {
|
|
memberFinder.findById(id)
|
|
} throws MemberException(MemberErrorCode.MEMBER_NOT_FOUND)
|
|
|
|
shouldThrow<MemberException> {
|
|
memberService.findById(id)
|
|
}.also {
|
|
it.errorCode shouldBe MemberErrorCode.MEMBER_NOT_FOUND
|
|
}
|
|
}
|
|
}
|
|
|
|
context("createMember") {
|
|
val request = SignupRequest(name = "new-user", email = "new@test.com", password = "password")
|
|
|
|
test("정상 저장") {
|
|
val member = MemberFixture.create(
|
|
name = request.name,
|
|
account = request.email,
|
|
password = request.password
|
|
)
|
|
|
|
every {
|
|
memberWriter.create(request.name, request.email, request.password, Role.MEMBER)
|
|
} returns member
|
|
|
|
val response = memberService.createMember(request)
|
|
|
|
response.id shouldBe member.id
|
|
}
|
|
|
|
test("중복된 이메일이 있으면 예외 응답") {
|
|
every {
|
|
memberWriter.create(request.name, request.email, request.password, Role.MEMBER)
|
|
} throws MemberException(MemberErrorCode.DUPLICATE_EMAIL)
|
|
|
|
shouldThrow<MemberException> {
|
|
memberService.createMember(request)
|
|
}.also {
|
|
it.errorCode shouldBe MemberErrorCode.DUPLICATE_EMAIL
|
|
}
|
|
}
|
|
}
|
|
})
|