From c9fb036798fc533a07b4b75386b51151b31f8be0 Mon Sep 17 00:00:00 2001 From: Torsten Grote Date: Mon, 20 Jul 2020 16:37:46 -0300 Subject: [pos] create merchant-lib and move first v1 API endpoint there --- .../java/net/taler/merchantlib/MerchantApiTest.kt | 43 ++++++++++++++++ .../java/net/taler/merchantlib/MockHttpClient.kt | 58 ++++++++++++++++++++++ 2 files changed, 101 insertions(+) create mode 100644 merchant-lib/src/test/java/net/taler/merchantlib/MerchantApiTest.kt create mode 100644 merchant-lib/src/test/java/net/taler/merchantlib/MockHttpClient.kt (limited to 'merchant-lib/src/test/java/net/taler') diff --git a/merchant-lib/src/test/java/net/taler/merchantlib/MerchantApiTest.kt b/merchant-lib/src/test/java/net/taler/merchantlib/MerchantApiTest.kt new file mode 100644 index 0000000..6b2199b --- /dev/null +++ b/merchant-lib/src/test/java/net/taler/merchantlib/MerchantApiTest.kt @@ -0,0 +1,43 @@ +/* + * This file is part of GNU Taler + * (C) 2020 Taler Systems S.A. + * + * GNU Taler is free software; you can redistribute it and/or modify it under the + * terms of the GNU General Public License as published by the Free Software + * Foundation; either version 3, or (at your option) any later version. + * + * GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY + * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR + * A PARTICULAR PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along with + * GNU Taler; see the file COPYING. If not, see + */ + +package net.taler.merchantlib + +import kotlinx.coroutines.runBlocking +import net.taler.merchantlib.MockHttpClient.giveJsonResponse +import net.taler.merchantlib.MockHttpClient.httpClient +import org.junit.Assert.assertEquals +import org.junit.Test + +class MerchantApiTest { + + private val api = MerchantApi(httpClient) + + @Test + fun testGetConfig() = runBlocking { + httpClient.giveJsonResponse("https://backend.int.taler.net/config") { + """ + { + "currency": "INTKUDOS", + "version": "0:0:0" + } + """.trimIndent() + } + val response = api.getConfig("https://backend.int.taler.net") + assertEquals(ConfigResponse("0:0:0", "INTKUDOS"), response) + } + +} diff --git a/merchant-lib/src/test/java/net/taler/merchantlib/MockHttpClient.kt b/merchant-lib/src/test/java/net/taler/merchantlib/MockHttpClient.kt new file mode 100644 index 0000000..076b77e --- /dev/null +++ b/merchant-lib/src/test/java/net/taler/merchantlib/MockHttpClient.kt @@ -0,0 +1,58 @@ +/* + * This file is part of GNU Taler + * (C) 2020 Taler Systems S.A. + * + * GNU Taler is free software; you can redistribute it and/or modify it under the + * terms of the GNU General Public License as published by the Free Software + * Foundation; either version 3, or (at your option) any later version. + * + * GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY + * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR + * A PARTICULAR PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along with + * GNU Taler; see the file COPYING. If not, see + */ + +package net.taler.merchantlib + +import io.ktor.client.HttpClient +import io.ktor.client.engine.mock.MockEngine +import io.ktor.client.engine.mock.MockEngineConfig +import io.ktor.client.engine.mock.respond +import io.ktor.client.features.json.JsonFeature +import io.ktor.client.features.json.serializer.KotlinxSerializer +import io.ktor.http.ContentType.Application.Json +import io.ktor.http.Url +import io.ktor.http.fullPath +import io.ktor.http.headersOf +import io.ktor.http.hostWithPort + +object MockHttpClient { + + val httpClient = HttpClient(MockEngine) { + install(JsonFeature) { + serializer = KotlinxSerializer() + } + engine { + addHandler { error("No response handler set") } + } + } + + fun HttpClient.giveJsonResponse(url: String, jsonProducer: () -> String) { + val httpConfig = engineConfig as MockEngineConfig + httpConfig.requestHandlers.removeAt(0) + httpConfig.requestHandlers.add { request -> + if (request.url.fullUrl == url) { + val headers = headersOf("Content-Type" to listOf(Json.toString())) + respond(jsonProducer(), headers = headers) + } else { + error("Unexpected URL: ${request.url.fullUrl}") + } + } + } + + private val Url.hostWithPortIfRequired: String get() = if (port == protocol.defaultPort) host else hostWithPort + private val Url.fullUrl: String get() = "${protocol.name}://$hostWithPortIfRequired$fullPath" + +} -- cgit v1.2.3