All Downloads are FREE. Search and download functionalities are using the official Maven repository.

sttp.client.testing.RecordingSttpBackend.scala Maven / Gradle / Ivy

The newest version!
package sttp.client.testing

import java.util.concurrent.atomic.AtomicReference
import java.util.function.UnaryOperator

import sttp.capabilities.Effect
import sttp.client.{Request, Response, SttpBackend}
import sttp.monad.MonadError
import sttp.monad.syntax._

import scala.util.{Failure, Success, Try}

class RecordingSttpBackend[F[_], +P](delegate: SttpBackend[F, P]) extends SttpBackend[F, P] {
  type RequestAndResponse = (Request[_, _], Try[Response[_]])

  private val _allInteractions = new AtomicReference[Vector[RequestAndResponse]](Vector())

  private def addInteraction(request: Request[_, _], response: Try[Response[_]]): Unit = {
    _allInteractions.updateAndGet(new UnaryOperator[Vector[RequestAndResponse]] {
      override def apply(t: Vector[RequestAndResponse]): Vector[RequestAndResponse] = t.:+((request, response))
    })
  }

  override def send[T, R >: P with Effect[F]](request: Request[T, R]): F[Response[T]] = {
    implicit val m: MonadError[F] = responseMonad
    delegate
      .send(request)
      .map { response =>
        addInteraction(request, Success(response))
        response
      }
      .handleError { case e: Exception =>
        addInteraction(request, Failure(e))
        responseMonad.error(e)
      }
  }

  override def close(): F[Unit] = delegate.close()
  override def responseMonad: MonadError[F] = delegate.responseMonad

  def allInteractions: List[RequestAndResponse] = _allInteractions.get().toList
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy