aboutsummaryrefslogtreecommitdiff
path: root/core/src/test/scala/com/softwaremill/sttp/testing/streaming/StreamingTest.scala
blob: 40aaf82edc543c0eed04d16bd7dba791e7dedb0f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
package com.softwaremill.sttp.testing.streaming

import com.softwaremill.sttp._
import com.softwaremill.sttp.testing.ForceWrapped
import org.scalatest.{AsyncFreeSpec, BeforeAndAfterAll, Matchers}
import scala.language.higherKinds

import com.softwaremill.sttp.testing.ConvertToFuture
import com.softwaremill.sttp.testing.TestHttpServer

trait StreamingTest[R[_], S]
    extends AsyncFreeSpec
    with Matchers
    with ForceWrapped
    with BeforeAndAfterAll
    with TestHttpServer {

  private val body = "streaming test"

  implicit def backend: SttpBackend[R, S]

  implicit def convertToFuture: ConvertToFuture[R]

  def bodyProducer(body: String): S

  def bodyConsumer(stream: S): R[String]

  "stream request body" in {
    sttp
      .post(uri"$endpoint/streaming/echo")
      .streamBody(bodyProducer(body))
      .send()
      .toFuture()
      .map { response =>
        response.unsafeBody shouldBe body
      }
  }

  "receive a stream" in {
    sttp
      .post(uri"$endpoint/streaming/echo")
      .body(body)
      .response(asStream[S])
      .send()
      .toFuture()
      .flatMap { response =>
        bodyConsumer(response.unsafeBody).toFuture()
      }
      .map { responseBody =>
        responseBody shouldBe body
      }
  }

  "receive a stream from an https site" in {
    sttp
    // of course, you should never rely on the internet being available
    // in tests, but that's so much easier than setting up an https
    // testing server
      .get(uri"https://softwaremill.com")
      .response(asStream[S])
      .send()
      .toFuture()
      .flatMap { response =>
        bodyConsumer(response.unsafeBody).toFuture()
      }
      .map { responseBody =>
        responseBody should include("</div>")
      }
  }

  override protected def afterAll(): Unit = {
    backend.close()
    super.afterAll()
  }

}