Class/Object

sttp.client.testing

SttpBackendStub

Related Docs: object SttpBackendStub | package testing

Permalink

class SttpBackendStub[R[_], S] extends SttpBackend[R, S]

A stub backend to use in tests.

The stub can be configured to respond with a given response if the request matches a predicate (see the whenRequestMatches() method).

Note however, that this is not type-safe with respect to the type of the response body - the stub doesn't have a way to check if the type of the body in the configured response is the same as the one specified by the request. Some conversions will be attempted (e.g. from a String to a custom mapped type, as specified in the request, see the documentation for more details).

Hence, the predicates can match requests basing on the URI or headers. A ClassCastException might occur if for a given request, a response is specified with the incorrect or inconvertible body type.

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SttpBackendStub
  2. SttpBackend
  3. AnyRef
  4. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. class WhenRequest extends AnyRef

    Permalink

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  6. def close(): R[Unit]

    Permalink
    Definition Classes
    SttpBackendStubSttpBackend
  7. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  8. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  9. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  10. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  11. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  12. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  13. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  14. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  15. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  16. def responseMonad: MonadError[R]

    Permalink

    The monad in which the responses are wrapped.

    The monad in which the responses are wrapped. Allows writing wrapper backends, which map/flatMap over the return value of send.

    Definition Classes
    SttpBackendStubSttpBackend
  17. def send[T](request: Request[T, S]): R[Response[T]]

    Permalink
    Definition Classes
    SttpBackendStubSttpBackend
  18. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  19. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  22. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  23. def whenAnyRequest: WhenRequest

    Permalink

    Specify how the stub backend should respond to any request (catch-all).

    Specify how the stub backend should respond to any request (catch-all).

    Note that the stubs are immutable, and each new specification that is added yields a new stub instance.

  24. def whenRequestMatches(p: (Request[_, _]) ⇒ Boolean): WhenRequest

    Permalink

    Specify how the stub backend should respond to requests matching the given predicate.

    Specify how the stub backend should respond to requests matching the given predicate.

    Note that the stubs are immutable, and each new specification that is added yields a new stub instance.

  25. def whenRequestMatchesPartial(partial: PartialFunction[Request[_, _], Response[_]]): SttpBackendStub[R, S]

    Permalink

    Specify how the stub backend should respond to requests using the given partial function.

    Specify how the stub backend should respond to requests using the given partial function.

    Note that the stubs are immutable, and each new specification that is added yields a new stub instance.

Inherited from SttpBackend[R, S]

Inherited from AnyRef

Inherited from Any

Ungrouped