From a0c7515a92233357f805ab8648a326b2d03f94c2 Mon Sep 17 00:00:00 2001 From: Seokjin Jeon Date: Wed, 3 Jan 2024 20:12:00 +0900 Subject: [PATCH] =?UTF-8?q?feat:=20MockWebServer=20=EC=9D=BC=EB=B6=80=20?= =?UTF-8?q?=ED=85=8C=EC=8A=A4=ED=8A=B8=20=EC=BD=94=EB=93=9C=20=EA=B0=9C?= =?UTF-8?q?=EC=84=A0=20(#69)=20(#70)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../sc/auth/infra/DiscordOAuth2ClientTest.kt | 8 ++++++-- .../sc/common/support/MockWebServerDsl.kt | 15 ++++++++------- .../infra/DeepLTranslatorClientTest.kt | 6 +++++- 3 files changed, 19 insertions(+), 10 deletions(-) diff --git a/src/test/kotlin/kr/galaxyhub/sc/auth/infra/DiscordOAuth2ClientTest.kt b/src/test/kotlin/kr/galaxyhub/sc/auth/infra/DiscordOAuth2ClientTest.kt index d319cf1..6f8086f 100644 --- a/src/test/kotlin/kr/galaxyhub/sc/auth/infra/DiscordOAuth2ClientTest.kt +++ b/src/test/kotlin/kr/galaxyhub/sc/auth/infra/DiscordOAuth2ClientTest.kt @@ -28,6 +28,10 @@ class DiscordOAuth2ClientTest : DescribeSpec({ timeoutDuration = Duration.ofSeconds(10) ) + afterEach { + mockWebServer.shutdown() + } + describe("getAccessToken") { val response = DiscordAccessTokenResponse( accessToken = "123123", @@ -100,7 +104,7 @@ class DiscordOAuth2ClientTest : DescribeSpec({ mockWebServer.enqueue { statusCode(200) body(response) - delay(10, TimeUnit.SECONDS) + delay(200, TimeUnit.MILLISECONDS) } it("InternalServerError 예외를 던진다.") { @@ -176,7 +180,7 @@ class DiscordOAuth2ClientTest : DescribeSpec({ mockWebServer.enqueue { statusCode(200) body(response) - delay(10, TimeUnit.SECONDS) + delay(200, TimeUnit.MILLISECONDS) } it("InternalServerError 예외를 던진다.") { diff --git a/src/test/kotlin/kr/galaxyhub/sc/common/support/MockWebServerDsl.kt b/src/test/kotlin/kr/galaxyhub/sc/common/support/MockWebServerDsl.kt index 064dd43..2ec9aee 100644 --- a/src/test/kotlin/kr/galaxyhub/sc/common/support/MockWebServerDsl.kt +++ b/src/test/kotlin/kr/galaxyhub/sc/common/support/MockWebServerDsl.kt @@ -11,7 +11,7 @@ class MockWebServerDsl { private var statusCode: Int? = null private var body: String? = null - private var mediaType: String? = null + private var mediaType: MediaType? = null private var delay: Long? = null private var timeUnit: TimeUnit? = null @@ -24,7 +24,7 @@ class MockWebServerDsl { } fun mediaType(mediaType: MediaType) { - this.mediaType = mediaType.toString() + this.mediaType = mediaType } fun delay(delay: Long, timeUnit: TimeUnit) { @@ -35,12 +35,13 @@ class MockWebServerDsl { internal fun perform(mockWebServer: MockWebServer) { val response = MockResponse() statusCode?.also { response.setResponseCode(it) } - body?.also { response.setBody(it) } + body?.also { + response.setBody(it) + response.setHeader(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON) + } delay?.also { response.setBodyDelay(it, timeUnit!!) } - if (mediaType != null) { - response.addHeader(HttpHeaders.CONTENT_TYPE, mediaType!!) - } else { - response.addHeader(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON) + mediaType?.also { + response.setHeader(HttpHeaders.CONTENT_TYPE, it) } mockWebServer.enqueue(response) } diff --git a/src/test/kotlin/kr/galaxyhub/sc/translation/infra/DeepLTranslatorClientTest.kt b/src/test/kotlin/kr/galaxyhub/sc/translation/infra/DeepLTranslatorClientTest.kt index c39d5e1..a388999 100644 --- a/src/test/kotlin/kr/galaxyhub/sc/translation/infra/DeepLTranslatorClientTest.kt +++ b/src/test/kotlin/kr/galaxyhub/sc/translation/infra/DeepLTranslatorClientTest.kt @@ -29,6 +29,10 @@ class DeepLTranslatorClientTest : DescribeSpec({ timeoutDuration = Duration.ofSeconds(10) ) + afterEach { + mockWebServer.shutdown() + } + describe("requestTranslate") { val response = DeepLResponse( listOf( @@ -124,7 +128,7 @@ class DeepLTranslatorClientTest : DescribeSpec({ mockWebServer.enqueue { statusCode(200) body(response) - delay(1, TimeUnit.SECONDS) + delay(200, TimeUnit.MILLISECONDS) } val expect = delayClient.requestTranslate(ContentFixture.create(), Language.KOREAN)