diff --git a/.github/workflows/build-test.yml b/.github/workflows/build-test.yml
index 6b99248f..f5852c7c 100644
--- a/.github/workflows/build-test.yml
+++ b/.github/workflows/build-test.yml
@@ -39,7 +39,7 @@ jobs:
with:
java: 21, 17
scala: 2.13.x, 3.x
- cmd: sbt ++$MATRIX_SCALA 'testOnly -- xonly timefactor 5'
+ cmd: sbt ++$MATRIX_SCALA test
finish:
name: Finish
diff --git a/integration-tests/src/test/java/play/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala b/integration-tests/src/test/java/play/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala
index 413be5f5..dbb8efcb 100644
--- a/integration-tests/src/test/java/play/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala
+++ b/integration-tests/src/test/java/play/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala
@@ -4,9 +4,8 @@
package play.libs.ws.ahc
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.concurrent.FutureAwait
-import org.specs2.mutable.Specification
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.mvc.Results
@@ -22,11 +21,11 @@ import scala.jdk.CollectionConverters._
import scala.jdk.FutureConverters._
import play.api.routing.sird._
-class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
+class AhcCurlRequestLoggerSpec
+ extends AnyWordSpec
with NettyServerProvider
with StandaloneWSClientSupport
- with FutureAwait
+ with ScalaFutures
with DefaultBodyWritables {
override def routes(components: BuiltInComponents) = {
@@ -56,9 +55,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch("--verbose")
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).exists(_.contains("--verbose")))
}
"add all headers" in withClient() { client =>
@@ -71,11 +70,11 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
+ .futureValue
val messages = testLogger.getLoggingEvents.asScala.map(_.getMessage)
- messages must containMatch("--header 'My-Header: My-Header-Value'")
+ assert(messages.exists(_.contains("--header 'My-Header: My-Header-Value'")))
}
"add all cookies" in withClient() { client =>
@@ -88,11 +87,11 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
+ .futureValue
val messages = testLogger.getLoggingEvents.asScala.map(_.getMessage)
- messages must containMatch("""--cookie 'cookie1=value1'""")
+ assert(messages.exists(_.contains("""--cookie 'cookie1=value1'""")))
}
"add method" in withClient() { client =>
@@ -104,9 +103,11 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch("--request GET")
+ assert(
+ testLogger.getLoggingEvents.asScala.map(_.getMessage).exists(_.contains("--request GET"))
+ )
}
"add authorization header" in withClient() { client =>
@@ -119,14 +120,20 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
-
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch(
- """--header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ='"""
+ .futureValue
+
+ assert(
+ testLogger.getLoggingEvents.asScala
+ .map(_.getMessage)
+ .exists(
+ _.contains(
+ """--header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ='"""
+ )
+ )
)
}
- "handle body" in {
+ "handle body" should {
"add when in memory" in withClient() { client =>
val testLogger = createTestLogger
@@ -138,9 +145,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch("the-body")
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).exists(_.contains("the-body")))
}
"do nothing for empty bodies" in withClient() { client =>
@@ -153,9 +160,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must not containMatch "--data"
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).forall(!_.contains("--data")))
}
}
@@ -171,18 +178,19 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(curlRequestLogger)
.get()
.asScala
- .awaitFor(defaultTimeout)
-
- testLogger.getLoggingEvents.get(0).getMessage must beEqualTo(
- s"""
- |curl \\
- | --verbose \\
- | --request GET \\
- | --header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=' \\
- | --header 'content-type: text/plain' \\
- | --header 'My-Header: My-Header-Value' \\
- | --data 'the-body' \\
- | 'http://localhost:$testServerPort/'
+ .futureValue
+
+ assert(
+ testLogger.getLoggingEvents.get(0).getMessage ==
+ s"""
+ |curl \\
+ | --verbose \\
+ | --request GET \\
+ | --header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=' \\
+ | --header 'content-type: text/plain' \\
+ | --header 'My-Header: My-Header-Value' \\
+ | --data 'the-body' \\
+ | 'http://localhost:$testServerPort/'
""".stripMargin.trim
)
}
diff --git a/integration-tests/src/test/java/play/libs/ws/ahc/StandaloneWSClientSupport.scala b/integration-tests/src/test/java/play/libs/ws/ahc/StandaloneWSClientSupport.scala
index 82434821..0f35db5e 100644
--- a/integration-tests/src/test/java/play/libs/ws/ahc/StandaloneWSClientSupport.scala
+++ b/integration-tests/src/test/java/play/libs/ws/ahc/StandaloneWSClientSupport.scala
@@ -5,7 +5,6 @@
package play.libs.ws.ahc
import org.apache.pekko.stream.Materializer
-import org.specs2.execute.Result
import play.api.libs.ws.ahc.AhcConfigBuilder
import play.api.libs.ws.ahc.AhcWSClientConfig
import play.api.libs.ws.ahc.{ AhcWSClientConfigFactory => ScalaAhcWSClientConfigFactory }
@@ -15,9 +14,9 @@ trait StandaloneWSClientSupport {
def materializer: Materializer
- def withClient(
+ def withClient[A](
config: AhcWSClientConfig = ScalaAhcWSClientConfigFactory.forConfig()
- )(block: StandaloneAhcWSClient => Result): Result = {
+ )(block: StandaloneAhcWSClient => A): A = {
val asyncHttpClient = new DefaultAsyncHttpClient(new AhcConfigBuilder(config).build())
val client = new StandaloneAhcWSClient(asyncHttpClient, materializer)
try {
diff --git a/integration-tests/src/test/scala/play/NettyServerProvider.scala b/integration-tests/src/test/scala/play/NettyServerProvider.scala
index 9b7b59ba..5ca53940 100644
--- a/integration-tests/src/test/scala/play/NettyServerProvider.scala
+++ b/integration-tests/src/test/scala/play/NettyServerProvider.scala
@@ -5,13 +5,17 @@
package play
import org.apache.pekko.actor.ActorSystem
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.specification.BeforeAfterAll
import scala.concurrent.duration._
import scala.concurrent.Await
+import scala.concurrent.ExecutionContext
import org.apache.pekko.stream.Materializer
+import org.scalatest.BeforeAndAfterAll
+import org.scalatest.Suite
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.time.Millis
+import org.scalatest.time.Span
import play.api.mvc.Handler
import play.api.mvc.RequestHeader
import play.core.server.NettyServer
@@ -19,17 +23,17 @@ import play.core.server.ServerConfig
import play.api.BuiltInComponents
import play.api.Mode
-trait NettyServerProvider extends BeforeAfterAll {
+trait NettyServerProvider extends BeforeAndAfterAll with ScalaFutures { self: Suite =>
+
+ final implicit override def patienceConfig: PatienceConfig =
+ PatienceConfig(Span(3000, Millis))
/**
* @return Routes to be used by the test.
*/
def routes(components: BuiltInComponents): PartialFunction[RequestHeader, Handler]
- /**
- * The execution context environment.
- */
- def executionEnv: ExecutionEnv
+ protected implicit def executionContext: ExecutionContext = ExecutionContext.global
lazy val testServerPort: Int = server.httpPort.getOrElse(sys.error("undefined port number"))
val defaultTimeout: FiniteDuration = 5.seconds
@@ -47,7 +51,9 @@ trait NettyServerProvider extends BeforeAfterAll {
)
)(components => routes(components))
- override def beforeAll(): Unit = {}
+ override def beforeAll(): Unit = {
+ super.beforeAll()
+ }
override def afterAll(): Unit = {
server.stop()
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala
index 33130432..3b185be6 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcCurlRequestLoggerSpec.scala
@@ -4,9 +4,8 @@
package play.api.libs.ws.ahc
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.concurrent.FutureAwait
-import org.specs2.mutable.Specification
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.libs.ws.DefaultBodyWritables
@@ -23,11 +22,11 @@ import play.api.routing.sird._
import scala.jdk.CollectionConverters._
-class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
+class AhcCurlRequestLoggerSpec
+ extends AnyWordSpec
with NettyServerProvider
with StandaloneWSClientSupport
- with FutureAwait
+ with ScalaFutures
with DefaultBodyWritables {
override def routes(components: BuiltInComponents): PartialFunction[RequestHeader, Handler] = {
@@ -57,9 +56,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.url(s"http://localhost:$testServerPort/")
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch("--verbose")
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).exists(_.contains("--verbose")))
}
"add all headers" in withClient() { client =>
@@ -71,11 +70,11 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.addHttpHeaders("My-Header" -> "My-Header-Value")
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
+ .futureValue
val messages = testLogger.getLoggingEvents.asScala.map(_.getMessage)
- messages must containMatch("--header 'My-Header: My-Header-Value'")
+ assert(messages.exists(_.contains("--header 'My-Header: My-Header-Value'")))
}
"add all cookies" in withClient() { client =>
@@ -87,11 +86,11 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.addCookies(DefaultWSCookie("cookie1", "value1"))
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
+ .futureValue
val messages = testLogger.getLoggingEvents.asScala.map(_.getMessage)
- messages must containMatch("--cookie 'cookie1=value1'")
+ assert(messages.exists(_.contains("--cookie 'cookie1=value1'")))
}
"add method" in withClient() { client =>
@@ -102,9 +101,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.url(s"http://localhost:$testServerPort/")
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch("--request GET")
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).exists(_.contains("--request GET")))
}
"add authorization header" in withClient() { client =>
@@ -116,14 +115,20 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.withAuth("username", "password", WSAuthScheme.BASIC)
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
-
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch(
- """--header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ='"""
+ .futureValue
+
+ assert(
+ testLogger.getLoggingEvents.asScala
+ .map(_.getMessage)
+ .exists(
+ _.contains(
+ """--header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ='"""
+ )
+ )
)
}
- "handle body" in {
+ "handle body" should {
"add when in memory" in withClient() { client =>
val testLogger = createTestLogger
@@ -134,9 +139,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.withBody("the-body")
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must containMatch("the-body")
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).exists(_.contains("the-body")))
}
"do nothing for empty bodies" in withClient() { client =>
@@ -148,9 +153,9 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.withBody(EmptyBody)
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
+ .futureValue
- testLogger.getLoggingEvents.asScala.map(_.getMessage) must not containMatch "--data"
+ assert(testLogger.getLoggingEvents.asScala.map(_.getMessage).forall(!_.contains("--data")))
}
}
@@ -165,18 +170,19 @@ class AhcCurlRequestLoggerSpec(implicit val executionEnv: ExecutionEnv)
.withAuth("username", "password", WSAuthScheme.BASIC)
.withRequestFilter(curlRequestLogger)
.get()
- .awaitFor(defaultTimeout)
-
- testLogger.getLoggingEvents.get(0).getMessage must beEqualTo(
- s"""
- |curl \\
- | --verbose \\
- | --request GET \\
- | --header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=' \\
- | --header 'My-Header: My-Header-Value' \\
- | --header 'Content-Type: text/plain' \\
- | --data 'the-body' \\
- | 'http://localhost:$testServerPort/'
+ .futureValue
+
+ assert(
+ testLogger.getLoggingEvents.get(0).getMessage ==
+ s"""
+ |curl \\
+ | --verbose \\
+ | --request GET \\
+ | --header 'Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=' \\
+ | --header 'My-Header: My-Header-Value' \\
+ | --header 'Content-Type: text/plain' \\
+ | --data 'the-body' \\
+ | 'http://localhost:$testServerPort/'
""".stripMargin.trim
)
}
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSClientSpec.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSClientSpec.scala
index a74b0258..4fa9d589 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSClientSpec.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSClientSpec.scala
@@ -6,11 +6,8 @@ package play.api.libs.ws.ahc
import org.apache.pekko.stream.scaladsl.Sink
import org.apache.pekko.util.ByteString
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.concurrent.FutureAwait
-import org.specs2.execute.Result
-import org.specs2.matcher.FutureMatchers
-import org.specs2.mutable.Specification
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.http.Status.MOVED_PERMANENTLY
@@ -24,18 +21,17 @@ import play.shaded.ahc.org.asynchttpclient.handler.MaxRedirectException
import scala.concurrent._
-class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
+class AhcWSClientSpec
+ extends AnyWordSpec
with NettyServerProvider
with StandaloneWSClientSupport
- with FutureMatchers
- with FutureAwait
+ with ScalaFutures
with DefaultBodyReadables
with DefaultBodyWritables {
- def withClientFollowingRedirect(
+ def withClientFollowingRedirect[A](
config: AhcWSClientConfig = AhcWSClientConfigFactory.forConfig()
- )(block: StandaloneAhcWSClient => Result): Result = {
+ )(block: StandaloneAhcWSClient => A): A = {
withClient(
config.copy(
wsClientConfig = config.wsClientConfig.copy(followRedirects = true)
@@ -106,13 +102,15 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
"url" should {
"throw an exception on invalid url" in {
withClient() { client =>
- { client.url("localhost") } must throwAn[IllegalArgumentException]
+ assertThrows[IllegalArgumentException] {
+ client.url("localhost")
+ }
}
}
"not throw exception on valid url" in {
withClient() { client =>
- { client.url(s"http://localhost:$testServerPort") } must not(throwAn[IllegalArgumentException])
+ client.url(s"http://localhost:$testServerPort")
}
}
}
@@ -125,7 +123,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/index").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -143,7 +141,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/index").get().map(res => res.body[Foo]),
defaultTimeout
)
- result must beEqualTo(Foo("Say hello to play"))
+ assert(result == Foo("Say hello to play"))
}
}
@@ -154,22 +152,22 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
defaultTimeout
)
val bytes: ByteString = Await.result(resultSource.runWith(Sink.head), defaultTimeout)
- bytes.utf8String must beEqualTo("Say hello to play")
+ assert(bytes.utf8String == "Say hello to play")
}
}
- "when following redirect" in {
+ "when following redirect" should {
"honor the number of redirects allowed" in {
// 1. Default number of max redirects is 5
withClientFollowingRedirect() { client =>
- {
+ assertThrows[MaxRedirectException] {
val request = client
// 2. Ask to redirect 10 times
.url(s"http://localhost:$testServerPort/redirects/302/10")
.get()
Await.result(request, defaultTimeout)
- } must throwA[MaxRedirectException]
+ }
}
}
@@ -179,7 +177,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/redirect/302").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -188,7 +186,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
val ahcWsConfig = AhcWSClientConfigFactory.forConfig().copy(wsClientConfig = wsConfig)
withClient(config = ahcWsConfig) { client =>
val result = Await.result(client.url(s"http://localhost:$testServerPort/redirect/302").get(), defaultTimeout)
- result.status must beEqualTo(302)
+ assert(result.status == 302)
}
}
@@ -201,7 +199,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
.withFollowRedirects(false)
.get()
val result = Await.result(request, defaultTimeout)
- result.status must beEqualTo(302)
+ assert(result.status == 302)
}
}
@@ -211,7 +209,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/redirect/301").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -221,7 +219,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/redirect/302").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -231,7 +229,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/redirect/303").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -241,7 +239,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/redirect/307").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -251,7 +249,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/redirect/308").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -262,7 +260,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
.withVirtualHost("localhost1")
.get()
val result = Await.result(request, defaultTimeout)
- result.header("Req-Host") must beSome("localhost1")
+ assert(result.header("Req-Host") == Some("localhost1"))
}
}
@@ -273,7 +271,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
.addHttpHeaders("X-Test" -> "Test")
.get()
val result = Await.result(request, defaultTimeout)
- result.header("Req-X-Test") must beSome("Test")
+ assert(result.header("Req-X-Test") == Some("Test"))
}
}
@@ -284,7 +282,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
.withAuth("test", "test", WSAuthScheme.BASIC)
.get()
val result = Await.result(request, defaultTimeout)
- result.header("Req-Authorization") must beSome
+ assert(result.header("Req-Authorization").isDefined)
}
}
@@ -294,7 +292,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/cookie").get().map(res => res.body[String]),
defaultTimeout
)
- result must beEqualTo(s"Cookie value => redirect-cookie")
+ assert(result == s"Cookie value => redirect-cookie")
}
}
@@ -311,11 +309,11 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
client.url(s"http://localhost:$testServerPort/cookie-destination").get().map(res => res.body[String]),
defaultTimeout
)
- res2 must beEqualTo(s"Request is missing required cookie 'flash'")
+ assert(res2 == s"Request is missing required cookie 'flash'")
}
}
- "switch to get " in {
+ "switch to get " should {
"for HTTP 301 Moved Permanently" in {
withClientFollowingRedirect() { client =>
val request = client
@@ -328,7 +326,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
// 2. So when following the redirect, the GET path should be found
// and we get its body
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -338,7 +336,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
.url(s"http://localhost:$testServerPort/redirect/303")
.post("request body")
val result = Await.result(request.map(res => res.body[String]), defaultTimeout)
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
@@ -354,7 +352,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
// 2. So when following the redirect, the GET path should be found
// and we get its body
- result must beEqualTo("Say hello to play")
+ assert(result == "Say hello to play")
}
}
}
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestFilterSpec.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestFilterSpec.scala
index d1fd61ca..2db9ef64 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestFilterSpec.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestFilterSpec.scala
@@ -4,9 +4,8 @@
package play.api.libs.ws.ahc
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.matcher.FutureMatchers
-import org.specs2.mutable.Specification
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.libs.ws._
@@ -14,11 +13,11 @@ import play.api.mvc.Results
import scala.collection.mutable
-class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
+class AhcWSRequestFilterSpec
+ extends AnyWordSpec
with NettyServerProvider
with StandaloneWSClientSupport
- with FutureMatchers
+ with ScalaFutures
with DefaultBodyReadables {
override def routes(components: BuiltInComponents) = { case _ =>
@@ -67,9 +66,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
})
.get()
.map { response =>
- response.body[String] must contain("some string")
+ assert(response.body[String].contains("some string"))
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"stream with adhoc request filter" in withClient() { client =>
@@ -81,9 +80,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withMethod("GET")
.stream()
.map { response =>
- response.body[String] must contain("some string")
+ assert(response.body[String].contains("some string"))
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"work with one request filter" in withClient() { client =>
@@ -93,9 +92,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withRequestFilter(new CallbackRequestFilter(callList, 1))
.get()
.map { _ =>
- callList must contain(1)
+ assert(callList.contains(1))
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"stream with one request filter" in withClient() { client =>
@@ -106,9 +105,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withMethod("GET")
.stream()
.map { _ =>
- callList must contain(1)
+ assert(callList.contains(1))
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"work with three request filter" in withClient() { client =>
@@ -120,9 +119,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withRequestFilter(new CallbackRequestFilter(callList, 3))
.get()
.map { _ =>
- callList must containTheSameElementsAs(Seq(1, 2, 3))
+ assert(callList.toSet == Set(1, 2, 3))
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"stream with three request filters" in withClient() { client =>
@@ -135,9 +134,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withMethod("GET")
.stream()
.map { _ =>
- callList must containTheSameElementsAs(Seq(1, 2, 3))
+ assert(callList.toSet == Set(1, 2, 3))
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"should allow filters to modify the request" in withClient() { client =>
@@ -148,9 +147,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withRequestFilter(new HeaderAppendingFilter(appendedHeader, appendedHeaderValue))
.get()
.map { response =>
- response.headers("X-Request-Id").head must be_==("someid")
+ assert(response.headers("X-Request-Id").head == "someid")
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
"allow filters to modify the streaming request" in withClient() { client =>
@@ -162,9 +161,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.withMethod("GET")
.stream()
.map { response =>
- response.headers("X-Request-Id").head must be_==("someid")
+ assert(response.headers("X-Request-Id").head == "someid")
}
- .await(retries = 0, timeout = defaultTimeout)
+ .futureValue
}
}
}
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/JsonRequestSpec.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/JsonRequestSpec.scala
index 7394ab89..37eec0f9 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/JsonRequestSpec.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/JsonRequestSpec.scala
@@ -14,8 +14,8 @@ import org.mockito.Mockito.verify
import org.mockito.Mockito.when
import org.mockito.Mockito
-import org.specs2.mutable.Specification
-import org.specs2.specification.AfterAll
+import org.scalatest.BeforeAndAfterAll
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.json.JsString
import play.api.libs.json.JsValue
import play.api.libs.json.Json
@@ -29,8 +29,7 @@ import scala.reflect.ClassTag
/**
*/
-class JsonRequestSpec extends Specification with AfterAll with JsonBodyWritables {
- sequential
+class JsonRequestSpec extends AnyWordSpec with BeforeAndAfterAll with JsonBodyWritables {
private def mock[A](implicit a: ClassTag[A]): A =
Mockito.mock(a.runtimeClass).asInstanceOf[A]
@@ -50,8 +49,8 @@ class JsonRequestSpec extends Specification with AfterAll with JsonBodyWritables
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get("Content-Type") must be_==("application/json")
- ByteString.fromArray(req.getByteData).utf8String must be_==("""{"k1":"v1"}""")
+ assert(req.getHeaders.get("Content-Type") == "application/json")
+ assert(ByteString.fromArray(req.getByteData).utf8String == """{"k1":"v1"}""")
}
"set a json node using the default object mapper" in {
@@ -65,8 +64,8 @@ class JsonRequestSpec extends Specification with AfterAll with JsonBodyWritables
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get("Content-Type") must be_==("application/json")
- ByteString.fromArray(req.getByteData).utf8String must be_==("""{"k1":"v1"}""")
+ assert(req.getHeaders.get("Content-Type") == "application/json")
+ assert(ByteString.fromArray(req.getByteData).utf8String == """{"k1":"v1"}""")
}
"read an encoding of UTF-8" in {
@@ -81,7 +80,7 @@ class JsonRequestSpec extends Specification with AfterAll with JsonBodyWritables
val value: JsValue = JsonBodyReadables.readableAsJson.transform(response)
verify(ahcResponse, times(1)).getResponseBody(StandardCharsets.UTF_8)
verify(ahcResponse, times(1)).getContentType
- value.toString must beEqualTo(json)
+ assert(value.toString == json)
}
"read an encoding of ISO-8859-1" in {
@@ -96,6 +95,6 @@ class JsonRequestSpec extends Specification with AfterAll with JsonBodyWritables
val value: JsValue = JsonBodyReadables.readableAsJson.transform(response)
verify(ahcResponse, times(1)).getResponseBody(StandardCharsets.ISO_8859_1)
verify(ahcResponse, times(1)).getContentType
- value.toString must beEqualTo(json)
+ assert(value.toString == json)
}
}
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/StandaloneWSClientSupport.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/StandaloneWSClientSupport.scala
index 0a2e692b..003458f5 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/StandaloneWSClientSupport.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/StandaloneWSClientSupport.scala
@@ -5,15 +5,14 @@
package play.api.libs.ws.ahc
import org.apache.pekko.stream.Materializer
-import org.specs2.execute.Result
trait StandaloneWSClientSupport {
def materializer: Materializer
- def withClient(
+ def withClient[A](
config: AhcWSClientConfig = AhcWSClientConfigFactory.forConfig()
- )(block: StandaloneAhcWSClient => Result): Result = {
+ )(block: StandaloneAhcWSClient => A): A = {
val client = StandaloneAhcWSClient(config)(materializer)
try {
block(client)
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/XMLRequestSpec.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/XMLRequestSpec.scala
index 05ef5c86..2c8f1dfa 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/XMLRequestSpec.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/XMLRequestSpec.scala
@@ -9,17 +9,15 @@ import java.nio.charset.StandardCharsets
import org.apache.pekko.actor.ActorSystem
import org.apache.pekko.stream.Materializer
import org.apache.pekko.util.ByteString
-import org.specs2.matcher.MustMatchers
-import org.specs2.mutable.Specification
-import org.specs2.specification.AfterAll
+import org.scalatest.BeforeAndAfterAll
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.ws._
import scala.xml.Elem
/**
*/
-class XMLRequestSpec extends Specification with AfterAll with MustMatchers {
- sequential
+class XMLRequestSpec extends AnyWordSpec with BeforeAndAfterAll {
implicit val system: ActorSystem = ActorSystem()
implicit val materializer: Materializer = Materializer.matFromSystem
@@ -59,8 +57,8 @@ class XMLRequestSpec extends Specification with AfterAll with MustMatchers {
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get("Content-Type") must be_==("text/xml; charset=UTF-8")
- ByteString.fromArray(req.getByteData).utf8String must be_==("")
+ assert(req.getHeaders.get("Content-Type") == "text/xml; charset=UTF-8")
+ assert(ByteString.fromArray(req.getByteData).utf8String == "")
}
"read an XML node in Utf-8" in {
@@ -76,9 +74,9 @@ class XMLRequestSpec extends Specification with AfterAll with MustMatchers {
val readables = new XMLBodyReadables() {}
/* UTF-8 */
val value: Elem = readables.readableAsXml.transform(new StubResponse(test.getBytes(StandardCharsets.UTF_8)))
- (value \\ "note" \ "to").text must be_==("Tove")
- (value \\ "note" \ "from").text must be_==("Jani")
- (value \\ "note" \ "heading").text must be_==("Reminder")
+ assert((value \\ "note" \ "to").text == "Tove")
+ assert((value \\ "note" \ "from").text == "Jani")
+ assert((value \\ "note" \ "heading").text == "Reminder")
}
"read an XML node in Utf-16" in {
@@ -94,8 +92,8 @@ class XMLRequestSpec extends Specification with AfterAll with MustMatchers {
val readables = new XMLBodyReadables() {}
/* UTF-16 */
val value: Elem = readables.readableAsXml.transform(new StubResponse(test.getBytes(StandardCharsets.UTF_16)))
- (value \\ "note" \ "to").text must be_==("Tove")
- (value \\ "note" \ "from").text must be_==("Jani")
- (value \\ "note" \ "heading").text must be_==("Reminder")
+ assert((value \\ "note" \ "to").text == "Tove")
+ assert((value \\ "note" \ "from").text == "Jani")
+ assert((value \\ "note" \ "heading").text == "Reminder")
}
}
diff --git a/integration-tests/src/test/scala/play/api/libs/ws/ahc/cache/CachingSpec.scala b/integration-tests/src/test/scala/play/api/libs/ws/ahc/cache/CachingSpec.scala
index 361cea81..be384129 100644
--- a/integration-tests/src/test/scala/play/api/libs/ws/ahc/cache/CachingSpec.scala
+++ b/integration-tests/src/test/scala/play/api/libs/ws/ahc/cache/CachingSpec.scala
@@ -7,10 +7,7 @@ package play.api.libs.ws.ahc.cache
import org.mockito.ArgumentMatchers.any
import org.mockito.Mockito
import org.mockito.Mockito.when
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.matcher.FutureMatchers
-import org.specs2.mutable.Specification
-import org.specs2.specification.AfterAll
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.libs.ws.ahc._
@@ -24,11 +21,7 @@ import play.shaded.ahc.org.asynchttpclient._
import scala.concurrent.Future
import scala.reflect.ClassTag
-class CachingSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
- with NettyServerProvider
- with AfterAll
- with FutureMatchers {
+class CachingSpec extends AnyWordSpec with NettyServerProvider {
private def mock[A](implicit a: ClassTag[A]): A =
Mockito.mock(a.runtimeClass).asInstanceOf[A]
@@ -64,12 +57,11 @@ class CachingSpec(implicit val executionEnv: ExecutionEnv)
ws.url(s"http://localhost:$testServerPort/hello")
.get()
.map { response =>
- response.body[String] must be_==("
Say hello to play
")
+ assert(response.body[String] == "Say hello to play
")
}
- .await
+ .futureValue
Mockito.verify(cache).get(EffectiveURIKey("GET", new java.net.URI(s"http://localhost:$testServerPort/hello")))
- success
}
}
}
diff --git a/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSClientSpec.scala b/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSClientSpec.scala
index 621d7d2c..a463bb51 100644
--- a/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSClientSpec.scala
+++ b/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSClientSpec.scala
@@ -6,9 +6,8 @@ package play.libs.ws.ahc
import org.apache.pekko.stream.javadsl.Sink
import org.apache.pekko.util.ByteString
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.matcher.FutureMatchers
-import org.specs2.mutable.Specification
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.mvc.AnyContentAsText
@@ -19,13 +18,12 @@ import play.libs.ws._
import scala.jdk.FutureConverters._
import scala.concurrent.Future
-import scala.concurrent.duration._
-class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
+class AhcWSClientSpec
+ extends AnyWordSpec
with NettyServerProvider
with StandaloneWSClientSupport
- with FutureMatchers
+ with ScalaFutures
with XMLBodyWritables
with XMLBodyReadables {
@@ -59,8 +57,8 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
.url(s"http://localhost:$testServerPort")
.post(someOtherMethod("hello world"))
.asScala
- .map(response => response.getBody() must be_==("hello world"))
- .await(retries = 0, timeout = 5.seconds)
+ .map(response => assert(response.getBody() == "hello world"))
+ .futureValue
}
"source successfully" in withClient() { client =>
@@ -69,7 +67,7 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
response.getBodyAsSource.runWith(Sink.head[ByteString](), materializer).asScala
}
val expected: ByteString = ByteString.fromString("Say hello to play
")
- result must be_==(expected).await(retries = 0, timeout = 5.seconds)
+ assert(result.futureValue == expected)
}
"round trip XML successfully" in withClient() { client =>
@@ -96,11 +94,10 @@ class AhcWSClientSpec(implicit val executionEnv: ExecutionEnv)
val responseXml = response.getBody(xml())
responseXml.normalizeDocument()
- (responseXml.isEqualNode(document) must beTrue).and {
- response.getUri must beEqualTo(new java.net.URI(s"http://localhost:$testServerPort"))
- }
+ assert(responseXml.isEqualNode(document))
+ assert(response.getUri == new java.net.URI(s"http://localhost:$testServerPort"))
}
- .await(retries = 0, timeout = 5.seconds)
+ .futureValue
}
}
}
diff --git a/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSRequestFilterSpec.scala b/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSRequestFilterSpec.scala
index 33212913..67facfe8 100644
--- a/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSRequestFilterSpec.scala
+++ b/integration-tests/src/test/scala/play/libs/ws/ahc/AhcWSRequestFilterSpec.scala
@@ -4,21 +4,19 @@
package play.libs.ws.ahc
-import org.specs2.concurrent.ExecutionEnv
-import org.specs2.matcher.FutureMatchers
-import org.specs2.mutable.Specification
+import org.scalatest.concurrent.ScalaFutures
+import org.scalatest.wordspec.AnyWordSpec
import play.NettyServerProvider
import play.api.BuiltInComponents
import play.api.mvc.Results
-import scala.concurrent.duration._
import scala.jdk.FutureConverters._
-class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
- extends Specification
+class AhcWSRequestFilterSpec
+ extends AnyWordSpec
with NettyServerProvider
with StandaloneWSClientSupport
- with FutureMatchers {
+ with ScalaFutures {
override def routes(components: BuiltInComponents) = { case _ =>
components.defaultActionBuilder { req =>
@@ -43,11 +41,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(new CallbackRequestFilter(callList, 1))
.get()
.asScala
- responseFuture
- .map { _ =>
- callList.asScala must contain(1)
- }
- .await(retries = 0, timeout = 5.seconds)
+ responseFuture.map { _ =>
+ assert(callList.asScala.map(_.intValue()).contains(1))
+ }.futureValue
}
"stream with one request filter" in withClient() { client =>
@@ -59,11 +55,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(new CallbackRequestFilter(callList, 1))
.stream()
.asScala
- responseFuture
- .map { _ =>
- callList.asScala must contain(1)
- }
- .await(retries = 0, timeout = 5.seconds)
+ responseFuture.map { _ =>
+ assert(callList.asScala.map(_.intValue()).contains(1))
+ }.futureValue
}
"work with three request filter" in withClient() { client =>
@@ -77,11 +71,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(new CallbackRequestFilter(callList, 3))
.get()
.asScala
- responseFuture
- .map { _ =>
- callList.asScala must containTheSameElementsAs(Seq(1, 2, 3))
- }
- .await(retries = 0, timeout = 5.seconds)
+ responseFuture.map { _ =>
+ assert(callList.asScala.toSet == Set(1, 2, 3))
+ }.futureValue
}
"stream with three request filters" in withClient() { client =>
@@ -95,11 +87,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.setRequestFilter(new CallbackRequestFilter(callList, 3))
.stream()
.asScala
- responseFuture
- .map { _ =>
- callList.asScala must containTheSameElementsAs(Seq(1, 2, 3))
- }
- .await(retries = 0, timeout = 5.seconds)
+ responseFuture.map { _ =>
+ assert(callList.asScala.toSet == Set(1, 2, 3))
+ }.futureValue
}
"should allow filters to modify the request" in withClient() { client =>
@@ -112,11 +102,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.get()
.asScala
- responseFuture
- .map { response =>
- response.getHeaders.get("X-Request-Id").get(0) must be_==("someid")
- }
- .await(retries = 0, timeout = 5.seconds)
+ responseFuture.map { response =>
+ assert(response.getHeaders.get("X-Request-Id").get(0) == "someid")
+ }.futureValue
}
"allow filters to modify the streaming request" in withClient() { client =>
@@ -129,11 +117,9 @@ class AhcWSRequestFilterSpec(implicit val executionEnv: ExecutionEnv)
.stream()
.asScala
- responseFuture
- .map { response =>
- response.getHeaders.get("X-Request-Id").get(0) must be_==("someid")
- }
- .await(retries = 0, timeout = 5.seconds)
+ responseFuture.map { response =>
+ assert(response.getHeaders.get("X-Request-Id").get(0) == "someid")
+ }.futureValue
}
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/oauth/OAuthSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/oauth/OAuthSpec.scala
index cbe5f748..615f7c50 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/oauth/OAuthSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/oauth/OAuthSpec.scala
@@ -4,12 +4,12 @@
package play.api.libs.oauth
-import org.specs2.mutable.Specification
+import org.scalatest.wordspec.AnyWordSpec
-class OAuthSpec extends Specification {
+class OAuthSpec extends AnyWordSpec {
"OAuth" should {
"be able to use signpost OAuth" in {
- Class.forName("play.shaded.oauth.oauth.signpost.OAuth") must not(throwA[ClassNotFoundException])
+ Class.forName("play.shaded.oauth.oauth.signpost.OAuth")
}
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcConfigBuilderSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcConfigBuilderSpec.scala
index c597fcdb..ae6e9d3d 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcConfigBuilderSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcConfigBuilderSpec.scala
@@ -9,7 +9,7 @@ import com.typesafe.config.ConfigFactory
import com.typesafe.sslconfig.ssl.Protocols
import com.typesafe.sslconfig.ssl.SSLConfigFactory
import com.typesafe.sslconfig.ssl.SSLConfigSettings
-import org.specs2.mutable.Specification
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.ws.WSClientConfig
import play.shaded.ahc.org.asynchttpclient.proxy.ProxyServerSelector
import play.shaded.ahc.org.asynchttpclient.util.ProxyUtils
@@ -18,7 +18,7 @@ import scala.concurrent.duration._
/**
*/
-class AhcConfigBuilderSpec extends Specification {
+class AhcConfigBuilderSpec extends AnyWordSpec {
val defaultWsConfig = WSClientConfig()
val defaultConfig = AhcWSClientConfig(defaultWsConfig)
@@ -35,11 +35,11 @@ class AhcConfigBuilderSpec extends Specification {
builder.setFollowRedirect(false)
}
.build()
- ahcConfig.isCompressionEnforced must beFalse
- ahcConfig.isFollowRedirect must beFalse
- ahcConfig.getConnectTimeout must_== 120000
- ahcConfig.getRequestTimeout must_== 120000
- ahcConfig.getReadTimeout must_== 120000
+ assert(ahcConfig.isCompressionEnforced == false)
+ assert(ahcConfig.isFollowRedirect == false)
+ assert(ahcConfig.getConnectTimeout == 120000)
+ assert(ahcConfig.getRequestTimeout == 120000)
+ assert(ahcConfig.getReadTimeout == 120000)
}
"with basic options" should {
@@ -49,13 +49,13 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getReadTimeout must_== defaultWsConfig.idleTimeout.toMillis
- actual.getRequestTimeout must_== defaultWsConfig.requestTimeout.toMillis
- actual.getConnectTimeout must_== defaultWsConfig.connectionTimeout.toMillis
- actual.isFollowRedirect must_== defaultWsConfig.followRedirects
- actual.getCookieStore must_== null
+ assert(actual.getReadTimeout == defaultWsConfig.idleTimeout.toMillis)
+ assert(actual.getRequestTimeout == defaultWsConfig.requestTimeout.toMillis)
+ assert(actual.getConnectTimeout == defaultWsConfig.connectionTimeout.toMillis)
+ assert(actual.isFollowRedirect == defaultWsConfig.followRedirects)
+ assert(actual.getCookieStore == null)
- actual.getEnabledProtocols.toSeq must not contain Protocols.deprecatedProtocols
+ assert(actual.getEnabledProtocols.toSeq.forall(x => !Protocols.deprecatedProtocols.contains(x)))
}
"use an explicit idle timeout" in {
@@ -64,7 +64,7 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getReadTimeout must_== 42L
+ assert(actual.getReadTimeout == 42L)
}
"use an explicit request timeout" in {
@@ -73,7 +73,7 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getRequestTimeout must_== 47L
+ assert(actual.getRequestTimeout == 47L)
}
"use an explicit connection timeout" in {
@@ -82,7 +82,7 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getConnectTimeout must_== 99L
+ assert(actual.getConnectTimeout == 99L)
}
"use an explicit followRedirects option" in {
@@ -91,7 +91,7 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.isFollowRedirect must_== true
+ assert(actual.isFollowRedirect == true)
}
"use an explicit proxy if useProxyProperties is true and there are system defined proxy settings" in {
@@ -106,9 +106,9 @@ class AhcConfigBuilderSpec extends Specification {
val proxyServerSelector = actual.getProxyServerSelector
- proxyServerSelector must not(beNull)
+ assert(proxyServerSelector != null)
- (proxyServerSelector must not).be_==(ProxyServerSelector.NO_PROXY_SELECTOR)
+ assert(proxyServerSelector != ProxyServerSelector.NO_PROXY_SELECTOR)
} finally {
// Unset http.proxyHost
System.clearProperty(ProxyUtils.PROXY_HOST)
@@ -122,42 +122,42 @@ class AhcConfigBuilderSpec extends Specification {
val config = defaultConfig.copy(keepAlive = false)
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.isKeepAlive must_== false
+ assert(actual.isKeepAlive == false)
}
"allow setting ahc maximumConnectionsPerHost" in {
val config = defaultConfig.copy(maxConnectionsPerHost = 3)
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getMaxConnectionsPerHost must_== 3
+ assert(actual.getMaxConnectionsPerHost == 3)
}
"allow setting ahc maximumConnectionsTotal" in {
val config = defaultConfig.copy(maxConnectionsTotal = 6)
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getMaxConnections must_== 6
+ assert(actual.getMaxConnections == 6)
}
"allow setting ahc maxNumberOfRedirects" in {
val config = defaultConfig.copy(maxNumberOfRedirects = 0)
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getMaxRedirects must_== 0
+ assert(actual.getMaxRedirects == 0)
}
"allow setting ahc maxRequestRetry" in {
val config = defaultConfig.copy(maxRequestRetry = 99)
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.getMaxRequestRetry must_== 99
+ assert(actual.getMaxRequestRetry == 99)
}
"allow setting ahc disableUrlEncoding" in {
val config = defaultConfig.copy(disableUrlEncoding = true)
val builder = new AhcConfigBuilder(config)
val actual = builder.build()
- actual.isDisableUrlEncodingForBoundRequests must_== true
+ assert(actual.isDisableUrlEncodingForBoundRequests == true)
}
}
@@ -177,12 +177,12 @@ class AhcConfigBuilderSpec extends Specification {
val config = defaultConfig.copy(wsClientConfig = wsConfig)
val builder = new AhcConfigBuilder(config)
- sslConfig.protocol must_== "TLSv1.2"
+ assert(sslConfig.protocol == "TLSv1.2")
val asyncClientConfig = builder.build()
// ...and return a result so specs2 is happy.
- asyncClientConfig.getSslEngineFactory must not(beNull)
+ assert(asyncClientConfig.getSslEngineFactory != null)
}
"should validate certificates" in {
@@ -192,7 +192,7 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val asyncConfig = builder.build()
- asyncConfig.isUseInsecureTrustManager must beFalse
+ assert(asyncConfig.isUseInsecureTrustManager == false)
}
"should disable the hostname verifier if loose.acceptAnyCertificate is enabled" in {
@@ -203,7 +203,7 @@ class AhcConfigBuilderSpec extends Specification {
val builder = new AhcConfigBuilder(config)
val asyncConfig = builder.build()
- asyncConfig.isUseInsecureTrustManager must beTrue
+ assert(asyncConfig.isUseInsecureTrustManager)
}
}
@@ -218,7 +218,7 @@ class AhcConfigBuilderSpec extends Specification {
val actual = builder.configureProtocols(existingProtocols, sslConfig)
- actual.toSeq must containTheSameElementsAs(Protocols.recommendedProtocols.toIndexedSeq)
+ assert(actual.toSet == Protocols.recommendedProtocols.toSet)
}
"provide explicit protocols if specified" in {
@@ -231,7 +231,7 @@ class AhcConfigBuilderSpec extends Specification {
val actual = builder.configureProtocols(existingProtocols, sslConfig)
- actual.toSeq must containTheSameElementsAs(Seq("derp", "baz", "quux"))
+ assert(actual.toSet == Set("derp", "baz", "quux"))
}
}
@@ -247,7 +247,7 @@ class AhcConfigBuilderSpec extends Specification {
val actual = builder.configureCipherSuites(existingCiphers, sslConfig)
- actual.toSeq must containTheSameElementsAs(Seq("goodone", "goodtwo"))
+ assert(actual.toSet == Set("goodone", "goodtwo"))
}
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSClientConfigParserSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSClientConfigParserSpec.scala
index e5f27948..d104962c 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSClientConfigParserSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSClientConfigParserSpec.scala
@@ -5,12 +5,12 @@
package play.api.libs.ws.ahc
import com.typesafe.config.ConfigFactory
-import org.specs2.mutable._
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.ws.WSClientConfig
import scala.concurrent.duration._
-class AhcWSClientConfigParserSpec extends Specification {
+class AhcWSClientConfigParserSpec extends AnyWordSpec {
val defaultWsConfig = WSClientConfig()
val defaultConfig = AhcWSClientConfig(defaultWsConfig)
@@ -30,15 +30,15 @@ class AhcWSClientConfigParserSpec extends Specification {
// since we use typesafe ssl-config we can't match the objects directly since they aren't case classes,
// and also AhcWSClientConfig has a duration which will be parsed into nanocseconds while the case class uses minutes
- s1.wsClientConfig.toString must_== s2.wsClientConfig.toString
- s1.maxConnectionsPerHost must_== s2.maxConnectionsPerHost
- s1.maxConnectionsTotal must_== s2.maxConnectionsTotal
- s1.maxConnectionLifetime must_== s2.maxConnectionLifetime
- s1.idleConnectionInPoolTimeout must_== s2.idleConnectionInPoolTimeout
- s1.maxNumberOfRedirects must_== s2.maxNumberOfRedirects
- s1.maxRequestRetry must_== s2.maxRequestRetry
- s1.disableUrlEncoding must_== s2.disableUrlEncoding
- s1.keepAlive must_== s2.keepAlive
+ assert(s1.wsClientConfig.toString == s2.wsClientConfig.toString)
+ assert(s1.maxConnectionsPerHost == s2.maxConnectionsPerHost)
+ assert(s1.maxConnectionsTotal == s2.maxConnectionsTotal)
+ assert(s1.maxConnectionLifetime == s2.maxConnectionLifetime)
+ assert(s1.idleConnectionInPoolTimeout == s2.idleConnectionInPoolTimeout)
+ assert(s1.maxNumberOfRedirects == s2.maxNumberOfRedirects)
+ assert(s1.maxRequestRetry == s2.maxRequestRetry)
+ assert(s1.disableUrlEncoding == s2.disableUrlEncoding)
+ assert(s1.keepAlive == s2.keepAlive)
}
"parse ws ahc section" in {
@@ -54,22 +54,22 @@ class AhcWSClientConfigParserSpec extends Specification {
|play.ws.ahc.keepAlive = false
""".stripMargin)
- actual.maxConnectionsPerHost must_== 3
- actual.maxConnectionsTotal must_== 6
- actual.maxConnectionLifetime must_== 1.minute
- actual.idleConnectionInPoolTimeout must_== 30.seconds
- actual.connectionPoolCleanerPeriod must_== 10.seconds
- actual.maxNumberOfRedirects must_== 0
- actual.maxRequestRetry must_== 99
- actual.disableUrlEncoding must beTrue
- actual.keepAlive must beFalse
+ assert(actual.maxConnectionsPerHost == 3)
+ assert(actual.maxConnectionsTotal == 6)
+ assert(actual.maxConnectionLifetime == 1.minute)
+ assert(actual.idleConnectionInPoolTimeout == 30.seconds)
+ assert(actual.connectionPoolCleanerPeriod == 10.seconds)
+ assert(actual.maxNumberOfRedirects == 0)
+ assert(actual.maxRequestRetry == 99)
+ assert(actual.disableUrlEncoding)
+ assert(actual.keepAlive == false)
}
"with keepAlive" should {
"parse keepAlive default as true" in {
val actual = parseThis("""""".stripMargin)
- actual.keepAlive must beTrue
+ assert(actual.keepAlive)
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestSpec.scala
index c6194e7c..38cc7924 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSRequestSpec.scala
@@ -12,9 +12,9 @@ import org.apache.pekko.stream.Materializer
import org.apache.pekko.util.ByteString
import org.mockito.Mockito
-import org.specs2.execute.Result
-import org.specs2.mutable.Specification
-import org.specs2.specification.AfterAll
+import org.scalatest.BeforeAndAfterAll
+import org.scalatest.OptionValues
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.oauth.ConsumerKey
import play.api.libs.oauth.RequestToken
@@ -28,9 +28,12 @@ import play.shaded.ahc.org.asynchttpclient.{ Request => AHCRequest }
import scala.reflect.ClassTag
-class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReadables with DefaultBodyWritables {
-
- sequential
+class AhcWSRequestSpec
+ extends AnyWordSpec
+ with BeforeAndAfterAll
+ with DefaultBodyReadables
+ with DefaultBodyWritables
+ with OptionValues {
private def mock[A](implicit a: ClassTag[A]): A =
Mockito.mock(a.runtimeClass).asInstanceOf[A]
@@ -44,11 +47,11 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
system.terminate()
}
- def withClient(block: StandaloneWSClient => Result): Result = {
+ def withClient[A](block: StandaloneWSClient => A): A = {
block(wsClient)
}
- "Given the full URL" in {
+ "Given the full URL" should {
implicit val materializer: Materializer = mock[org.apache.pekko.stream.Materializer]
val client = mock[StandaloneAhcWSClient]
@@ -56,46 +59,56 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
"request withQueryStringParameters" in {
val request = StandaloneAhcWSRequest(client, "http://example.com")
- request.uri.toString must equalTo("http://example.com")
- request.withQueryStringParameters("bar" -> "baz").uri.toString must equalTo("http://example.com?bar=baz")
- request.withQueryStringParameters("bar" -> "baz", "bar" -> "bah").uri.toString must equalTo(
- "http://example.com?bar=bah&bar=baz"
+ assert(request.uri.toString == "http://example.com")
+ assert(request.withQueryStringParameters("bar" -> "baz").uri.toString == "http://example.com?bar=baz")
+ assert(
+ request
+ .withQueryStringParameters("bar" -> "baz", "bar" -> "bah")
+ .uri
+ .toString == "http://example.com?bar=bah&bar=baz"
)
}
"correctly URL-encode the query string part" in {
val request = StandaloneAhcWSRequest(client, "http://example.com")
- request.withQueryStringParameters("&" -> "=").uri.toString must equalTo("http://example.com?%26=%3D")
+ assert(request.withQueryStringParameters("&" -> "=").uri.toString == "http://example.com?%26=%3D")
}
"set all query string parameters" in {
val request = StandaloneAhcWSRequest(client, "http://example.com")
- request.withQueryStringParameters("bar" -> "baz").uri.toString must equalTo("http://example.com?bar=baz")
- request.withQueryStringParameters("bar" -> "baz", "bar" -> "bah").uri.toString must equalTo(
- "http://example.com?bar=bah&bar=baz"
+ assert(request.withQueryStringParameters("bar" -> "baz").uri.toString == "http://example.com?bar=baz")
+ assert(
+ request
+ .withQueryStringParameters("bar" -> "baz", "bar" -> "bah")
+ .uri
+ .toString == "http://example.com?bar=bah&bar=baz"
)
}
"discard old query parameters when setting new ones" in {
val request = StandaloneAhcWSRequest(client, "http://example.com")
- request
- .withQueryStringParameters("bar" -> "baz")
- .withQueryStringParameters("bar" -> "bah")
- .uri
- .toString must equalTo("http://example.com?bar=bah")
+ assert(
+ request
+ .withQueryStringParameters("bar" -> "baz")
+ .withQueryStringParameters("bar" -> "bah")
+ .uri
+ .toString == "http://example.com?bar=bah"
+ )
}
"add query string param" in {
val request = StandaloneAhcWSRequest(client, "http://example.com")
- request
- .withQueryStringParameters("bar" -> "baz")
- .addQueryStringParameters("bar" -> "bah")
- .uri
- .toString must equalTo("http://example.com?bar=bah&bar=baz")
+ assert(
+ request
+ .withQueryStringParameters("bar" -> "baz")
+ .addQueryStringParameters("bar" -> "bah")
+ .uri
+ .toString == "http://example.com?bar=bah&bar=baz"
+ )
}
"support adding several query string values for a parameter" in {
@@ -104,9 +117,10 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withQueryStringParameters("play" -> "foo1")
.addQueryStringParameters("play" -> "foo2")
- newRequest.queryString.get("play") must beSome[Seq[String]].which(_.contains("foo1"))
- newRequest.queryString.get("play") must beSome[Seq[String]].which(_.contains("foo2"))
- newRequest.queryString.get("play") must beSome[Seq[String]].which(_.size == 2)
+ val actual = newRequest.queryString.get("play").value
+ assert(actual.contains("foo1"))
+ assert(actual.contains("foo2"))
+ assert(actual.size == 2)
}
"support several query string values for a parameter" in {
@@ -118,16 +132,16 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.buildRequest()
val paramsList: Seq[Param] = req.getQueryParams.asScala.toSeq
- paramsList.exists(p => (p.getName == "foo") && (p.getValue == "foo1")) must beTrue
- paramsList.exists(p => (p.getName == "foo") && (p.getValue == "foo2")) must beTrue
- paramsList.count(p => p.getName == "foo") must beEqualTo(2)
+ assert(paramsList.exists(p => (p.getName == "foo") && (p.getValue == "foo1")))
+ assert(paramsList.exists(p => (p.getName == "foo") && (p.getValue == "foo2")))
+ assert(paramsList.count(p => p.getName == "foo") == 2)
}
}
}
- "For Cookies" in {
+ "For Cookies" should {
def cookie(name: String, value: String): WSCookie = DefaultWSCookie(name, value)
@@ -139,9 +153,9 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getCookies.asScala must size(1)
- req.getCookies.asScala.head.name must beEqualTo("cookie1")
- req.getCookies.asScala.head.value must beEqualTo("value1")
+ assert(req.getCookies.asScala.size == 1)
+ assert(req.getCookies.asScala.head.name == "cookie1")
+ assert(req.getCookies.asScala.head.value == "value1")
}
}
@@ -153,12 +167,12 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getCookies.asScala must size(2)
- req.getCookies.asScala.head.name must beEqualTo("cookie1")
- req.getCookies.asScala.head.value must beEqualTo("value1")
+ assert(req.getCookies.asScala.size == 2)
+ assert(req.getCookies.asScala.head.name == "cookie1")
+ assert(req.getCookies.asScala.head.value == "value1")
- req.getCookies.asScala(1).name must beEqualTo("cookie2")
- req.getCookies.asScala(1).value must beEqualTo("value2")
+ assert(req.getCookies.asScala(1).name == "cookie2")
+ assert(req.getCookies.asScala(1).value == "value2")
}
}
@@ -171,12 +185,12 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getCookies.asScala must size(2)
- req.getCookies.asScala.head.name must beEqualTo("cookie1")
- req.getCookies.asScala.head.value must beEqualTo("value1")
+ assert(req.getCookies.asScala.size == 2)
+ assert(req.getCookies.asScala.head.name == "cookie1")
+ assert(req.getCookies.asScala.head.value == "value1")
- req.getCookies.asScala(1).name must beEqualTo("cookie2")
- req.getCookies.asScala(1).value must beEqualTo("value2")
+ assert(req.getCookies.asScala(1).name == "cookie2")
+ assert(req.getCookies.asScala(1).value == "value2")
}
}
@@ -189,12 +203,12 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getCookies.asScala must size(2)
- req.getCookies.asScala.head.name must beEqualTo("cookie3")
- req.getCookies.asScala.head.value must beEqualTo("value3")
+ assert(req.getCookies.asScala.size == 2)
+ assert(req.getCookies.asScala.head.name == "cookie3")
+ assert(req.getCookies.asScala.head.value == "value3")
- req.getCookies.asScala(1).name must beEqualTo("cookie4")
- req.getCookies.asScala(1).value must beEqualTo("value4")
+ assert(req.getCookies.asScala(1).name == "cookie4")
+ assert(req.getCookies.asScala(1).value == "value4")
}
}
@@ -207,13 +221,13 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.entries.asScala must size(1)
- req.getHeaders.get("Cookie") must beEqualTo("cookie1=value1, cookie2=value2")
+ assert(req.getHeaders.entries.asScala.size == 1)
+ assert(req.getHeaders.get("Cookie") == "cookie1=value1, cookie2=value2")
}
}
}
- "For HTTP Headers" in {
+ "For HTTP Headers" should {
"support setting headers" in {
withClient { client =>
@@ -222,7 +236,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withHttpHeaders("key" -> "value1", "key" -> "value2")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.getAll("key").asScala must containTheSameElementsAs(Seq("value1", "value2"))
+ assert(req.getHeaders.getAll("key").asScala.toSet == Set("value1", "value2"))
}
}
@@ -234,8 +248,8 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withHttpHeaders("key2" -> "value2")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get("key1") must beNull
- req.getHeaders.get("key2") must beEqualTo("value2")
+ assert(req.getHeaders.get("key1") == null)
+ assert(req.getHeaders.get("key2") == "value2")
}
}
@@ -247,7 +261,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.addHttpHeaders("key" -> "value2")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.getAll("key").asScala must containTheSameElementsAs(Seq("value1", "value2"))
+ assert(req.getHeaders.getAll("key").asScala.toSet == Set("value1", "value2"))
}
}
@@ -259,8 +273,8 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.addHttpHeaders("key2" -> "value2")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get("key1") must beEqualTo("value1")
- req.getHeaders.get("key2") must beEqualTo("value2")
+ assert(req.getHeaders.get("key1") == "value1")
+ assert(req.getHeaders.get("key2") == "value2")
}
}
@@ -274,8 +288,10 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withBody("I am a text/plain body")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.getAll(HttpHeaderNames.CONTENT_TYPE.toString()).asScala must_== Seq(
- "fake/contenttype; charset=utf-8"
+ assert(
+ req.getHeaders.getAll(HttpHeaderNames.CONTENT_TYPE.toString()).asScala == Seq(
+ "fake/contenttype; charset=utf-8"
+ )
)
}
}
@@ -287,7 +303,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withHttpHeaders("key" -> "value1", "KEY" -> "value2")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.getAll("key").asScala must containTheSameElementsAs(Seq("value1", "value2"))
+ assert(req.getHeaders.getAll("key").asScala.toSet == Set("value1", "value2"))
}
}
@@ -297,7 +313,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.url("http://playframework.com/")
.withHttpHeaders("Key1" -> "value1", "Key2" -> "value2")
- req.header("Key1") must beSome("value1")
+ assert(req.header("Key1") == Some("value1"))
}
}
@@ -307,7 +323,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.url("http://playframework.com/")
.withHttpHeaders("Key1" -> "value1", "Key1" -> "value2", "Key2" -> "some")
- req.headerValues("Key1") must containTheSameElementsAs(Seq("value1", "value2"))
+ assert(req.headerValues("Key1").toSet == Set("value1", "value2"))
}
}
@@ -317,7 +333,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.url("http://playframework.com/")
.withHttpHeaders("Key1" -> "value1", "Key1" -> "value2", "Key2" -> "some")
- req.header("Non") must beNone
+ assert(req.header("Non").isEmpty)
}
}
@@ -327,7 +343,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.url("http://playframework.com/")
.withHttpHeaders("Key1" -> "value1", "Key1" -> "value2", "Key2" -> "some")
- req.headerValues("Non") must beEmpty
+ assert(req.headerValues("Non").isEmpty)
}
}
@@ -337,13 +353,13 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.url("http://playframework.com/")
.withHttpHeaders("Key1" -> "value1", "Key1" -> "value2", "Key2" -> "value")
- req.headers("Key1") must containTheSameElementsAs(Seq("value1", "value2"))
- req.headers("Key2") must containTheSameElementsAs(Seq("value"))
+ assert(req.headers("Key1").toSet == Set("value1", "value2"))
+ assert(req.headers("Key2").toSet == Set("value"))
}
}
}
- "For requests with body" in {
+ "For requests with body" should {
"Have form params for content type application/x-www-form-urlencoded" in {
withClient { client =>
@@ -352,7 +368,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withBody(Map("param1" -> Seq("value1")))
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (new String(req.getByteData, "UTF-8")) must_== "param1=value1"
+ assert((new String(req.getByteData, "UTF-8")) == "param1=value1")
}
}
@@ -369,13 +385,15 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
// Note we use getFormParams instead of getByteData here.
- req.getFormParams.asScala must containTheSameElementsAs(
- List(new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1"))
+ assert(
+ req.getFormParams.asScala.toSet == List(
+ new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1")
+ ).toSet
)
- req.getByteData must beNull // should NOT result in byte data.
+ assert(req.getByteData == null) // should NOT result in byte data.
val headers = req.getHeaders
- headers.get("Content-Length") must beNull
+ assert(headers.get("Content-Length") == null)
}
}
@@ -391,7 +409,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- reqEmptyParams.getFormParams.asScala must beEmpty
+ assert(reqEmptyParams.getFormParams.asScala.isEmpty)
}
}
@@ -404,9 +422,9 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (new String(req.getByteData, "UTF-8")) must be_==("HELLO WORLD")
+ assert((new String(req.getByteData, "UTF-8")) == "HELLO WORLD")
val headers = req.getHeaders
- headers.get("Content-Length") must beNull
+ assert(headers.get("Content-Length") == null)
}
}
@@ -421,7 +439,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withBody("HELLO WORLD") // and body is set to string (see #5221)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (new String(req.getByteData, "UTF-8")) must be_==("HELLO WORLD") // should result in byte data.
+ assert((new String(req.getByteData, "UTF-8")) == "HELLO WORLD") // should result in byte data.
}
}
@@ -434,7 +452,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- ByteString(req.getByteData) must_== binData
+ assert(ByteString(req.getByteData) == binData)
}
"Preserve existing headers when setting the body" in {
@@ -445,12 +463,12 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withBody("HELLO WORLD") // will set content-type header
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get("Some-Header") must beEqualTo("Some-Value")
+ assert(req.getHeaders.get("Some-Header") == "Some-Value")
}
}
}
- "When using a Proxy Server" in {
+ "When using a Proxy Server" should {
"support a proxy server with basic" in withClient { client =>
val proxy = DefaultWSProxyServer(
@@ -467,11 +485,11 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.buildRequest()
val actual = req.getProxyServer
- (actual.getHost must be).equalTo("localhost")
- (actual.getPort must be).equalTo(8080)
- (actual.getRealm.getPrincipal must be).equalTo("principal")
- (actual.getRealm.getPassword must be).equalTo("password")
- (actual.getRealm.getScheme must be).equalTo(AuthScheme.BASIC)
+ assert(actual.getHost == "localhost")
+ assert(actual.getPort == 8080)
+ assert(actual.getRealm.getPrincipal == "principal")
+ assert(actual.getRealm.getPassword == "password")
+ assert(actual.getRealm.getScheme == AuthScheme.BASIC)
}
"support a proxy server with NTLM" in withClient { client =>
@@ -490,12 +508,12 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.buildRequest()
val actual = req.getProxyServer
- (actual.getHost must be).equalTo("localhost")
- (actual.getPort must be).equalTo(8080)
- (actual.getRealm.getPrincipal must be).equalTo("principal")
- (actual.getRealm.getPassword must be).equalTo("password")
- (actual.getRealm.getNtlmDomain must be).equalTo("somentlmdomain")
- (actual.getRealm.getScheme must be).equalTo(AuthScheme.NTLM)
+ assert(actual.getHost == "localhost")
+ assert(actual.getPort == 8080)
+ assert(actual.getRealm.getPrincipal == "principal")
+ assert(actual.getRealm.getPassword == "password")
+ assert(actual.getRealm.getNtlmDomain == "somentlmdomain")
+ assert(actual.getRealm.getScheme == AuthScheme.NTLM)
}
"support a proxy server" in withClient { client =>
@@ -507,19 +525,19 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.buildRequest()
val actual = req.getProxyServer
- (actual.getHost must be).equalTo("localhost")
- (actual.getPort must be).equalTo(8080)
- actual.getRealm must beNull
+ assert(actual.getHost == "localhost")
+ assert(actual.getPort == 8080)
+ assert(actual.getRealm == null)
}
}
- "StandaloneAhcWSRequest supports" in {
+ "StandaloneAhcWSRequest supports" should {
"replace url" in withClient { client =>
val req = client
.url("http://playframework.com/")
.withUrl("http://www.example.com/")
- req.url must_=== "http://www.example.com/"
+ assert(req.url == "http://www.example.com/")
}
"a custom signature calculator" in {
@@ -538,7 +556,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.sign(calc)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- called must beTrue
+ assert(called)
}
}
@@ -548,7 +566,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withVirtualHost("192.168.1.1")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (req.getVirtualHost must be).equalTo("192.168.1.1")
+ assert(req.getVirtualHost == "192.168.1.1")
}
"follow redirects" in withClient { client =>
@@ -557,7 +575,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withFollowRedirects(follow = true)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getFollowRedirect must beEqualTo(true)
+ assert(req.getFollowRedirect == true)
}
"enable url encoding by default" in withClient { client =>
@@ -566,7 +584,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.addQueryStringParameters("abc+def" -> "uvw+xyz")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getUrl must beEqualTo("http://playframework.com/?abc%2Bdef=uvw%2Bxyz")
+ assert(req.getUrl == "http://playframework.com/?abc%2Bdef=uvw%2Bxyz")
}
"disable url encoding globally via client config" in {
@@ -576,7 +594,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.addQueryStringParameters("abc+def" -> "uvw+xyz")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getUrl must beEqualTo("http://playframework.com/?abc+def=uvw+xyz")
+ assert(req.getUrl == "http://playframework.com/?abc+def=uvw+xyz")
}
"disable url encoding for specific request only" in withClient { client =>
@@ -586,7 +604,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withDisableUrlEncoding(disableUrlEncoding = true)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getUrl must beEqualTo("http://playframework.com/?abc+def=uvw+xyz")
+ assert(req.getUrl == "http://playframework.com/?abc+def=uvw+xyz")
}
"finite timeout" in withClient { client =>
@@ -595,7 +613,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withRequestTimeout(1000.millis)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (req.getRequestTimeout must be).equalTo(1000)
+ assert(req.getRequestTimeout == 1000)
}
"infinite timeout" in withClient { client =>
@@ -604,28 +622,30 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withRequestTimeout(Duration.Inf)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (req.getRequestTimeout must be).equalTo(-1)
+ assert(req.getRequestTimeout == -1)
}
"no negative timeout" in withClient { client =>
- client.url("http://playframework.com/").withRequestTimeout(-1.millis) should throwAn[IllegalArgumentException]
+ assertThrows[IllegalArgumentException] { client.url("http://playframework.com/").withRequestTimeout(-1.millis) }
}
"no timeout greater than Int.MaxValue" in withClient { client =>
- client
- .url("http://playframework.com/")
- .withRequestTimeout((Int.MaxValue.toLong + 1).millis) should throwAn[IllegalArgumentException]
+ assertThrows[IllegalArgumentException] {
+ client
+ .url("http://playframework.com/")
+ .withRequestTimeout((Int.MaxValue.toLong + 1).millis)
+ }
}
}
- "Set Realm.UsePreemptiveAuth" in {
+ "Set Realm.UsePreemptiveAuth" should {
"to false when WSAuthScheme.DIGEST being used" in withClient { client =>
val req = client
.url("http://playframework.com/")
.withAuth("usr", "pwd", WSAuthScheme.DIGEST)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getRealm.isUsePreemptiveAuth must beFalse
+ assert(req.getRealm.isUsePreemptiveAuth == false)
}
"to true when WSAuthScheme.DIGEST not being used" in withClient { client =>
@@ -634,7 +654,7 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withAuth("usr", "pwd", WSAuthScheme.BASIC)
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getRealm.isUsePreemptiveAuth must beTrue
+ assert(req.getRealm.isUsePreemptiveAuth)
}
}
@@ -646,10 +666,10 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- (new String(req.getByteData, "UTF-8")) must be_==("param1=value1") // should result in byte data.
+ assert((new String(req.getByteData, "UTF-8")) == "param1=value1") // should result in byte data.
val headers = req.getHeaders
- headers.get("Content-Length") must_== "9001"
+ assert(headers.get("Content-Length") == "9001")
}
"Remove a user defined content length header if we are parsing body explicitly when signed" in withClient { client =>
@@ -666,11 +686,11 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.buildRequest()
val headers = req.getHeaders
- req.getByteData must beNull // should NOT result in byte data.
- req.getFormParams.asScala must containTheSameElementsAs(
- List(new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1"))
+ assert(req.getByteData == null) // should NOT result in byte data.
+ assert(
+ req.getFormParams.asScala.toSet == List(new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1")).toSet
)
- headers.get("Content-Length") must beNull // no content length!
+ assert(headers.get("Content-Length") == null) // no content length!
}
"Verify Content-Type header is passed through correctly" in withClient { client =>
@@ -681,7 +701,9 @@ class AhcWSRequestSpec extends Specification with AfterAll with DefaultBodyReada
.withBody("HELLO WORLD")
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.getAll(HttpHeaderNames.CONTENT_TYPE.toString()).asScala must_== Seq("text/plain; charset=US-ASCII")
+ assert(
+ req.getHeaders.getAll(HttpHeaderNames.CONTENT_TYPE.toString()).asScala == Seq("text/plain; charset=US-ASCII")
+ )
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSResponseSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSResponseSpec.scala
index eeebc303..f0ddf358 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSResponseSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/AhcWSResponseSpec.scala
@@ -10,7 +10,8 @@ import java.util
import org.apache.pekko.util.ByteString
import org.mockito.Mockito.when
import org.mockito.Mockito
-import org.specs2.mutable.Specification
+import org.scalatest.OptionValues
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.ws._
import play.shaded.ahc.io.netty.handler.codec.http.DefaultHttpHeaders
import play.shaded.ahc.io.netty.handler.codec.http.cookie.DefaultCookie
@@ -19,7 +20,7 @@ import play.shaded.ahc.org.asynchttpclient.{ Response => AHCResponse }
import scala.reflect.ClassTag
-class AhcWSResponseSpec extends Specification with DefaultBodyReadables with DefaultBodyWritables {
+class AhcWSResponseSpec extends AnyWordSpec with DefaultBodyReadables with DefaultBodyWritables with OptionValues {
private def mock[A](implicit a: ClassTag[A]): A =
Mockito.mock(a.runtimeClass).asInstanceOf[A]
@@ -39,13 +40,13 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
val cookies: Seq[WSCookie] = response.cookies
val cookie = cookies.head
- cookie.name must ===(name)
- cookie.value must ===(value)
- cookie.path must beSome(path)
- cookie.domain must beSome(domain)
- cookie.maxAge must beSome(maxAge)
- cookie.secure must beFalse
- cookie.httpOnly must beFalse
+ assert(cookie.name == name)
+ assert(cookie.value == value)
+ assert(cookie.path == Some(path))
+ assert(cookie.domain == Some(domain))
+ assert(cookie.maxAge == Some(maxAge))
+ assert(cookie.secure == false)
+ assert(cookie.httpOnly == false)
}
"get a single cookie from an AHC response" in {
@@ -58,16 +59,14 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
val response = StandaloneAhcWSResponse(ahcResponse)
- val optionCookie = response.cookie("someName")
- optionCookie must beSome[WSCookie].which { cookie =>
- cookie.name must ===(name)
- cookie.value must ===(value)
- cookie.path must beSome(path)
- cookie.domain must beSome(domain)
- cookie.maxAge must beSome(maxAge)
- cookie.secure must beFalse
- cookie.httpOnly must beFalse
- }
+ val cookie = response.cookie("someName").value
+ assert(cookie.name == name)
+ assert(cookie.value == value)
+ assert(cookie.path == Some(path))
+ assert(cookie.domain == Some(domain))
+ assert(cookie.maxAge == Some(maxAge))
+ assert(cookie.secure == false)
+ assert(cookie.httpOnly == false)
}
"return -1 values of expires and maxAge as None" in {
@@ -78,10 +77,8 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
val response = StandaloneAhcWSResponse(ahcResponse)
- val optionCookie = response.cookie("someName")
- optionCookie must beSome[WSCookie].which { cookie =>
- cookie.maxAge must beNone
- }
+ val cookie = response.cookie("someName").value
+ assert(cookie.maxAge.isEmpty)
}
"get the body as bytes from the AHC response" in {
@@ -89,7 +86,7 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
val bytes = ByteString(-87, -72, 96, -63, -32, 46, -117, -40, -128, -7, 61, 109, 80, 45, 44, 30)
when(ahcResponse.getResponseBodyAsBytes).thenReturn(bytes.toArray)
val response = StandaloneAhcWSResponse(ahcResponse)
- response.body[ByteString] must_== bytes
+ assert(response.body[ByteString] == bytes)
}
"get JSON body as a string from the AHC response" in {
@@ -100,70 +97,70 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
when(ahcResponse.getResponseBody(StandardCharsets.UTF_8)).thenReturn(json)
val response = StandaloneAhcWSResponse(ahcResponse)
- response.body[String] must_== json
- }
-
- "get text body as a string from the AHC response" in {
- val ahcResponse: AHCResponse = mock[AHCResponse]
- val text = "Hello ☺"
- when(ahcResponse.getContentType).thenReturn("text/plain")
- when(ahcResponse.getResponseBody(StandardCharsets.ISO_8859_1)).thenReturn(text)
- val response = StandaloneAhcWSResponse(ahcResponse)
- response.body[String] must_== text
+ assert(response.body[String] == json)
}
+ }
- "get headers from an AHC response in a case insensitive map" in {
- val ahcResponse: AHCResponse = mock[AHCResponse]
- val ahcHeaders = new DefaultHttpHeaders(true)
- ahcHeaders.add("Foo", "bar")
- ahcHeaders.add("Foo", "baz")
- ahcHeaders.add("Bar", "baz")
- when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
- val response = StandaloneAhcWSResponse(ahcResponse)
- val headers = response.headers
- headers must beEqualTo(Map("Foo" -> Seq("bar", "baz"), "Bar" -> Seq("baz")))
- headers.contains("foo") must beTrue
- headers.contains("Foo") must beTrue
- headers.contains("BAR") must beTrue
- headers.contains("Bar") must beTrue
- }
+ "get text body as a string from the AHC response" in {
+ val ahcResponse: AHCResponse = mock[AHCResponse]
+ val text = "Hello ☺"
+ when(ahcResponse.getContentType).thenReturn("text/plain")
+ when(ahcResponse.getResponseBody(StandardCharsets.ISO_8859_1)).thenReturn(text)
+ val response = StandaloneAhcWSResponse(ahcResponse)
+ assert(response.body[String] == text)
+ }
- "get a single header" in {
- val ahcResponse: AHCResponse = mock[AHCResponse]
- val ahcHeaders = new DefaultHttpHeaders(true)
- ahcHeaders.add("Foo", "bar")
- ahcHeaders.add("Foo", "baz")
- ahcHeaders.add("Bar", "baz")
- when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
- val response = StandaloneAhcWSResponse(ahcResponse)
+ "get headers from an AHC response in a case insensitive map" in {
+ val ahcResponse: AHCResponse = mock[AHCResponse]
+ val ahcHeaders = new DefaultHttpHeaders(true)
+ ahcHeaders.add("Foo", "bar")
+ ahcHeaders.add("Foo", "baz")
+ ahcHeaders.add("Bar", "baz")
+ when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
+ val response = StandaloneAhcWSResponse(ahcResponse)
+ val headers = response.headers
+ assert(headers == Map("Foo" -> Seq("bar", "baz"), "Bar" -> Seq("baz")))
+ assert(headers.contains("foo"))
+ assert(headers.contains("Foo"))
+ assert(headers.contains("BAR"))
+ assert(headers.contains("Bar"))
+ }
- response.header("Foo") must beSome("bar")
- response.header("Bar") must beSome("baz")
- }
+ "get a single header" in {
+ val ahcResponse: AHCResponse = mock[AHCResponse]
+ val ahcHeaders = new DefaultHttpHeaders(true)
+ ahcHeaders.add("Foo", "bar")
+ ahcHeaders.add("Foo", "baz")
+ ahcHeaders.add("Bar", "baz")
+ when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
+ val response = StandaloneAhcWSResponse(ahcResponse)
+
+ assert(response.header("Foo") == Some("bar"))
+ assert(response.header("Bar") == Some("baz"))
+ }
- "get none when header does not exists" in {
- val ahcResponse: AHCResponse = mock[AHCResponse]
- val ahcHeaders = new DefaultHttpHeaders(true)
- ahcHeaders.add("Foo", "bar")
- ahcHeaders.add("Foo", "baz")
- ahcHeaders.add("Bar", "baz")
- when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
- val response = StandaloneAhcWSResponse(ahcResponse)
+ "get none when header does not exists" in {
+ val ahcResponse: AHCResponse = mock[AHCResponse]
+ val ahcHeaders = new DefaultHttpHeaders(true)
+ ahcHeaders.add("Foo", "bar")
+ ahcHeaders.add("Foo", "baz")
+ ahcHeaders.add("Bar", "baz")
+ when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
+ val response = StandaloneAhcWSResponse(ahcResponse)
- response.header("Non") must beNone
- }
+ assert(response.header("Non").isEmpty)
+ }
- "get all values for a header" in {
- val ahcResponse: AHCResponse = mock[AHCResponse]
- val ahcHeaders = new DefaultHttpHeaders(true)
- ahcHeaders.add("Foo", "bar")
- ahcHeaders.add("Foo", "baz")
- ahcHeaders.add("Bar", "baz")
- when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
- val response = StandaloneAhcWSResponse(ahcResponse)
+ "get all values for a header" in {
+ val ahcResponse: AHCResponse = mock[AHCResponse]
+ val ahcHeaders = new DefaultHttpHeaders(true)
+ ahcHeaders.add("Foo", "bar")
+ ahcHeaders.add("Foo", "baz")
+ ahcHeaders.add("Bar", "baz")
+ when(ahcResponse.getHeaders).thenReturn(ahcHeaders)
+ val response = StandaloneAhcWSResponse(ahcResponse)
- response.headerValues("Foo") must beEqualTo(Seq("bar", "baz"))
- }
+ assert(response.headerValues("Foo") == Seq("bar", "baz"))
}
def asCookie(
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/AhcWSCacheSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/AhcWSCacheSpec.scala
index c077ab0d..acd69788 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/AhcWSCacheSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/AhcWSCacheSpec.scala
@@ -8,14 +8,15 @@ import java.net.URI
import org.playframework.cachecontrol.HttpDate._
import org.playframework.cachecontrol._
-import org.specs2.mutable.Specification
+import org.scalatest.OptionValues
+import org.scalatest.wordspec.AnyWordSpec
import play.shaded.ahc.io.netty.handler.codec.http.DefaultHttpHeaders
import play.shaded.ahc.io.netty.handler.codec.http.HttpHeaders
import play.shaded.ahc.org.asynchttpclient.DefaultAsyncHttpClientConfig
import play.shaded.ahc.org.asynchttpclient.Request
import play.shaded.ahc.org.asynchttpclient.RequestBuilder
-class AhcWSCacheSpec extends Specification {
+class AhcWSCacheSpec extends AnyWordSpec with OptionValues {
"freshness heuristics flag" should {
@@ -31,11 +32,9 @@ class AhcWSCacheSpec extends Specification {
val response: CacheResponse =
StoredResponse(uri, 200, Map(HeaderName("Last-Modified") -> Seq(lastModifiedDate)), "GET", Map())
- val actual = cache.calculateFreshnessFromHeuristic(request, response)
+ val actual = cache.calculateFreshnessFromHeuristic(request, response).value
- actual must beSome[Seconds].which { case value =>
- value must be_==(Seconds.seconds(360)) // 0.1 hours
- }
+ assert(actual == Seconds.seconds(360)) // 0.1 hours
}
"be disabled when set to false" in {
@@ -52,7 +51,7 @@ class AhcWSCacheSpec extends Specification {
val actual = cache.calculateFreshnessFromHeuristic(request, response)
- actual must beNone
+ assert(actual.isEmpty)
}
}
@@ -70,13 +69,10 @@ class AhcWSCacheSpec extends Specification {
val request = generateRequest(url)(headers => headers.add("Accept-Encoding", "gzip"))
val response = CacheableResponse(200, url, achConfig).withHeaders("Vary" -> "Accept-Encoding")
- val actual = cache.calculateSecondaryKeys(request, response)
-
- actual must beSome[Map[HeaderName, Seq[String]]].which { d =>
- d must haveKey(HeaderName("Accept-Encoding"))
- d(HeaderName("Accept-Encoding")) must be_==(Seq("gzip"))
- }
+ val d = cache.calculateSecondaryKeys(request, response).value
+ assert(d.isDefinedAt(HeaderName("Accept-Encoding")))
+ assert(d(HeaderName("Accept-Encoding")) == Seq("gzip"))
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/BackgroundAsyncHandlerSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/BackgroundAsyncHandlerSpec.scala
index 38c57623..5d2ad89b 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/BackgroundAsyncHandlerSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/BackgroundAsyncHandlerSpec.scala
@@ -4,9 +4,9 @@
package play.api.libs.ws.ahc.cache
-import org.specs2.mutable.Specification
+import org.scalatest.wordspec.AnyWordSpec
-class BackgroundAsyncHandlerSpec extends Specification {
+class BackgroundAsyncHandlerSpec extends AnyWordSpec {
"BackgroundAsyncHandler" should {
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheAsyncHandlerSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheAsyncHandlerSpec.scala
index 70a3ee8e..106b3392 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheAsyncHandlerSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheAsyncHandlerSpec.scala
@@ -4,9 +4,9 @@
package play.api.libs.ws.ahc.cache
-import org.specs2.mutable.Specification
+import org.scalatest.wordspec.AnyWordSpec
-class CacheAsyncHandlerSpec extends Specification {
+class CacheAsyncHandlerSpec extends AnyWordSpec {
"CacheAsyncHandlerSpec" should {
diff --git a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheableResponseSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheableResponseSpec.scala
index fd668627..f448d314 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheableResponseSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/api/libs/ws/ahc/cache/CacheableResponseSpec.scala
@@ -4,38 +4,38 @@
package play.api.libs.ws.ahc.cache
-import org.specs2.mutable.Specification
+import org.scalatest.wordspec.AnyWordSpec
import play.shaded.ahc.io.netty.handler.codec.http.HttpHeaders.Names._
import play.shaded.ahc.org.asynchttpclient.DefaultAsyncHttpClientConfig
-class CacheableResponseSpec extends Specification {
+class CacheableResponseSpec extends AnyWordSpec {
val achConfig = new DefaultAsyncHttpClientConfig.Builder().build()
"CacheableResponse" should {
- "get body" in {
+ "get body" should {
"when it is text/plain" in {
val response = CacheableResponse(200, "https://playframework.com/", "PlayFramework Homepage", achConfig)
.withHeaders(CONTENT_TYPE -> "text/plain")
- response.getResponseBody must beEqualTo("PlayFramework Homepage")
- response.getContentType must beEqualTo("text/plain")
+ assert(response.getResponseBody == "PlayFramework Homepage")
+ assert(response.getContentType == "text/plain")
}
"when it is application/json" in {
val response = CacheableResponse(200, "https://playframework.com/", """{ "a": "b" }""", achConfig).withHeaders(
"Content-Type" -> "application/json"
)
- response.getResponseBody must beEqualTo("""{ "a": "b" }""")
- response.getContentType must beEqualTo("application/json")
+ assert(response.getResponseBody == """{ "a": "b" }""")
+ assert(response.getContentType == "application/json")
}
"when it is application/json; charset=utf-8" in {
val response = CacheableResponse(200, "https://playframework.com/", """{ "a": "b" }""", achConfig).withHeaders(
"Content-Type" -> "application/json; charset=utf-8"
)
- response.getResponseBody must beEqualTo("""{ "a": "b" }""")
- response.getContentType must beEqualTo("application/json; charset=utf-8")
+ assert(response.getResponseBody == """{ "a": "b" }""")
+ assert(response.getContentType == "application/json; charset=utf-8")
}
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSRequestSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSRequestSpec.scala
index 24b14fb3..71836e3b 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSRequestSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSRequestSpec.scala
@@ -9,7 +9,7 @@ import com.typesafe.config.ConfigFactory
import java.time.Duration
import java.util.Collections
-import org.specs2.mutable._
+import org.scalatest.wordspec.AnyWordSpec
import play.libs.oauth.OAuth
import play.libs.ws._
import play.shaded.ahc.io.netty.handler.codec.http.HttpHeaderNames
@@ -21,7 +21,7 @@ import scala.jdk.CollectionConverters._
import scala.collection.mutable
import scala.jdk.OptionConverters._
-class AhcWSRequestSpec extends Specification with DefaultBodyReadables with DefaultBodyWritables {
+class AhcWSRequestSpec extends AnyWordSpec with DefaultBodyReadables with DefaultBodyWritables {
"AhcWSRequest" should {
@@ -30,8 +30,8 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
AhcWSClientConfigFactory.forConfig(ConfigFactory.load(), this.getClass.getClassLoader), /*materializer*/ null
)
val request = new StandaloneAhcWSRequest(client, "http://example.com", /*materializer*/ null)
- request.getMethod must be_==("GET")
- request.buildRequest().getMethod must be_==("GET")
+ assert(request.getMethod == "GET")
+ assert(request.buildRequest().getMethod == "GET")
}
"Set virtualHost appropriately" in {
@@ -41,7 +41,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
val request = new StandaloneAhcWSRequest(client, "http://example.com", /*materializer*/ null)
request.setVirtualHost("foo.com")
val actual = request.buildRequest().getVirtualHost()
- actual must beEqualTo("foo.com")
+ assert(actual == "foo.com")
}
"set the url" in {
@@ -49,15 +49,13 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
AhcWSClientConfigFactory.forConfig(ConfigFactory.load(), this.getClass.getClassLoader), /*materializer*/ null
)
val req = new StandaloneAhcWSRequest(client, "http://playframework.com/", null)
- (req.getUrl must be_===("http://playframework.com/")).and {
- val setReq = req.setUrl("http://example.com")
- (setReq.getUrl must be_===("http://example.com")).and {
- setReq must be_===(req)
- }
- }
+ assert(req.getUrl == "http://playframework.com/")
+ val setReq = req.setUrl("http://example.com")
+ assert(setReq.getUrl == "http://example.com")
+ assert(setReq == req)
}
- "For POST requests" in {
+ "For POST requests" should {
"get method" in {
val client = StandaloneAhcWSClient.create(
@@ -66,7 +64,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
val req = new StandaloneAhcWSRequest(client, "http://playframework.com/", null)
.setMethod("POST")
- req.getMethod must be_===("POST")
+ assert(req.getMethod == "POST")
}
"set text/plain content-types for text bodies" in {
@@ -77,7 +75,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.setBody(body("HELLO WORLD"))
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getStringData must be_==("HELLO WORLD")
+ assert(req.getStringData == "HELLO WORLD")
}
"sets content type based on a body when its not explicitly set" in {
@@ -89,8 +87,8 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
- req.getHeaders.get(HttpHeaderNames.CONTENT_TYPE) must be_==("text/plain; charset=UTF-8")
- req.getStringData must be_==("HELLO WORLD")
+ assert(req.getHeaders.get(HttpHeaderNames.CONTENT_TYPE) == "text/plain; charset=UTF-8")
+ assert(req.getStringData == "HELLO WORLD")
}
"keep existing content type when setting body" in {
@@ -104,11 +102,9 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.buildRequest()
// preserve the content type
- req.getHeaders.get(HttpHeaderNames.CONTENT_TYPE) must be_==(
- "text/plain+hello; charset=UTF-8"
- )
+ assert(req.getHeaders.get(HttpHeaderNames.CONTENT_TYPE) == "text/plain+hello; charset=UTF-8")
// should result in byte data.
- req.getStringData must be_==("HELLO WORLD")
+ assert(req.getStringData == "HELLO WORLD")
}
"have form params when passing in map" in {
@@ -122,11 +118,13 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.buildRequest()
// Must set the form url encoding autoomatically.
- req.getHeaders.get("Content-Type") must be_==("application/x-www-form-urlencoded")
+ assert(req.getHeaders.get("Content-Type") == "application/x-www-form-urlencoded")
// Note we use getFormParams instead of getByteData here.
- req.getFormParams.asScala must containTheSameElementsAs(
- List(new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1"))
+ assert(
+ req.getFormParams.asScala.toSet == Set(
+ new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1")
+ )
)
}
@@ -145,8 +143,10 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.asInstanceOf[StandaloneAhcWSRequest]
.buildRequest()
// Note we use getFormParams instead of getByteData here.
- req.getFormParams.asScala must containTheSameElementsAs(
- List(new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1"))
+ assert(
+ req.getFormParams.asScala.toSet == Set(
+ new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1")
+ )
)
}
@@ -167,10 +167,12 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.buildRequest()
val headers = req.getHeaders
- req.getFormParams.asScala must containTheSameElementsAs(
- List(new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1"))
+ assert(
+ req.getFormParams.asScala.toSet == Set(
+ new play.shaded.ahc.org.asynchttpclient.Param("param1", "value1")
+ )
)
- headers.get("Content-Length") must beNull // no content length!
+ assert(headers.get("Content-Length") == null) // no content length!
}
}
@@ -188,32 +190,32 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
new StandaloneAhcWSRequest(client, "http://playframework.com/", null)
.sign(calc)
.buildRequest()
- called must beTrue
+ assert(called)
}
"setRequestTimeout(java.time.Duration)" should {
"support setting a request timeout to a duration" in {
- requestWithTimeout(Duration.ofSeconds(1)) must beEqualTo(1000)
+ assert(requestWithTimeout(Duration.ofSeconds(1)) == 1000)
}
"support setting a request timeout duration to infinite using -1" in {
- requestWithTimeout(Duration.ofMillis(-1)) must beEqualTo(-1)
+ assert(requestWithTimeout(Duration.ofMillis(-1)) == -1)
}
"support setting a request timeout duration to infinite using any negative duration" in {
- requestWithTimeout(Duration.ofMillis(-2)) must beEqualTo(-1)
- requestWithTimeout(Duration.ofMillis(-15)) must beEqualTo(-1)
- requestWithTimeout(Duration.ofSeconds(-1)) must beEqualTo(-1)
- requestWithTimeout(Duration.ofMillis(java.lang.Integer.MIN_VALUE)) must beEqualTo(-1)
+ assert(requestWithTimeout(Duration.ofMillis(-2)) == -1)
+ assert(requestWithTimeout(Duration.ofMillis(-15)) == -1)
+ assert(requestWithTimeout(Duration.ofSeconds(-1)) == -1)
+ assert(requestWithTimeout(Duration.ofMillis(java.lang.Integer.MIN_VALUE)) == -1)
}
"support setting a request timeout duration to Long.MAX_VALUE as infinite" in {
- requestWithTimeout(Duration.ofMillis(java.lang.Long.MAX_VALUE)) must beEqualTo(-1)
+ assert(requestWithTimeout(Duration.ofMillis(java.lang.Long.MAX_VALUE)) == -1)
}
"not support setting a request timeout to null" in {
- requestWithTimeout(null) must throwA[IllegalArgumentException]
+ assertThrows[IllegalArgumentException] { requestWithTimeout(null) }
}
}
@@ -225,7 +227,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
request.setBody(body("HELLO WORLD", null)) // content type is not set
request.addHeader("Content-Type", "application/json") // will be used as content type is not set with a body
val req = request.buildRequest()
- req.getHeaders.get("Content-Type") must be_==("application/json")
+ assert(req.getHeaders.get("Content-Type") == "application/json")
}
"ignore explicit Content-Type header if the BodyWritable already set the Content-Type" in {
@@ -236,7 +238,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
request.setBody(body("HELLO WORLD"))
request.addHeader("Content-Type", "application/json") // will be ignored since body already sets content type
val req = request.buildRequest()
- req.getHeaders.get("Content-Type") must be_==("text/plain; charset=UTF-8")
+ assert(req.getHeaders.get("Content-Type") == "text/plain; charset=UTF-8")
}
"only send first Content-Type header and keep the charset when setting the Content-Type multiple times" in {
@@ -248,7 +250,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
request.addHeader("Content-Type", "application/xml")
request.setBody(body("HELLO WORLD")) // content type is not overwritten here as its already set before
val req = request.buildRequest()
- req.getHeaders.get("Content-Type") must be_==("application/json; charset=US-ASCII")
+ assert(req.getHeaders.get("Content-Type") == "application/json; charset=US-ASCII")
}
"Set Realm.UsePreemptiveAuth to false when WSAuthScheme.DIGEST being used" in {
@@ -258,7 +260,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
val request = new StandaloneAhcWSRequest(client, "http://example.com", /*materializer*/ null)
request.setAuth("usr", "pwd", WSAuthScheme.DIGEST)
val req = request.buildRequest()
- req.getRealm.isUsePreemptiveAuth must beFalse
+ assert(req.getRealm.isUsePreemptiveAuth == false)
}
"Set Realm.UsePreemptiveAuth to true when WSAuthScheme.DIGEST not being used" in {
@@ -268,10 +270,10 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
val request = new StandaloneAhcWSRequest(client, "http://example.com", /*materializer*/ null)
request.setAuth("usr", "pwd", WSAuthScheme.BASIC)
val req = request.buildRequest()
- req.getRealm.isUsePreemptiveAuth must beTrue
+ assert(req.getRealm.isUsePreemptiveAuth)
}
- "For HTTP Headers" in {
+ "For HTTP Headers" should {
"add a new header" in {
val client = StandaloneAhcWSClient.create(
@@ -279,11 +281,13 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
)
val request = new StandaloneAhcWSRequest(client, "http://example.com", /*materializer*/ null)
- request
- .addHeader("header1", "value1")
- .buildRequest()
- .getHeaders
- .get("header1") must beEqualTo("value1")
+ assert(
+ request
+ .addHeader("header1", "value1")
+ .buildRequest()
+ .getHeaders
+ .get("header1") == "value1"
+ )
}
"add new value for existing header" in {
@@ -294,11 +298,11 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header1", "value1")
.addHeader("header1", "value2")
- request.getHeaders.get("header1").asScala.toSet must_== Set("value1", "value2")
+ assert(request.getHeaders.get("header1").asScala.toSet == Set("value1", "value2"))
val ahcRequest = request.buildRequest()
- ahcRequest.getHeaders.getAll("header1").asScala.toSet must_== Set("value1", "value2")
+ assert(ahcRequest.getHeaders.getAll("header1").asScala.toSet == Set("value1", "value2"))
}
"set all headers" in {
@@ -307,11 +311,13 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
)
val request = new StandaloneAhcWSRequest(client, "http://example.com", /*materializer*/ null)
- request
- .setHeaders(Map("header1" -> Seq("value1").asJava, "header2" -> Seq("value2").asJava).asJava)
- .buildRequest()
- .getHeaders
- .get("header1") must beEqualTo("value1")
+ assert(
+ request
+ .setHeaders(Map("header1" -> Seq("value1").asJava, "header2" -> Seq("value2").asJava).asJava)
+ .buildRequest()
+ .getHeaders
+ .get("header1") == "value1"
+ )
}
"keep existing headers when adding a new one" in {
@@ -325,8 +331,8 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header2", "value2")
.buildRequest()
- ahcReq.getHeaders.get("header1") must beEqualTo("value1")
- ahcReq.getHeaders.get("header2") must beEqualTo("value2")
+ assert(ahcReq.getHeaders.get("header1") == "value1")
+ assert(ahcReq.getHeaders.get("header2") == "value2")
}
"treat header names case insensitively" in {
@@ -338,7 +344,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("HEADER1", "value2")
.buildRequest()
- request.getHeaders.getAll("header1").asScala.toSet must_== Set("value1", "value2")
+ assert(request.getHeaders.getAll("header1").asScala.toSet == Set("value1", "value2"))
}
"get a single header" in {
@@ -349,7 +355,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header1", "value1")
.addHeader("header1", "value2")
- request.getHeader("header1").toScala must beSome("value1")
+ assert(request.getHeader("header1").toScala == Some("value1"))
}
"get an empty optional when header is not present" in {
@@ -360,7 +366,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header1", "value1")
.addHeader("header1", "value2")
- request.getHeader("non").toScala must beNone
+ assert(request.getHeader("non").toScala.isEmpty)
}
"get all values for a header" in {
@@ -371,7 +377,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header1", "value1")
.addHeader("header1", "value2")
- request.getHeaderValues("header1").asScala must containTheSameElementsAs(Seq("value1", "value2"))
+ assert(request.getHeaderValues("header1").asScala.toSet == Set("value1", "value2"))
}
"get an empty list when header is not present" in {
@@ -382,7 +388,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header1", "value1")
.addHeader("header1", "value2")
- request.getHeaderValues("Non").asScala must beEmpty
+ assert(request.getHeaderValues("Non").asScala.isEmpty)
}
"get all headers" in {
@@ -395,13 +401,13 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addHeader("header2", "Value1ForHeader2")
val headers = request.getHeaders.asScala
- headers("header1").asScala must containTheSameElementsAs(Seq("Value1ForHeader1", "Value2ForHeader1"))
- headers("header2").asScala must containTheSameElementsAs(Seq("Value1ForHeader2"))
+ assert(headers("header1").asScala.toSet == Set("Value1ForHeader1", "Value2ForHeader1"))
+ assert(headers("header2").asScala.toSet == Set("Value1ForHeader2"))
}
}
- "For query string parameters" in {
+ "For query string parameters" should {
"add query string parameter" in {
val client = StandaloneAhcWSClient.create(
@@ -411,7 +417,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("p1", "v1")
.buildRequest()
- request.getUrl must contain("p1=v1")
+ assert(request.getUrl.contains("p1=v1"))
}
"deterministic query param order a" in {
@@ -423,7 +429,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("p2", "v2")
.buildRequest()
- request.getUrl must contain("p1=v1&p2=v2")
+ assert(request.getUrl.contains("p1=v1&p2=v2"))
}
"deterministic query param order b" in {
@@ -435,7 +441,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("p1", "v1")
.buildRequest()
- request.getUrl must contain("p2=v2&p1=v1")
+ assert(request.getUrl.contains("p2=v2&p1=v1"))
}
"deterministic query param order for duplicate keys" in {
@@ -449,7 +455,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("p1", "v4")
.buildRequest()
- request.getUrl must contain("p1=v1&p1=v3&p1=v4&p2=v2")
+ assert(request.getUrl.contains("p1=v1&p1=v3&p1=v4&p2=v2"))
}
"add new value for existing parameter" in {
@@ -461,8 +467,8 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("p1", "v2")
.buildRequest()
- request.getUrl must contain("p1=v1")
- request.getUrl must contain("p1=v2")
+ assert(request.getUrl.contains("p1=v1"))
+ assert(request.getUrl.contains("p1=v2"))
}
"keep existing parameters when adding a new one" in {
@@ -474,8 +480,8 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("p2", "v2")
.buildRequest()
- request.getUrl must contain("p1=v1")
- request.getUrl must contain("p2=v2")
+ assert(request.getUrl.contains("p1=v1"))
+ assert(request.getUrl.contains("p2=v2"))
}
"set all the parameters" in {
@@ -486,35 +492,35 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.setQueryString(Map("p1" -> Seq("v1").asJava, "p2" -> Seq("v2").asJava).asJava)
.buildRequest()
- request.getUrl must contain("p1=v1")
- request.getUrl must contain("p2=v2")
+ assert(request.getUrl.contains("p1=v1"))
+ assert(request.getUrl.contains("p2=v2"))
}
"set a query string appropriately" in {
val queryParams = requestWithQueryString("q=playframework&src=typd")
- queryParams.size must beEqualTo(2)
- queryParams.exists(p => (p.getName == "q") && (p.getValue == "playframework")) must beTrue
- queryParams.exists(p => (p.getName == "src") && (p.getValue == "typd")) must beTrue
+ assert(queryParams.size == 2)
+ assert(queryParams.exists(p => (p.getName == "q") && (p.getValue == "playframework")))
+ assert(queryParams.exists(p => (p.getName == "src") && (p.getValue == "typd")))
}
"support several query string values for a parameter" in {
val queryParams = requestWithQueryString("q=scala&q=playframework&q=fp")
- queryParams.size must beEqualTo(3)
- queryParams.exists(p => (p.getName == "q") && (p.getValue == "scala")) must beTrue
- queryParams.exists(p => (p.getName == "q") && (p.getValue == "playframework")) must beTrue
- queryParams.exists(p => (p.getName == "q") && (p.getValue == "fp")) must beTrue
- queryParams.count(p => p.getName == "q") must beEqualTo(3)
+ assert(queryParams.size == 3)
+ assert(queryParams.exists(p => (p.getName == "q") && (p.getValue == "scala")))
+ assert(queryParams.exists(p => (p.getName == "q") && (p.getValue == "playframework")))
+ assert(queryParams.exists(p => (p.getName == "q") && (p.getValue == "fp")))
+ assert(queryParams.count(p => p.getName == "q") == 3)
}
"support a query string parameter without value" in {
val queryParams = requestWithQueryString("q=playframework&src=")
- queryParams.size must beEqualTo(2)
- queryParams.exists(p => (p.getName == "q") && (p.getValue == "playframework")) must beTrue
- queryParams.exists(p => (p.getName.equals("src")) && (p.getValue == null)) must beTrue
+ assert(queryParams.size == 2)
+ assert(queryParams.exists(p => (p.getName == "q") && (p.getValue == "playframework")))
+ assert(queryParams.exists(p => (p.getName.equals("src")) && (p.getValue == null)))
}
"not support a query string with more than 2 = per part" in {
- requestWithQueryString("q=scala=playframework&src=typd") must throwA[RuntimeException]
+ assertThrows[RuntimeException] { requestWithQueryString("q=scala=playframework&src=typd") }
}
"support a query string parameter with an encoded equals sign" in {
@@ -526,12 +532,12 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
val queryParams = request.buildRequest().getQueryParams.asScala
val p = queryParams(0)
- p.getName must beEqualTo("bar")
- p.getValue must beEqualTo("F%253Dma")
+ assert(p.getName == "bar")
+ assert(p.getValue == "F%253Dma")
}
"not support a query string if it starts with = and is empty" in {
- requestWithQueryString("=&src=typd") must throwA[RuntimeException]
+ assertThrows[RuntimeException] { requestWithQueryString("=&src=typd") }
}
"enable url encoding by default" in {
@@ -542,7 +548,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("abc+def", "uvw+xyz")
.buildRequest()
- request.getUrl must beEqualTo("http://example.com?abc%2Bdef=uvw%2Bxyz")
+ assert(request.getUrl == "http://example.com?abc%2Bdef=uvw%2Bxyz")
}
"disable url encoding globally via client config" in {
@@ -555,7 +561,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addQueryParameter("abc+def", "uvw+xyz")
.buildRequest()
- request.getUrl must beEqualTo("http://example.com?abc+def=uvw+xyz")
+ assert(request.getUrl == "http://example.com?abc+def=uvw+xyz")
}
"disable url encoding for specific request only" in {
@@ -567,11 +573,11 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.setDisableUrlEncoding(true)
.buildRequest()
- request.getUrl must beEqualTo("http://example.com?abc+def=uvw+xyz")
+ assert(request.getUrl == "http://example.com?abc+def=uvw+xyz")
}
}
- "For Cookies" in {
+ "For Cookies" should {
def cookie(name: String, value: String): WSCookie = {
new WSCookieBuilder().setName(name).setValue(value).build()
@@ -585,10 +591,10 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addCookie(cookie("cookie1", "value1"))
val cookiesInRequest: mutable.Buffer[WSCookie] = request.getCookies.asScala
- cookiesInRequest.size must beEqualTo(1)
+ assert(cookiesInRequest.size == 1)
val cookieInRequest: WSCookie = cookiesInRequest.head
- cookieInRequest.getName must beEqualTo("cookie1")
- cookieInRequest.getValue must beEqualTo("value1")
+ assert(cookieInRequest.getName == "cookie1")
+ assert(cookieInRequest.getValue == "value1")
}
"add a new cookie" in {
@@ -599,7 +605,7 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addCookie(cookie("cookie1", "value1"))
.buildRequest()
- request.getCookies.asScala.head.name must beEqualTo("cookie1")
+ assert(request.getCookies.asScala.head.name == "cookie1")
}
"add more than one cookie" in {
@@ -610,9 +616,9 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addCookies(cookie("cookie1", "value1"), cookie("cookie2", "value2"))
.buildRequest()
- request.getCookies.asScala must size(2)
- request.getCookies.asScala.head.name must beEqualTo("cookie1")
- request.getCookies.asScala(1).name must beEqualTo("cookie2")
+ assert(request.getCookies.asScala.size == 2)
+ assert(request.getCookies.asScala.head.name == "cookie1")
+ assert(request.getCookies.asScala(1).name == "cookie2")
}
"keep existing cookies when adding a new one" in {
@@ -624,9 +630,9 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.addCookie(cookie("cookie2", "value2"))
.buildRequest()
- request.getCookies.asScala must size(2)
- request.getCookies.asScala.head.name must beEqualTo("cookie1")
- request.getCookies.asScala(1).name must beEqualTo("cookie2")
+ assert(request.getCookies.asScala.size == 2)
+ assert(request.getCookies.asScala.head.name == "cookie1")
+ assert(request.getCookies.asScala(1).name == "cookie2")
}
"set all cookies" in {
@@ -637,9 +643,9 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.setCookies(List(cookie("cookie1", "value1"), cookie("cookie2", "value2")).asJava)
.buildRequest()
- request.getCookies.asScala must size(2)
- request.getCookies.asScala.head.name must beEqualTo("cookie1")
- request.getCookies.asScala(1).name must beEqualTo("cookie2")
+ assert(request.getCookies.asScala.size == 2)
+ assert(request.getCookies.asScala.head.name == "cookie1")
+ assert(request.getCookies.asScala(1).name == "cookie2")
}
"discard old cookies when setting" in {
@@ -651,9 +657,9 @@ class AhcWSRequestSpec extends Specification with DefaultBodyReadables with Defa
.setCookies(List(cookie("cookie3", "value1"), cookie("cookie4", "value2")).asJava)
.buildRequest()
- request.getCookies.asScala must size(2)
- request.getCookies.asScala.head.name must beEqualTo("cookie3")
- request.getCookies.asScala(1).name must beEqualTo("cookie4")
+ assert(request.getCookies.asScala.size == 2)
+ assert(request.getCookies.asScala.head.name == "cookie3")
+ assert(request.getCookies.asScala(1).name == "cookie4")
}
}
}
diff --git a/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSResponseSpec.scala b/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSResponseSpec.scala
index 9a08b435..61e8e0e1 100644
--- a/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSResponseSpec.scala
+++ b/play-ahc-ws-standalone/src/test/scala/play/libs/ws/ahc/AhcWSResponseSpec.scala
@@ -6,7 +6,7 @@ package play.libs.ws.ahc
import org.mockito.Mockito.when
import org.mockito.Mockito
-import org.specs2.mutable._
+import org.scalatest.wordspec.AnyWordSpec
import play.libs.ws._
import play.shaded.ahc.io.netty.handler.codec.http.DefaultHttpHeaders
import play.shaded.ahc.org.asynchttpclient.Response
@@ -15,7 +15,7 @@ import scala.jdk.CollectionConverters._
import scala.jdk.OptionConverters._
import scala.reflect.ClassTag
-class AhcWSResponseSpec extends Specification with DefaultBodyReadables with DefaultBodyWritables {
+class AhcWSResponseSpec extends AnyWordSpec with DefaultBodyReadables with DefaultBodyWritables {
private def mock[A](implicit a: ClassTag[A]): A =
Mockito.mock(a.runtimeClass).asInstanceOf[A]
@@ -25,7 +25,7 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
"return the underlying response" in {
val srcResponse = mock[Response]
val response = new StandaloneAhcWSResponse(srcResponse)
- response.getUnderlying must_== srcResponse
+ assert(response.getUnderlying == srcResponse)
}
}
@@ -42,8 +42,8 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
when(srcResponse.getHeaders).thenReturn(srcHeaders)
val response = new StandaloneAhcWSResponse(srcResponse)
val headers = response.getHeaders
- headers.get("foo").asScala must_== Seq("a", "b", "b")
- headers.get("BAR").asScala must_== Seq("baz")
+ assert(headers.get("foo").asScala == Seq("a", "b", "b"))
+ assert(headers.get("BAR").asScala == Seq("baz"))
}
"get a single header" in {
@@ -56,8 +56,8 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
when(srcResponse.getHeaders).thenReturn(srcHeaders)
val response = new StandaloneAhcWSResponse(srcResponse)
- response.getSingleHeader("Foo").toScala must beSome("a")
- response.getSingleHeader("Bar").toScala must beSome("baz")
+ assert(response.getSingleHeader("Foo").toScala == Some("a"))
+ assert(response.getSingleHeader("Bar").toScala == Some("baz"))
}
"get an empty optional when header is not present" in {
@@ -70,7 +70,7 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
when(srcResponse.getHeaders).thenReturn(srcHeaders)
val response = new StandaloneAhcWSResponse(srcResponse)
- response.getSingleHeader("Non").toScala must beNone
+ assert(response.getSingleHeader("Non").toScala.isEmpty)
}
"get all values for a header" in {
@@ -83,7 +83,7 @@ class AhcWSResponseSpec extends Specification with DefaultBodyReadables with Def
when(srcResponse.getHeaders).thenReturn(srcHeaders)
val response = new StandaloneAhcWSResponse(srcResponse)
- response.getHeaderValues("Foo").asScala must containTheSameElementsAs(Seq("a", "b", "b"))
+ assert(response.getHeaderValues("Foo").asScala.toSet == Set("a", "b", "b"))
}
}
diff --git a/play-ws-standalone-json/src/test/scala/play/api/libs/ws/JsonBodyReadablesSpec.scala b/play-ws-standalone-json/src/test/scala/play/api/libs/ws/JsonBodyReadablesSpec.scala
index 2d285368..671a44ec 100644
--- a/play-ws-standalone-json/src/test/scala/play/api/libs/ws/JsonBodyReadablesSpec.scala
+++ b/play-ws-standalone-json/src/test/scala/play/api/libs/ws/JsonBodyReadablesSpec.scala
@@ -9,12 +9,11 @@ import java.nio.charset.StandardCharsets._
import org.apache.pekko.stream.scaladsl.Source
import org.apache.pekko.util.ByteString
-import org.specs2.matcher.MustMatchers
-import org.specs2.mutable.Specification
+import org.scalatest.wordspec.AnyWordSpec
import play.api.libs.json.JsSuccess
import play.api.libs.json.JsValue
-class JsonBodyReadablesSpec extends Specification with MustMatchers {
+class JsonBodyReadablesSpec extends AnyWordSpec {
class StubResponse(byteArray: Array[Byte], charset: Charset = UTF_8) extends StandaloneWSResponse {
override def uri: java.net.URI = ???
@@ -46,7 +45,7 @@ class JsonBodyReadablesSpec extends Specification with MustMatchers {
val charsetName = "UTF-32BE"
val value: JsValue =
readables.readableAsJson.transform(new StubResponse(json.getBytes(charsetName), Charset.forName(charsetName)))
- (value \ "menu" \ "id").validate[String] must beEqualTo(JsSuccess("file"))
+ assert((value \ "menu" \ "id").validate[String] == JsSuccess("file"))
}
"read an encoding of UTF-32LE" in {
@@ -55,7 +54,7 @@ class JsonBodyReadablesSpec extends Specification with MustMatchers {
val charsetName = "UTF-32LE"
val value: JsValue =
readables.readableAsJson.transform(new StubResponse(json.getBytes(charsetName), Charset.forName(charsetName)))
- (value \ "menu" \ "id").validate[String] must beEqualTo(JsSuccess("file"))
+ assert((value \ "menu" \ "id").validate[String] == JsSuccess("file"))
}
"read an encoding of UTF-16BE" in {
@@ -63,7 +62,7 @@ class JsonBodyReadablesSpec extends Specification with MustMatchers {
val json = """{"menu": {"id": "file", "value": "File"} }"""
val charset = UTF_16BE
val value: JsValue = readables.readableAsJson.transform(new StubResponse(json.getBytes(charset), charset))
- (value \ "menu" \ "id").validate[String] must beEqualTo(JsSuccess("file"))
+ assert((value \ "menu" \ "id").validate[String] == JsSuccess("file"))
}
"read an encoding of UTF-16LE" in {
@@ -71,28 +70,28 @@ class JsonBodyReadablesSpec extends Specification with MustMatchers {
val json = """{"menu": {"id": "file", "value": "File"} }"""
val charset = UTF_16LE
val value: JsValue = readables.readableAsJson.transform(new StubResponse(json.getBytes(charset), charset))
- (value \ "menu" \ "id").validate[String] must beEqualTo(JsSuccess("file"))
+ assert((value \ "menu" \ "id").validate[String] == JsSuccess("file"))
}
"read an encoding of UTF-8" in {
val readables = new JsonBodyReadables() {}
val json = """{"menu": {"id": "file", "value": "File"} }"""
val value: JsValue = readables.readableAsJson.transform(new StubResponse(json.getBytes(UTF_8)))
- (value \ "menu" \ "id").validate[String] must beEqualTo(JsSuccess("file"))
+ assert((value \ "menu" \ "id").validate[String] == JsSuccess("file"))
}
"read an encoding of UTF-8 with empty object" in {
val readables = new JsonBodyReadables() {}
val json = "{}"
val value: JsValue = readables.readableAsJson.transform(new StubResponse(json.getBytes(UTF_8)))
- value.toString() must beEqualTo("{}")
+ assert(value.toString() == "{}")
}
"read an encoding of UTF-8 with empty array" in {
val readables = new JsonBodyReadables() {}
val json = "[]"
val value: JsValue = readables.readableAsJson.transform(new StubResponse(json.getBytes(UTF_8)))
- value.toString() must beEqualTo("[]")
+ assert(value.toString() == "[]")
}
}
diff --git a/play-ws-standalone/src/test/scala/play/api/libs/ws/WSConfigParserSpec.scala b/play-ws-standalone/src/test/scala/play/api/libs/ws/WSConfigParserSpec.scala
index 7c71dc04..1e1a3a9b 100644
--- a/play-ws-standalone/src/test/scala/play/api/libs/ws/WSConfigParserSpec.scala
+++ b/play-ws-standalone/src/test/scala/play/api/libs/ws/WSConfigParserSpec.scala
@@ -4,12 +4,12 @@
package play.api.libs.ws
-import org.specs2.mutable._
import com.typesafe.config.ConfigFactory
+import org.scalatest.wordspec.AnyWordSpec
import scala.concurrent.duration._
-class WSConfigParserSpec extends Specification {
+class WSConfigParserSpec extends AnyWordSpec {
"WSConfigParser" should {
@@ -29,17 +29,17 @@ class WSConfigParserSpec extends Specification {
|play.ws.useragent = "FakeUserAgent"
""".stripMargin)
- actual.connectionTimeout must_== 9999.millis
- actual.idleTimeout must_== 666.millis
- actual.requestTimeout must_== 1234.millis
+ assert(actual.connectionTimeout == 9999.millis)
+ assert(actual.idleTimeout == 666.millis)
+ assert(actual.requestTimeout == 1234.millis)
// default: true
- actual.followRedirects must beFalse
+ assert(actual.followRedirects == false)
// default: true
- actual.useProxyProperties must beFalse
+ assert(actual.useProxyProperties == false)
- actual.userAgent must beSome[String].which(_ must_== "FakeUserAgent")
+ assert(actual.userAgent == Some("FakeUserAgent"))
}
}
}
diff --git a/project/Dependencies.scala b/project/Dependencies.scala
index a7ff997f..b675aaa4 100644
--- a/project/Dependencies.scala
+++ b/project/Dependencies.scala
@@ -15,10 +15,7 @@ object Dependencies {
val awaitility = Seq("org.awaitility" % "awaitility" % "4.2.1")
- val specsVersion = "4.20.7"
- val specsBuild = Seq(
- "specs2-core",
- ).map("org.specs2" %% _ % specsVersion)
+ val scalatest = Seq("org.scalatest" %% "scalatest-wordspec" % "3.2.19")
val mockito = Seq("org.mockito" % "mockito-core" % "5.12.0")
@@ -65,7 +62,7 @@ object Dependencies {
val reactiveStreams = Seq("org.reactivestreams" % "reactive-streams" % "1.0.4")
val testDependencies =
- (mockito ++ specsBuild ++ junitInterface ++ assertj ++ awaitility ++ slf4jtest ++ logback).map(_ % Test)
+ (mockito ++ scalatest ++ junitInterface ++ assertj ++ awaitility ++ slf4jtest ++ logback).map(_ % Test)
val standaloneApiWSDependencies = javaxInject ++ sslConfigCore ++ pekkoStreams ++ testDependencies