test #426
@@ -0,0 +1,39 @@
|
||||
package kr.co.vividnext.sodalive.v2.content.ranking.adapter.out.persistence
|
||||
|
||||
import com.querydsl.jpa.impl.JPAQueryFactory
|
||||
import kr.co.vividnext.sodalive.member.block.QBlockMember
|
||||
import kr.co.vividnext.sodalive.v2.content.ranking.port.out.AudioRankingBlockPort
|
||||
import org.springframework.stereotype.Repository
|
||||
|
||||
@Repository
|
||||
class DefaultAudioRankingBlockRepository(
|
||||
private val queryFactory: JPAQueryFactory
|
||||
) : AudioRankingBlockPort {
|
||||
override fun findBlockedCreatorMemberIds(memberId: Long, creatorMemberIds: Set<Long>): Set<Long> {
|
||||
if (creatorMemberIds.isEmpty()) return emptySet()
|
||||
val viewerBlock = QBlockMember("audioRankingViewerBlock")
|
||||
val creatorBlock = QBlockMember("audioRankingCreatorBlock")
|
||||
|
||||
val viewerBlockedIds = queryFactory
|
||||
.select(viewerBlock.blockedMember.id)
|
||||
.from(viewerBlock)
|
||||
.where(
|
||||
viewerBlock.isActive.isTrue,
|
||||
viewerBlock.member.id.eq(memberId),
|
||||
viewerBlock.blockedMember.id.`in`(creatorMemberIds)
|
||||
)
|
||||
.fetch()
|
||||
|
||||
val creatorBlockedIds = queryFactory
|
||||
.select(creatorBlock.member.id)
|
||||
.from(creatorBlock)
|
||||
.where(
|
||||
creatorBlock.isActive.isTrue,
|
||||
creatorBlock.member.id.`in`(creatorMemberIds),
|
||||
creatorBlock.blockedMember.id.eq(memberId)
|
||||
)
|
||||
.fetch()
|
||||
|
||||
return (viewerBlockedIds + creatorBlockedIds).toSet()
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,5 @@
|
||||
package kr.co.vividnext.sodalive.v2.content.ranking.port.out
|
||||
|
||||
interface AudioRankingBlockPort {
|
||||
fun findBlockedCreatorMemberIds(memberId: Long, creatorMemberIds: Set<Long>): Set<Long>
|
||||
}
|
||||
@@ -0,0 +1,100 @@
|
||||
package kr.co.vividnext.sodalive.v2.content.ranking.adapter.out.persistence
|
||||
|
||||
import com.querydsl.jpa.impl.JPAQueryFactory
|
||||
import kr.co.vividnext.sodalive.configs.QueryDslConfig
|
||||
import kr.co.vividnext.sodalive.member.Member
|
||||
import kr.co.vividnext.sodalive.member.MemberRole
|
||||
import kr.co.vividnext.sodalive.member.block.BlockMember
|
||||
import org.junit.jupiter.api.Assertions.assertEquals
|
||||
import org.junit.jupiter.api.DisplayName
|
||||
import org.junit.jupiter.api.Test
|
||||
import org.springframework.beans.factory.annotation.Autowired
|
||||
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest
|
||||
import org.springframework.context.annotation.Import
|
||||
import javax.persistence.EntityManager
|
||||
|
||||
@DataJpaTest(
|
||||
properties = [
|
||||
"spring.cache.type=none",
|
||||
"spring.datasource.url=jdbc:h2:mem:testdb;MODE=MySQL;NON_KEYWORDS=VALUE"
|
||||
]
|
||||
)
|
||||
@Import(QueryDslConfig::class)
|
||||
class DefaultAudioRankingBlockRepositoryTest @Autowired constructor(
|
||||
private val entityManager: EntityManager,
|
||||
queryFactory: JPAQueryFactory
|
||||
) {
|
||||
private val repository = DefaultAudioRankingBlockRepository(queryFactory)
|
||||
|
||||
@Test
|
||||
@DisplayName("활성 양방향 차단된 크리에이터 member id만 조회한다")
|
||||
fun shouldFindActiveBlockedCreatorMemberIdsInBothDirections() {
|
||||
val viewer = saveUser("viewer")
|
||||
val blockedByViewer = saveCreator("blocked-by-viewer")
|
||||
val blocksViewer = saveCreator("blocks-viewer")
|
||||
val inactiveBlocked = saveCreator("inactive-blocked")
|
||||
val allowed = saveCreator("allowed")
|
||||
val outsideInput = saveCreator("outside-input")
|
||||
saveBlock(viewer, blockedByViewer, isActive = true)
|
||||
saveBlock(blocksViewer, viewer, isActive = true)
|
||||
saveBlock(viewer, inactiveBlocked, isActive = false)
|
||||
saveBlock(viewer, outsideInput, isActive = true)
|
||||
flushAndClear()
|
||||
|
||||
val blockedCreatorMemberIds = repository.findBlockedCreatorMemberIds(
|
||||
memberId = viewer.id!!,
|
||||
creatorMemberIds = setOf(blockedByViewer.id!!, blocksViewer.id!!, inactiveBlocked.id!!, allowed.id!!)
|
||||
)
|
||||
|
||||
assertEquals(setOf(blockedByViewer.id, blocksViewer.id), blockedCreatorMemberIds)
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("크리에이터 member id 목록이 비어 있으면 빈 집합을 반환한다")
|
||||
fun shouldReturnEmptySetWhenCreatorMemberIdsIsEmpty() {
|
||||
val viewer = saveUser("empty-viewer")
|
||||
val creator = saveCreator("empty-creator")
|
||||
saveBlock(viewer, creator, isActive = true)
|
||||
flushAndClear()
|
||||
|
||||
val blockedCreatorMemberIds = repository.findBlockedCreatorMemberIds(
|
||||
memberId = viewer.id!!,
|
||||
creatorMemberIds = emptySet()
|
||||
)
|
||||
|
||||
assertEquals(emptySet<Long>(), blockedCreatorMemberIds)
|
||||
}
|
||||
|
||||
private fun saveCreator(nickname: String): Member {
|
||||
return saveMember(nickname, MemberRole.CREATOR)
|
||||
}
|
||||
|
||||
private fun saveUser(nickname: String): Member {
|
||||
return saveMember(nickname, MemberRole.USER)
|
||||
}
|
||||
|
||||
private fun saveMember(nickname: String, role: MemberRole): Member {
|
||||
val member = Member(
|
||||
email = "$nickname@test.com",
|
||||
password = "password",
|
||||
nickname = nickname,
|
||||
role = role,
|
||||
isActive = true
|
||||
)
|
||||
entityManager.persist(member)
|
||||
entityManager.flush()
|
||||
return member
|
||||
}
|
||||
|
||||
private fun saveBlock(member: Member, blockedMember: Member, isActive: Boolean) {
|
||||
val block = BlockMember(isActive = isActive)
|
||||
block.member = member
|
||||
block.blockedMember = blockedMember
|
||||
entityManager.persist(block)
|
||||
}
|
||||
|
||||
private fun flushAndClear() {
|
||||
entityManager.flush()
|
||||
entityManager.clear()
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user