From ba16e3ff196c67b6deffd9b76be1419c6a090930 Mon Sep 17 00:00:00 2001 From: usbharu <64310155+usbharu@users.noreply.github.com> Date: Thu, 10 Aug 2023 19:42:18 +0900 Subject: [PATCH] =?UTF-8?q?refactor:=20Repository=E3=81=AB=E4=B8=8D?= =?UTF-8?q?=E8=A6=81=E3=81=AA=E9=96=A2=E6=95=B0=E3=82=92=E5=89=8A=E9=99=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../usbharu/hideout/plugins/ActivityPub.kt | 12 +- .../dev/usbharu/hideout/plugins/Routing.kt | 2 +- .../hideout/repository/IUserRepository.kt | 27 +--- .../hideout/repository/UserRepository.kt | 135 ---------------- .../hideout/routing/api/internal/v1/Auth.kt | 10 +- .../auth/HttpSignatureVerifyServiceImpl.kt | 6 +- .../hideout/service/user/UserAuthService.kt | 9 +- .../hideout/service/user/UserService.kt | 12 +- .../hideout/plugins/ActivityPubKtTest.kt | 118 +++----------- .../usbharu/hideout/plugins/KtorKeyMapTest.kt | 86 ++-------- .../usbharu/hideout/plugins/SecurityKtTest.kt | 18 +-- .../hideout/repository/UserRepositoryTest.kt | 151 ------------------ .../hideout/service/user/UserServiceTest.kt | 4 +- 13 files changed, 73 insertions(+), 517 deletions(-) delete mode 100644 src/test/kotlin/dev/usbharu/hideout/repository/UserRepositoryTest.kt diff --git a/src/main/kotlin/dev/usbharu/hideout/plugins/ActivityPub.kt b/src/main/kotlin/dev/usbharu/hideout/plugins/ActivityPub.kt index cbaec3a5..669c01ec 100644 --- a/src/main/kotlin/dev/usbharu/hideout/plugins/ActivityPub.kt +++ b/src/main/kotlin/dev/usbharu/hideout/plugins/ActivityPub.kt @@ -2,7 +2,7 @@ package dev.usbharu.hideout.plugins import dev.usbharu.hideout.config.Config import dev.usbharu.hideout.domain.model.ap.JsonLd -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.service.user.UserAuthService import dev.usbharu.hideout.util.HttpUtil.Activity import io.ktor.client.* @@ -164,15 +164,15 @@ val httpSignaturePlugin = createClientPlugin("HttpSign", ::HttpSignaturePluginCo } } -class KtorKeyMap(private val userAuthRepository: IUserRepository) : KeyMap { +class KtorKeyMap(private val userQueryService: UserQueryService) : KeyMap { override fun getPublicKey(keyId: String?): PublicKey = runBlocking { val username = (keyId ?: throw IllegalArgumentException("keyId is null")).substringBeforeLast("#pubkey") .substringAfterLast("/") val publicBytes = Base64.getDecoder().decode( - userAuthRepository.findByNameAndDomain( + userQueryService.findByNameAndDomain( username, Config.configData.domain - )?.run { + ).run { publicKey .replace("-----BEGIN PUBLIC KEY-----", "") .replace("-----END PUBLIC KEY-----", "") @@ -187,10 +187,10 @@ class KtorKeyMap(private val userAuthRepository: IUserRepository) : KeyMap { val username = (keyId ?: throw IllegalArgumentException("keyId is null")).substringBeforeLast("#pubkey") .substringAfterLast("/") val publicBytes = Base64.getDecoder().decode( - userAuthRepository.findByNameAndDomain( + userQueryService.findByNameAndDomain( username, Config.configData.domain - )?.privateKey?.run { + ).privateKey?.run { replace("-----BEGIN PRIVATE KEY-----", "") .replace("-----END PRIVATE KEY-----", "") .replace("\n", "") diff --git a/src/main/kotlin/dev/usbharu/hideout/plugins/Routing.kt b/src/main/kotlin/dev/usbharu/hideout/plugins/Routing.kt index 59d39369..ca62091c 100644 --- a/src/main/kotlin/dev/usbharu/hideout/plugins/Routing.kt +++ b/src/main/kotlin/dev/usbharu/hideout/plugins/Routing.kt @@ -47,7 +47,7 @@ fun Application.configureRouting( route("/api/internal/v1") { posts(postService, reactionService) users(userService, userApiService) - auth(userAuthService, userRepository, jwtService) + auth(userAuthService, jwtService, userQueryService) } } } diff --git a/src/main/kotlin/dev/usbharu/hideout/repository/IUserRepository.kt b/src/main/kotlin/dev/usbharu/hideout/repository/IUserRepository.kt index 07912009..e717f7b0 100644 --- a/src/main/kotlin/dev/usbharu/hideout/repository/IUserRepository.kt +++ b/src/main/kotlin/dev/usbharu/hideout/repository/IUserRepository.kt @@ -8,35 +8,10 @@ interface IUserRepository { suspend fun findById(id: Long): User? - suspend fun findByIds(ids: List): List - - suspend fun findByName(name: String): List - - suspend fun findByNameAndDomain(name: String, domain: String): User? - - suspend fun findByDomain(domain: String): List - - suspend fun findByNameAndDomains(names: List>): List - - suspend fun findByUrl(url: String): User? - - suspend fun findByUrls(urls: List): List - - @Deprecated("", ReplaceWith("save(userEntity)")) - suspend fun update(userEntity: User) = save(userEntity) - suspend fun delete(id: Long) - suspend fun findAll(): List - - suspend fun findAllByLimitAndByOffset(limit: Int, offset: Long = 0): List - - suspend fun createFollower(id: Long, follower: Long) - suspend fun deleteFollower(id: Long, follower: Long) - suspend fun findFollowersById(id: Long): List - - suspend fun addFollowRequest(id: Long, follower: Long) suspend fun deleteFollowRequest(id: Long, follower: Long) + suspend fun findFollowRequestsById(id: Long, follower: Long): Boolean suspend fun nextId(): Long diff --git a/src/main/kotlin/dev/usbharu/hideout/repository/UserRepository.kt b/src/main/kotlin/dev/usbharu/hideout/repository/UserRepository.kt index 9bc60ffd..0d56a973 100644 --- a/src/main/kotlin/dev/usbharu/hideout/repository/UserRepository.kt +++ b/src/main/kotlin/dev/usbharu/hideout/repository/UserRepository.kt @@ -66,15 +66,6 @@ class UserRepository(private val database: Database, private val idGenerateServi } } - override suspend fun createFollower(id: Long, follower: Long) { - return query { - UsersFollowers.insert { - it[userId] = id - it[followerId] = follower - } - } - } - override suspend fun findById(id: Long): User? { return query { Users.select { Users.id eq id }.map { @@ -83,114 +74,6 @@ class UserRepository(private val database: Database, private val idGenerateServi } } - override suspend fun findByIds(ids: List): List { - return query { - Users.select { Users.id inList ids }.map { - it.toUser() - } - } - } - - override suspend fun findByName(name: String): List { - return query { - Users.select { Users.name eq name }.map { - it.toUser() - } - } - } - - override suspend fun findByNameAndDomain(name: String, domain: String): User? { - return query { - Users.select { Users.name eq name and (Users.domain eq domain) }.singleOrNull()?.toUser() - } - } - - override suspend fun findByDomain(domain: String): List { - return query { - Users.select { Users.domain eq domain }.map { - it.toUser() - } - } - } - - override suspend fun findByNameAndDomains(names: List>): List { - return query { - val selectAll = Users.selectAll() - names.forEach { (name, domain) -> - selectAll.orWhere { Users.name eq name and (Users.domain eq domain) } - } - selectAll.map { it.toUser() } - } - } - - override suspend fun findByUrl(url: String): User? { - return query { - Users.select { Users.url eq url }.singleOrNull()?.toUser() - } - } - - override suspend fun findByUrls(urls: List): List { - return query { - Users.select { Users.url inList urls }.map { it.toUser() } - } - } - - override suspend fun findFollowersById(id: Long): List { - return query { - val followers = Users.alias("FOLLOWERS") - Users.innerJoin( - otherTable = UsersFollowers, - onColumn = { Users.id }, - otherColumn = { userId } - ) - .innerJoin( - otherTable = followers, - onColumn = { UsersFollowers.followerId }, - otherColumn = { followers[Users.id] } - ) - .slice( - followers.get(Users.id), - followers.get(Users.name), - followers.get(Users.domain), - followers.get(Users.screenName), - followers.get(Users.description), - followers.get(Users.password), - followers.get(Users.inbox), - followers.get(Users.outbox), - followers.get(Users.url), - followers.get(Users.publicKey), - followers.get(Users.privateKey), - followers.get(Users.createdAt) - ) - .select { Users.id eq id } - .map { - User( - id = it[followers[Users.id]], - name = it[followers[Users.name]], - domain = it[followers[Users.domain]], - screenName = it[followers[Users.screenName]], - description = it[followers[Users.description]], - password = it[followers[Users.password]], - inbox = it[followers[Users.inbox]], - outbox = it[followers[Users.outbox]], - url = it[followers[Users.url]], - publicKey = it[followers[Users.publicKey]], - privateKey = it[followers[Users.privateKey]], - createdAt = Instant.ofEpochMilli(it[followers[Users.createdAt]]) - ) - } - } - } - - override suspend fun addFollowRequest(id: Long, follower: Long) { - query { - FollowRequests.insert { - it[userId] = id - it[followerId] = follower - } - } - } - override suspend fun deleteFollowRequest(id: Long, follower: Long) { query { FollowRequests.deleteWhere { userId.eq(id) and followerId.eq(follower) } @@ -210,24 +93,6 @@ class UserRepository(private val database: Database, private val idGenerateServi } } - override suspend fun deleteFollower(id: Long, follower: Long) { - query { - UsersFollowers.deleteWhere { (userId eq id).and(followerId eq follower) } - } - } - - override suspend fun findAll(): List { - return query { - Users.selectAll().map { it.toUser() } - } - } - - override suspend fun findAllByLimitAndByOffset(limit: Int, offset: Long): List { - return query { - Users.selectAll().limit(limit, offset).map { it.toUser() } - } - } - override suspend fun nextId(): Long = idGenerateService.generateId() } diff --git a/src/main/kotlin/dev/usbharu/hideout/routing/api/internal/v1/Auth.kt b/src/main/kotlin/dev/usbharu/hideout/routing/api/internal/v1/Auth.kt index f185e832..bd0d280a 100644 --- a/src/main/kotlin/dev/usbharu/hideout/routing/api/internal/v1/Auth.kt +++ b/src/main/kotlin/dev/usbharu/hideout/routing/api/internal/v1/Auth.kt @@ -3,9 +3,8 @@ package dev.usbharu.hideout.routing.api.internal.v1 import dev.usbharu.hideout.config.Config import dev.usbharu.hideout.domain.model.hideout.form.RefreshToken import dev.usbharu.hideout.domain.model.hideout.form.UserLogin -import dev.usbharu.hideout.exception.UserNotFoundException import dev.usbharu.hideout.plugins.TOKEN_AUTH -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.service.auth.IJwtService import dev.usbharu.hideout.service.user.IUserAuthService import io.ktor.http.* @@ -18,8 +17,8 @@ import io.ktor.server.routing.* fun Route.auth( userAuthService: IUserAuthService, - userRepository: IUserRepository, - jwtService: IJwtService + jwtService: IJwtService, + userQueryService: UserQueryService ) { post("/login") { val loginUser = call.receive() @@ -28,8 +27,7 @@ fun Route.auth( return@post call.respond(HttpStatusCode.Unauthorized) } - val user = userRepository.findByNameAndDomain(loginUser.username, Config.configData.domain) - ?: throw UserNotFoundException("${loginUser.username} was not found.") + val user = userQueryService.findByNameAndDomain(loginUser.username, Config.configData.domain) return@post call.respond(jwtService.createToken(user)) } diff --git a/src/main/kotlin/dev/usbharu/hideout/service/auth/HttpSignatureVerifyServiceImpl.kt b/src/main/kotlin/dev/usbharu/hideout/service/auth/HttpSignatureVerifyServiceImpl.kt index 4acb9aab..d64d0fd4 100644 --- a/src/main/kotlin/dev/usbharu/hideout/service/auth/HttpSignatureVerifyServiceImpl.kt +++ b/src/main/kotlin/dev/usbharu/hideout/service/auth/HttpSignatureVerifyServiceImpl.kt @@ -1,15 +1,15 @@ package dev.usbharu.hideout.service.auth import dev.usbharu.hideout.plugins.KtorKeyMap -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import io.ktor.http.* import org.koin.core.annotation.Single import tech.barbero.http.message.signing.SignatureHeaderVerifier @Single -class HttpSignatureVerifyServiceImpl(private val userAuthService: IUserRepository) : HttpSignatureVerifyService { +class HttpSignatureVerifyServiceImpl(private val userQueryService: UserQueryService) : HttpSignatureVerifyService { override fun verify(headers: Headers): Boolean { - val build = SignatureHeaderVerifier.builder().keyMap(KtorKeyMap(userAuthService)).build() + val build = SignatureHeaderVerifier.builder().keyMap(KtorKeyMap(userQueryService)).build() return true // build.verify(object : HttpMessage { // override fun headerValues(name: String?): MutableList { diff --git a/src/main/kotlin/dev/usbharu/hideout/service/user/UserAuthService.kt b/src/main/kotlin/dev/usbharu/hideout/service/user/UserAuthService.kt index a8b6e6f2..c32249dc 100644 --- a/src/main/kotlin/dev/usbharu/hideout/service/user/UserAuthService.kt +++ b/src/main/kotlin/dev/usbharu/hideout/service/user/UserAuthService.kt @@ -1,7 +1,7 @@ package dev.usbharu.hideout.service.user import dev.usbharu.hideout.config.Config -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import io.ktor.util.* import org.koin.core.annotation.Single import java.security.* @@ -9,7 +9,7 @@ import java.util.* @Single class UserAuthService( - val userRepository: IUserRepository + val userQueryService: UserQueryService ) : IUserAuthService { override fun hash(password: String): String { @@ -18,13 +18,12 @@ class UserAuthService( } override suspend fun usernameAlreadyUse(username: String): Boolean { - userRepository.findByName(username) + userQueryService.findByName(username) return true } override suspend fun verifyAccount(username: String, password: String): Boolean { - val userEntity = userRepository.findByNameAndDomain(username, Config.configData.domain) - ?: return false + val userEntity = userQueryService.findByNameAndDomain(username, Config.configData.domain) return userEntity.password == hash(password) } diff --git a/src/main/kotlin/dev/usbharu/hideout/service/user/UserService.kt b/src/main/kotlin/dev/usbharu/hideout/service/user/UserService.kt index b7ff0e3a..89876aaf 100644 --- a/src/main/kotlin/dev/usbharu/hideout/service/user/UserService.kt +++ b/src/main/kotlin/dev/usbharu/hideout/service/user/UserService.kt @@ -6,6 +6,8 @@ import dev.usbharu.hideout.domain.model.hideout.dto.SendFollowDto import dev.usbharu.hideout.domain.model.hideout.dto.UserCreateDto import dev.usbharu.hideout.domain.model.hideout.entity.User import dev.usbharu.hideout.exception.UserNotFoundException +import dev.usbharu.hideout.query.FollowerQueryService +import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.repository.IUserRepository import dev.usbharu.hideout.service.activitypub.ActivityPubSendFollowService import org.koin.core.annotation.Single @@ -15,12 +17,14 @@ import java.time.Instant class UserService( private val userRepository: IUserRepository, private val userAuthService: IUserAuthService, - private val activityPubSendFollowService: ActivityPubSendFollowService + private val activityPubSendFollowService: ActivityPubSendFollowService, + private val userQueryService: UserQueryService, + private val followerQueryService: FollowerQueryService ) : IUserService { override suspend fun usernameAlreadyUse(username: String): Boolean { - val findByNameAndDomain = userRepository.findByNameAndDomain(username, Config.configData.domain) + val findByNameAndDomain = userQueryService.findByNameAndDomain(username, Config.configData.domain) return findByNameAndDomain != null } @@ -80,14 +84,14 @@ class UserService( } override suspend fun follow(id: Long, followerId: Long) { - userRepository.createFollower(id, followerId) + followerQueryService.appendFollower(id, followerId) if (userRepository.findFollowRequestsById(id, followerId)) { userRepository.deleteFollowRequest(id, followerId) } } override suspend fun unfollow(id: Long, followerId: Long): Boolean { - userRepository.deleteFollower(id, followerId) + followerQueryService.removeFollower(id, followerId) return false } } diff --git a/src/test/kotlin/dev/usbharu/hideout/plugins/ActivityPubKtTest.kt b/src/test/kotlin/dev/usbharu/hideout/plugins/ActivityPubKtTest.kt index fc830bf2..f0d77035 100644 --- a/src/test/kotlin/dev/usbharu/hideout/plugins/ActivityPubKtTest.kt +++ b/src/test/kotlin/dev/usbharu/hideout/plugins/ActivityPubKtTest.kt @@ -2,41 +2,28 @@ package dev.usbharu.hideout.plugins import dev.usbharu.hideout.domain.model.ap.JsonLd import dev.usbharu.hideout.domain.model.hideout.entity.User -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.service.user.toPem import io.ktor.client.* import io.ktor.client.engine.mock.* import io.ktor.client.plugins.logging.* import kotlinx.coroutines.runBlocking import org.junit.jupiter.api.Test +import org.mockito.kotlin.any +import org.mockito.kotlin.doAnswer +import org.mockito.kotlin.mock import java.security.KeyPairGenerator import java.time.Instant class ActivityPubKtTest { @Test - fun HttpSignTest(): Unit = runBlocking { - val ktorKeyMap = KtorKeyMap(object : IUserRepository { - override suspend fun save(user: User): User { - TODO("Not yet implemented") - } - - override suspend fun findById(id: Long): User? { - TODO("Not yet implemented") - } - - override suspend fun findByIds(ids: List): List { - TODO("Not yet implemented") - } - - override suspend fun findByName(name: String): List { - TODO() - } - - override suspend fun findByNameAndDomain(name: String, domain: String): User { + fun HttpSignTest() { + val userQueryService = mock { + onBlocking { findByNameAndDomain(any(), any()) } doAnswer { val keyPairGenerator = KeyPairGenerator.getInstance("RSA") keyPairGenerator.initialize(1024) val generateKeyPair = keyPairGenerator.generateKeyPair() - return User( + User( 1, "test", "localhost", @@ -51,78 +38,25 @@ class ActivityPubKtTest { Instant.now() ) } - - override suspend fun findByDomain(domain: String): List { - TODO("Not yet implemented") - } - - override suspend fun findByNameAndDomains(names: List>): List { - TODO("Not yet implemented") - } - - override suspend fun findByUrl(url: String): User? { - TODO("Not yet implemented") - } - - override suspend fun findByUrls(urls: List): List { - TODO("Not yet implemented") - } - - override suspend fun delete(id: Long) { - TODO("Not yet implemented") - } - - override suspend fun findAll(): List { - TODO("Not yet implemented") - } - - override suspend fun findAllByLimitAndByOffset(limit: Int, offset: Long): List { - TODO("Not yet implemented") - } - - override suspend fun createFollower(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun deleteFollower(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun findFollowersById(id: Long): List { - TODO("Not yet implemented") - } - - override suspend fun addFollowRequest(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun deleteFollowRequest(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun findFollowRequestsById(id: Long, follower: Long): Boolean { - TODO("Not yet implemented") - } - - override suspend fun nextId(): Long { - TODO("Not yet implemented") - } - }) - - val httpClient = HttpClient( - MockEngine { httpRequestData -> - respondOk() - } - ) { - install(httpSignaturePlugin) { - keyMap = ktorKeyMap - } - install(Logging) { - logger = Logger.DEFAULT - level = LogLevel.ALL - } } + runBlocking { + val ktorKeyMap = KtorKeyMap(userQueryService) - httpClient.postAp("https://localhost", "test", JsonLd(emptyList())) + val httpClient = HttpClient( + MockEngine { httpRequestData -> + respondOk() + } + ) { + install(httpSignaturePlugin) { + keyMap = ktorKeyMap + } + install(Logging) { + logger = Logger.DEFAULT + level = LogLevel.ALL + } + } + + httpClient.postAp("https://localhost", "test", JsonLd(emptyList())) + } } } diff --git a/src/test/kotlin/dev/usbharu/hideout/plugins/KtorKeyMapTest.kt b/src/test/kotlin/dev/usbharu/hideout/plugins/KtorKeyMapTest.kt index 70343bc4..d736b04d 100644 --- a/src/test/kotlin/dev/usbharu/hideout/plugins/KtorKeyMapTest.kt +++ b/src/test/kotlin/dev/usbharu/hideout/plugins/KtorKeyMapTest.kt @@ -1,9 +1,12 @@ package dev.usbharu.hideout.plugins import dev.usbharu.hideout.domain.model.hideout.entity.User -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.service.user.toPem import org.junit.jupiter.api.Test +import org.mockito.kotlin.any +import org.mockito.kotlin.doAnswer +import org.mockito.kotlin.mock import java.security.KeyPairGenerator import java.time.Instant @@ -11,28 +14,12 @@ class KtorKeyMapTest { @Test fun getPrivateKey() { - val ktorKeyMap = KtorKeyMap(object : IUserRepository { - override suspend fun save(user: User): User { - TODO("Not yet implemented") - } - - override suspend fun findById(id: Long): User? { - TODO("Not yet implemented") - } - - override suspend fun findByIds(ids: List): List { - TODO("Not yet implemented") - } - - override suspend fun findByName(name: String): List { - TODO() - } - - override suspend fun findByNameAndDomain(name: String, domain: String): User { + val userQueryService = mock { + onBlocking { findByNameAndDomain(any(), any()) } doAnswer { val keyPairGenerator = KeyPairGenerator.getInstance("RSA") keyPairGenerator.initialize(1024) val generateKeyPair = keyPairGenerator.generateKeyPair() - return User( + User( 1, "test", "localhost", @@ -47,63 +34,8 @@ class KtorKeyMapTest { createdAt = Instant.now() ) } - - override suspend fun findByDomain(domain: String): List { - TODO("Not yet implemented") - } - - override suspend fun findByNameAndDomains(names: List>): List { - TODO("Not yet implemented") - } - - override suspend fun findByUrl(url: String): User? { - TODO("Not yet implemented") - } - - override suspend fun findByUrls(urls: List): List { - TODO("Not yet implemented") - } - - override suspend fun delete(id: Long) { - TODO("Not yet implemented") - } - - override suspend fun findAll(): List { - TODO("Not yet implemented") - } - - override suspend fun findAllByLimitAndByOffset(limit: Int, offset: Long): List { - TODO("Not yet implemented") - } - - override suspend fun createFollower(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun deleteFollower(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun findFollowersById(id: Long): List { - TODO("Not yet implemented") - } - - override suspend fun addFollowRequest(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun deleteFollowRequest(id: Long, follower: Long) { - TODO("Not yet implemented") - } - - override suspend fun findFollowRequestsById(id: Long, follower: Long): Boolean { - TODO("Not yet implemented") - } - - override suspend fun nextId(): Long { - TODO("Not yet implemented") - } - }) + } + val ktorKeyMap = KtorKeyMap(userQueryService) ktorKeyMap.getPrivateKey("test") } diff --git a/src/test/kotlin/dev/usbharu/hideout/plugins/SecurityKtTest.kt b/src/test/kotlin/dev/usbharu/hideout/plugins/SecurityKtTest.kt index 8c1f4d13..32cbe523 100644 --- a/src/test/kotlin/dev/usbharu/hideout/plugins/SecurityKtTest.kt +++ b/src/test/kotlin/dev/usbharu/hideout/plugins/SecurityKtTest.kt @@ -14,7 +14,7 @@ import dev.usbharu.hideout.domain.model.hideout.entity.User import dev.usbharu.hideout.domain.model.hideout.form.RefreshToken import dev.usbharu.hideout.domain.model.hideout.form.UserLogin import dev.usbharu.hideout.exception.InvalidRefreshTokenException -import dev.usbharu.hideout.repository.IUserRepository +import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.routing.api.internal.v1.auth import dev.usbharu.hideout.service.auth.IJwtService import dev.usbharu.hideout.service.core.IMetaService @@ -49,7 +49,7 @@ class SecurityKtTest { onBlocking { verifyAccount(eq("testUser"), eq("password")) } doReturn true } val metaService = mock() - val userRepository = mock { + val userQueryService = mock { onBlocking { findByNameAndDomain(eq("testUser"), eq("example.com")) } doReturn User( id = 1L, name = "testUser", @@ -74,7 +74,7 @@ class SecurityKtTest { configureSerialization() configureSecurity(jwkProvider, metaService) routing { - auth(userAuthService, userRepository, jwtService) + auth(userAuthService, jwtService, userQueryService) } } @@ -97,14 +97,14 @@ class SecurityKtTest { onBlocking { verifyAccount(anyString(), anyString()) }.doReturn(false) } val metaService = mock() - val userRepository = mock() + val userQueryService = mock() val jwtService = mock() val jwkProvider = mock() application { configureSerialization() configureSecurity(jwkProvider, metaService) routing { - auth(userAuthService, userRepository, jwtService) + auth(userAuthService, jwtService, userQueryService) } } client.post("/login") { @@ -125,14 +125,14 @@ class SecurityKtTest { onBlocking { verifyAccount(anyString(), eq("InvalidPassword")) } doReturn false } val metaService = mock() - val userRepository = mock() + val userQueryService = mock() val jwtService = mock() val jwkProvider = mock() application { configureSerialization() configureSecurity(jwkProvider, metaService) routing { - auth(userAuthService, userRepository, jwtService) + auth(userAuthService, jwtService, userQueryService) } } client.post("/login") { @@ -531,7 +531,7 @@ class SecurityKtTest { configureSerialization() configureSecurity(mock(), mock()) routing { - auth(mock(), mock(), jwtService) + auth(mock(), jwtService, mock()) } } client.post("/refresh-token") { @@ -556,7 +556,7 @@ class SecurityKtTest { configureSerialization() configureSecurity(mock(), mock()) routing { - auth(mock(), mock(), jwtService) + auth(mock(), jwtService, mock()) } } client.post("/refresh-token") { diff --git a/src/test/kotlin/dev/usbharu/hideout/repository/UserRepositoryTest.kt b/src/test/kotlin/dev/usbharu/hideout/repository/UserRepositoryTest.kt deleted file mode 100644 index 244ff004..00000000 --- a/src/test/kotlin/dev/usbharu/hideout/repository/UserRepositoryTest.kt +++ /dev/null @@ -1,151 +0,0 @@ -@file:OptIn(ExperimentalCoroutinesApi::class) - -package dev.usbharu.hideout.repository - -import dev.usbharu.hideout.domain.model.hideout.entity.User -import dev.usbharu.hideout.service.core.IdGenerateService -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import org.jetbrains.exposed.sql.Database -import org.jetbrains.exposed.sql.SchemaUtils -import org.jetbrains.exposed.sql.select -import org.jetbrains.exposed.sql.transactions.transaction -import org.junit.jupiter.api.AfterEach -import org.junit.jupiter.api.Assertions.assertIterableEquals -import org.junit.jupiter.api.BeforeEach -import org.junit.jupiter.api.Test -import java.time.Clock -import java.time.Instant -import java.time.ZoneId - -class UserRepositoryTest { - - lateinit var db: Database - - @BeforeEach - fun beforeEach() { - db = Database.connect("jdbc:h2:mem:test;DB_CLOSE_DELAY=-1", driver = "org.h2.Driver") - transaction(db) { - SchemaUtils.create(Users) - SchemaUtils.create(UsersFollowers) - SchemaUtils.create(FollowRequests) - } - } - - @AfterEach - fun tearDown() { - transaction(db) { - SchemaUtils.drop(UsersFollowers) - SchemaUtils.drop(FollowRequests) - SchemaUtils.drop(Users) - } - } - - @Test - fun `findFollowersById フォロワー一覧を取得`() = runTest { - val userRepository = UserRepository( - db, - object : IdGenerateService { - override suspend fun generateId(): Long { - TODO("Not yet implemented") - } - } - ) - val user = userRepository.save( - User( - id = 0L, - name = "test", - domain = "example.com", - screenName = "testUser", - description = "This user is test user.", - password = "https://example.com/inbox", - inbox = "", - outbox = "https://example.com/outbox", - url = "https://example.com", - publicKey = "", - createdAt = Instant.now(Clock.tickMillis(ZoneId.systemDefault())) - ) - ) - val follower = userRepository.save( - User( - id = 1L, - name = "follower", - domain = "follower.example.com", - screenName = "followerUser", - description = "This user is follower user.", - password = "", - inbox = "https://follower.example.com/inbox", - outbox = "https://follower.example.com/outbox", - url = "https://follower.example.com", - publicKey = "", - createdAt = Instant.now(Clock.tickMillis(ZoneId.systemDefault())) - ) - ) - val follower2 = userRepository.save( - User( - id = 3L, - name = "follower2", - domain = "follower2.example.com", - screenName = "followerUser2", - description = "This user is follower user 2.", - password = "", - inbox = "https://follower2.example.com/inbox", - outbox = "https://follower2.example.com/outbox", - url = "https://follower2.example.com", - publicKey = "", - createdAt = Instant.now(Clock.tickMillis(ZoneId.systemDefault())) - ) - ) - userRepository.createFollower(user.id, follower.id) - userRepository.createFollower(user.id, follower2.id) - assertIterableEquals(listOf(follower, follower2), userRepository.findFollowersById(user.id)) - } - - @Test - fun `createFollower フォロワー追加`() = runTest { - val userRepository = UserRepository( - db, - object : IdGenerateService { - override suspend fun generateId(): Long { - TODO("Not yet implemented") - } - } - ) - val user = userRepository.save( - User( - 0L, - "test", - "example.com", - "testUser", - "This user is test user.", - "https://example.com/inbox", - "", - "https://example.com/outbox", - "https://example.com", - publicKey = "", - createdAt = Instant.now() - ) - ) - val follower = userRepository.save( - User( - 1L, - "follower", - "follower.example.com", - "followerUser", - "This user is follower user.", - "", - "https://follower.example.com/inbox", - "https://follower.example.com/outbox", - "https://follower.example.com", - publicKey = "", - createdAt = Instant.now() - ) - ) - userRepository.createFollower(user.id, follower.id) - transaction { - val followerIds = - UsersFollowers.select { UsersFollowers.userId eq user.id }.map { it[UsersFollowers.followerId] } - assertIterableEquals(listOf(follower.id), followerIds) - } - } -} diff --git a/src/test/kotlin/dev/usbharu/hideout/service/user/UserServiceTest.kt b/src/test/kotlin/dev/usbharu/hideout/service/user/UserServiceTest.kt index 4fcdedb3..4aed672e 100644 --- a/src/test/kotlin/dev/usbharu/hideout/service/user/UserServiceTest.kt +++ b/src/test/kotlin/dev/usbharu/hideout/service/user/UserServiceTest.kt @@ -28,7 +28,7 @@ class UserServiceTest { onBlocking { hash(anyString()) } doReturn "hashedPassword" onBlocking { generateKeyPair() } doReturn generateKeyPair } - val userService = UserService(userRepository, userAuthService, mock()) + val userService = UserService(userRepository, userAuthService, mock(), mock(), mock()) userService.createLocalUser(UserCreateDto("test", "testUser", "XXXXXXXXXXXXX", "test")) verify(userRepository, times(1)).save(any()) argumentCaptor { @@ -54,7 +54,7 @@ class UserServiceTest { val userRepository = mock { onBlocking { nextId() } doReturn 113345L } - val userService = UserService(userRepository, mock(), mock()) + val userService = UserService(userRepository, mock(), mock(), mock(), mock()) val user = RemoteUserCreateDto( "test", "example.com",