Skip to content

Commit

Permalink
selectBySlug test implemented
Browse files Browse the repository at this point in the history
  • Loading branch information
arioston committed Jan 7, 2024
1 parent c9d41c4 commit 8ea92db
Showing 1 changed file with 66 additions and 2 deletions.
68 changes: 66 additions & 2 deletions src/test/kotlin/io/github/nomisrev/routes/ArticlesRouteSpec.kt
Original file line number Diff line number Diff line change
Expand Up @@ -3,29 +3,61 @@ package io.github.nomisrev.routes
import arrow.core.flatMap
import io.github.nefilim.kjwt.JWSHMAC512Algorithm
import io.github.nefilim.kjwt.JWT
import io.github.nomisrev.KotestProject
import io.github.nomisrev.auth.JwtToken
import io.github.nomisrev.repo.UserId
import io.github.nomisrev.service.CreateArticle
import io.github.nomisrev.service.Login
import io.github.nomisrev.service.RegisterUser
import io.github.nomisrev.withServer
import io.kotest.assertions.arrow.core.shouldBeRight
import io.kotest.assertions.arrow.core.shouldBeSome
import io.kotest.core.spec.style.StringSpec
import io.ktor.client.call.body
import io.ktor.client.plugins.resources.get
import io.ktor.client.request.bearerAuth
import io.ktor.http.HttpStatusCode
import kotlin.properties.Delegates

class ArticlesRouteSpec :
StringSpec({
// User
val validUsername = "username2"
val validEmail = "[email protected]"
val validPw = "123456789"
// User 3
val validUsername3 = "username3"
val validEmail3 = "[email protected]"
val validPw3 = "123456789"

// Article
val validTags = setOf("arrow", "kotlin", "ktor", "sqldelight")
val validTitle = "Fake Article Arrow "
val validDescription = "This is a fake article description."
val validBody = "Lorem ipsum dolor sit amet, consectetur adipiscing elit."

var token: JwtToken by Delegates.notNull()
var userId: UserId by Delegates.notNull()

beforeAny {
KotestProject.dependencies
.get()
.userService
.register(RegisterUser(validUsername3, validEmail3, validPw3))
.shouldBeRight()
}

beforeTest {
token =
KotestProject.dependencies
.get()
.userService
.login(Login(validEmail3, validPw3))
.shouldBeRight()
.first
userId = KotestProject.dependencies.get().jwtService.verifyJwtToken(token).shouldBeRight()
}

"Article by slug not found" {
withServer {
val response = get(ArticlesResource.Slug(slug = "slug"))
Expand All @@ -39,7 +71,7 @@ class ArticlesRouteSpec :

"Can get an article by slug" {
withServer { dependencies ->
val userId =
val user1Id =
dependencies.userService
.register(RegisterUser(validUsername, validEmail, validPw))
.flatMap { JWT.decodeT(it.value, JWSHMAC512Algorithm) }
Expand All @@ -49,7 +81,7 @@ class ArticlesRouteSpec :
val article =
dependencies.articleService
.createArticle(
CreateArticle(UserId(userId), validTitle, validDescription, validBody, validTags)
CreateArticle(UserId(user1Id), validTitle, validDescription, validBody, validTags)
)
.shouldBeRight()

Expand All @@ -59,4 +91,36 @@ class ArticlesRouteSpec :
assert(response.body<SingleArticleResponse>().article == article)
}
}

"can get comments for an article by slug when authenticated" {
withServer { dependencies ->
val article =
dependencies.articleService
.createArticle(
CreateArticle(userId, validTitle, validDescription, validBody, validTags)
)
.shouldBeRight()

val response =
get(ArticlesResource.Comments(slug = article.slug)) { bearerAuth(token.value) }

assert(response.status == HttpStatusCode.OK)
assert(response.body<MultipleCommentsResponse>().comments == emptyList<Comment>())
}
}

"can not get comments for an article when not authenticated" {
withServer { dependencies ->
val article =
dependencies.articleService
.createArticle(
CreateArticle(userId, validTitle, validDescription, validBody, validTags)
)
.shouldBeRight()

val response = get(ArticlesResource.Comments(slug = article.slug))

assert(response.status == HttpStatusCode.Unauthorized)
}
}
})

0 comments on commit 8ea92db

Please sign in to comment.