From 0ca82debb6756c2510cebe8ecff9fd506541e154 Mon Sep 17 00:00:00 2001 From: Aleksei Shashev Date: Mon, 6 May 2024 22:26:23 +0300 Subject: [PATCH] Keep original request body as Array[Byte] --- .../ru/tinkoff/tcb/mockingbird/api/admin/package.scala | 7 +++---- .../ru/tinkoff/tcb/mockingbird/api/exec/package.scala | 7 +++---- .../ru/tinkoff/tcb/mockingbird/model/RequestBody.scala | 4 +++- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/admin/package.scala b/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/admin/package.scala index cbbe1af9..3dc047ab 100644 --- a/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/admin/package.scala +++ b/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/admin/package.scala @@ -66,10 +66,9 @@ package object admin { .summary("Test HTTP stub resolution") .in(execInput) .in( - binaryBody(RawBodyType.ByteArrayBody)[Option[String]] - .map[RequestBody]((_: Option[String]).fold[RequestBody](AbsentRequestBody)(SimpleRequestBody(_)))( - SimpleRequestBody.subset.getOption(_).map(_.value) - ) + byteArrayBody.map[RequestBody]((b: Array[Byte]) => if (b.isEmpty) AbsentRequestBody else SimpleRequestBody(b))( + SimpleRequestBody.subset.getOption(_).map(_.binary).getOrElse(Array.empty) + ) ) .out(jsonBody[SID[HttpStub]]) diff --git a/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/exec/package.scala b/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/exec/package.scala index f655533b..7dff1adc 100644 --- a/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/exec/package.scala +++ b/backend/mockingbird-api/src/main/scala/ru/tinkoff/tcb/mockingbird/api/exec/package.scala @@ -48,10 +48,9 @@ package object exec { baseEndpoint .in(execInput) .in( - binaryBody(RawBodyType.ByteArrayBody)[Option[String]] - .map[RequestBody]((_: Option[String]).fold[RequestBody](AbsentRequestBody)(SimpleRequestBody(_)))( - SimpleRequestBody.subset.getOption(_).map(_.value) - ) + byteArrayBody.map[RequestBody]((b: Array[Byte]) => if (b.isEmpty) AbsentRequestBody else SimpleRequestBody(b))( + SimpleRequestBody.subset.getOption(_).map(_.binary).getOrElse(Array.empty) + ) ) .out(headers) .out(statusCode) diff --git a/backend/mockingbird/src/main/scala/ru/tinkoff/tcb/mockingbird/model/RequestBody.scala b/backend/mockingbird/src/main/scala/ru/tinkoff/tcb/mockingbird/model/RequestBody.scala index 1f284c7b..513327f6 100644 --- a/backend/mockingbird/src/main/scala/ru/tinkoff/tcb/mockingbird/model/RequestBody.scala +++ b/backend/mockingbird/src/main/scala/ru/tinkoff/tcb/mockingbird/model/RequestBody.scala @@ -19,7 +19,9 @@ case object AbsentRequestBody extends RequestBody { implicit val absentRequestBodyLoggable: Loggable[AbsentRequestBody.type] = Loggable.empty[AbsentRequestBody.type] } -final case class SimpleRequestBody(value: String) extends RequestBody +final case class SimpleRequestBody(binary: Array[Byte]) extends RequestBody { + val value: String = new String(binary) +} object SimpleRequestBody { final val subset: Subset[RequestBody, SimpleRequestBody] = GenSubset[RequestBody, SimpleRequestBody]