Skip to content

Commit

Permalink
add an API interface to add/remove favorite tools
Browse files Browse the repository at this point in the history
  • Loading branch information
frett committed Sep 29, 2023
1 parent d236f53 commit b2c56c4
Show file tree
Hide file tree
Showing 5 changed files with 92 additions and 1 deletion.
5 changes: 4 additions & 1 deletion gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,7 @@ hilt-compiler = { module = "com.google.dagger:hilt-compiler", version.ref = "dag
hilt-testing = { module = "com.google.dagger:hilt-android-testing", version.ref = "dagger" }
javapoet = "com.squareup:javapoet:1.13.0"
json = "org.json:json:20230618"
jsonUnit-assertj = "net.javacrumbs.json-unit:json-unit-assertj:3.2.2"
jsoup = "org.jsoup:jsoup:1.16.1"
junit = "junit:junit:4.13.2"
kotlin-coroutines = { module = "org.jetbrains.kotlinx:kotlinx-coroutines-core", version.ref = "kotlinCoroutines" }
Expand All @@ -167,13 +168,15 @@ kotlin-coroutines-test = { module = "org.jetbrains.kotlinx:kotlinx-coroutines-te
kotlin-gradlePlugin = { module = "org.jetbrains.kotlin:kotlin-gradle-plugin", version.ref = "kotlin" }
kotlin-kover-gradlePlugin = { module = "org.jetbrains.kotlinx:kover-gradle-plugin", version.ref = "kotlinKover" }
kotlin-stdlib = { module = "org.jetbrains.kotlin:kotlin-stdlib", version.ref = "kotlin" }
kotlin-test = { module = "org.jetbrains.kotlin:kotlin-test", version.ref = "kotlin" }
ktlint-gradle = { module = "org.jlleitschuh.gradle:ktlint-gradle", version.ref = "ktlintGradle" }
leakcanary = "com.squareup.leakcanary:leakcanary-android:2.12"
lottie = { module = "com.airbnb.android:lottie", version.ref = "lottie" }
lottie-compose = { module = "com.airbnb.android:lottie-compose", version.ref = "lottie" }
materialComponents = "com.google.android.material:material:1.9.0"
mockk = "io.mockk:mockk:1.13.8"
okhttp3 = { module = "com.squareup.okhttp3:okhttp", version.ref = "okhttp3" }
okhttp3-mockwebserver = { module = "com.squareup.okhttp3:mockwebserver", version.ref = "okhttp3" }
onesky-gradlePlugin = "co.brainly:plugin:1.6.0"
picasso = "com.squareup.picasso:picasso:2.8"
picasso-transformations = "jp.wasabeef:picasso-transformations:2.4.0"
Expand Down Expand Up @@ -211,7 +214,7 @@ androidx-compose = ["androidx-compose-runtime", "androidx-compose-ui", "androidx
androidx-compose-debug = ["androidx-compose-ui-test-manifest", "androidx-compose-ui-tooling"]
androidx-compose-testing = ["androidx-compose-ui-test"]
common = ["kotlin-stdlib", "timber"]
test-framework = ["junit", "androidx-test-junit", "mockk", "robolectric"]
test-framework = ["junit", "kotlin-test", "androidx-test-junit", "mockk", "robolectric"]

[plugins]
firebase-appdistribution = { id = "com.google.firebase.appdistribution", version = "4.0.0" }
Expand Down
3 changes: 3 additions & 0 deletions library/api/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,7 @@ dependencies {
kapt(libs.hilt.compiler)

testImplementation(libs.json)
testImplementation(libs.jsonUnit.assertj)
testImplementation(libs.kotlin.coroutines.test)
testImplementation(libs.okhttp3.mockwebserver)
}
6 changes: 6 additions & 0 deletions library/api/src/main/kotlin/org/cru/godtools/api/ApiModule.kt
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,12 @@ object ApiModule {
@Named(MOBILE_CONTENT_API_AUTHENTICATED) retrofit: Retrofit,
): UserCountersApi = retrofit.create()

@Provides
@Reusable
fun userFavoriteToolsApi(
@Named(MOBILE_CONTENT_API_AUTHENTICATED) retrofit: Retrofit,
): UserFavoriteToolsApi = retrofit.create()

@Provides
@Reusable
fun viewsApi(@Named(MOBILE_CONTENT_API) retrofit: Retrofit): ViewsApi = retrofit.create()
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
package org.cru.godtools.api

import org.ccci.gto.android.common.jsonapi.model.JsonApiObject
import org.ccci.gto.android.common.jsonapi.retrofit2.JsonApiParams
import org.ccci.gto.android.common.jsonapi.retrofit2.annotation.JsonApiFields
import org.cru.godtools.model.Tool
import retrofit2.Response
import retrofit2.http.Body
import retrofit2.http.HTTP
import retrofit2.http.POST
import retrofit2.http.QueryMap

interface UserFavoriteToolsApi {
companion object {
internal const val PATH_FAVORITE_TOOLS = "$PATH_USER/relationships/favorite-tools"
}

@POST(PATH_FAVORITE_TOOLS)
suspend fun addFavoriteTools(
@QueryMap params: JsonApiParams = JsonApiParams(),
@Body
@JsonApiFields(Tool.JSONAPI_TYPE)
tools: List<Tool>,
): Response<JsonApiObject<Tool>>

@HTTP(method = "DELETE", path = PATH_FAVORITE_TOOLS, hasBody = true)
suspend fun removeFavoriteTools(
@QueryMap params: JsonApiParams = JsonApiParams(),
@Body
@JsonApiFields(Tool.JSONAPI_TYPE)
tools: List<Tool>,
): Response<JsonApiObject<Tool>>
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
package org.cru.godtools.api

import kotlin.test.Test
import kotlin.test.assertEquals
import kotlin.test.assertNotNull
import kotlinx.coroutines.test.runTest
import net.javacrumbs.jsonunit.assertj.assertThatJson
import okhttp3.mockwebserver.MockResponse
import okhttp3.mockwebserver.MockWebServer
import org.ccci.gto.android.common.jsonapi.retrofit2.JsonApiConverterFactory
import org.cru.godtools.api.UserFavoriteToolsApi.Companion.PATH_FAVORITE_TOOLS
import org.cru.godtools.model.Tool
import org.junit.Rule
import retrofit2.Retrofit

private const val JSON_RESPONSE_FAVORITES = "{data:[{id:5,type:\"resource\"}]}"

class UserFavoriteToolsApiTest {
@get:Rule
val server = MockWebServer()

private var api = Retrofit.Builder()
.baseUrl(server.url("/"))
.addConverterFactory(JsonApiConverterFactory(Tool::class.java))
.build()
.create(UserFavoriteToolsApi::class.java)

@Test
fun `removeFavoriteTools()`() = runTest {
server.enqueue(MockResponse().setBody(JSON_RESPONSE_FAVORITES))

val resp = api.removeFavoriteTools(tools = listOf(Tool("en") { id = 1 })).body()!!.data.single()
assertNotNull(resp) { assertEquals(5, it.id) }

val request = server.takeRequest()
assertEquals("DELETE", request.method)
assertEquals("/$PATH_FAVORITE_TOOLS", request.path)
assertThatJson(request.body.readUtf8()) {
isObject
node("data").isArray.hasSize(1)
node("data[0].id").isEqualTo(1)
node("data[0].attributes").isAbsent()
node("data[0].relationships").isAbsent()
}
}
}

0 comments on commit b2c56c4

Please sign in to comment.