mirror of https://github.com/usbharu/Hideout.git
test: ローカル投稿削除の配送テストを追加
This commit is contained in:
parent
bf2c50c445
commit
9a8fd22b92
|
@ -1,6 +1,7 @@
|
||||||
package dev.usbharu.hideout.core.service.post
|
package dev.usbharu.hideout.core.service.post
|
||||||
|
|
||||||
import dev.usbharu.hideout.activitypub.service.activity.create.ApSendCreateService
|
import dev.usbharu.hideout.activitypub.service.activity.create.ApSendCreateService
|
||||||
|
import dev.usbharu.hideout.activitypub.service.activity.delete.APSendDeleteService
|
||||||
import dev.usbharu.hideout.application.config.CharacterLimit
|
import dev.usbharu.hideout.application.config.CharacterLimit
|
||||||
import dev.usbharu.hideout.core.domain.exception.resource.DuplicateException
|
import dev.usbharu.hideout.core.domain.exception.resource.DuplicateException
|
||||||
import dev.usbharu.hideout.core.domain.model.actor.ActorRepository
|
import dev.usbharu.hideout.core.domain.model.actor.ActorRepository
|
||||||
|
@ -43,6 +44,9 @@ class PostServiceImplTest {
|
||||||
@Mock
|
@Mock
|
||||||
private lateinit var reactionRepository: ReactionRepository
|
private lateinit var reactionRepository: ReactionRepository
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private lateinit var apSendDeleteService: APSendDeleteService
|
||||||
|
|
||||||
@InjectMocks
|
@InjectMocks
|
||||||
private lateinit var postServiceImpl: PostServiceImpl
|
private lateinit var postServiceImpl: PostServiceImpl
|
||||||
|
|
||||||
|
@ -130,4 +134,32 @@ class PostServiceImplTest {
|
||||||
verify(postRepository, times(1)).save(eq(post))
|
verify(postRepository, times(1)).save(eq(post))
|
||||||
verify(timelineService, times(1)).publishTimeline(eq(post), eq(false))
|
verify(timelineService, times(1)).publishTimeline(eq(post), eq(false))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `deleteLocal Deleteが配送される`() = runTest {
|
||||||
|
val post = PostBuilder.of()
|
||||||
|
|
||||||
|
val localUserOf = UserBuilder.localUserOf()
|
||||||
|
|
||||||
|
whenever(actorRepository.findById(eq(post.actorId))).doReturn(localUserOf)
|
||||||
|
|
||||||
|
postServiceImpl.deleteLocal(post)
|
||||||
|
|
||||||
|
verify(reactionRepository, times(1)).deleteByPostId(eq(post.id))
|
||||||
|
verify(postRepository, times(1)).save(eq(post.delete()))
|
||||||
|
verify(apSendDeleteService, times(1)).sendDeleteNote(eq(post))
|
||||||
|
verify(actorRepository, times(1)).save(eq(localUserOf.decrementPostsCount()))
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `deleteLocal 削除済み投稿は何もしない`() = runTest {
|
||||||
|
val delete = PostBuilder.of().delete()
|
||||||
|
|
||||||
|
postServiceImpl.deleteLocal(delete)
|
||||||
|
|
||||||
|
verify(reactionRepository, never()).deleteByPostId(any())
|
||||||
|
verify(postRepository, never()).save(any())
|
||||||
|
verify(apSendDeleteService, never()).sendDeleteNote(any())
|
||||||
|
verify(actorRepository, never()).save(any())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue