diff options
author | adamw <adam@warski.org> | 2017-07-09 16:39:29 +0200 |
---|---|---|
committer | adamw <adam@warski.org> | 2017-07-09 16:39:29 +0200 |
commit | 18ed991eefd4ff541e722808f80a48d47df58a57 (patch) | |
tree | b4a1a72825f6d6d7a3adbb2811cef98bdd514ba5 /tests/src/test/scala | |
parent | 820095216e671888cfa607b329d749ba099a7bc1 (diff) | |
download | sttp-18ed991eefd4ff541e722808f80a48d47df58a57.tar.gz sttp-18ed991eefd4ff541e722808f80a48d47df58a57.tar.bz2 sttp-18ed991eefd4ff541e722808f80a48d47df58a57.zip |
Initial version of the URI interpolator
Diffstat (limited to 'tests/src/test/scala')
-rw-r--r-- | tests/src/test/scala/com/softwaremill/sttp/UriInterpolatorTests.scala | 64 |
1 files changed, 52 insertions, 12 deletions
diff --git a/tests/src/test/scala/com/softwaremill/sttp/UriInterpolatorTests.scala b/tests/src/test/scala/com/softwaremill/sttp/UriInterpolatorTests.scala index 0f30f8a..f0eeb1e 100644 --- a/tests/src/test/scala/com/softwaremill/sttp/UriInterpolatorTests.scala +++ b/tests/src/test/scala/com/softwaremill/sttp/UriInterpolatorTests.scala @@ -2,24 +2,64 @@ package com.softwaremill.sttp import java.net.URI -import org.scalatest.{FlatSpec, Matchers} +import org.scalatest.{FunSuite, Matchers} -class UriInterpolatorTests extends FlatSpec with Matchers { +class UriInterpolatorTests extends FunSuite with Matchers { val v1 = "y" val v2 = "a c" - val v2encoded = "a%20c" + val v2queryEncoded = "a+c" + val v2hostEncoded = "a%20c" + val secure = true - val testData: List[(URI, String)] = List( - (uri"http://example.com", "http://example.com"), - (uri"http://example.com?x=y", "http://example.com?x=y"), - (uri"http://example.com?x=$v1", s"http://example.com?x=$v1"), - (uri"http://example.com?x=$v2", s"http://example.com?x=$v2encoded"), - (uri"http://$v1.com", s"http://$v1.com"), - (uri"http://$v1.com?x=$v2", s"http://$v1.com?x=$v2encoded") + val testData: List[(String, List[(URI, String)])] = List( + "basic" -> List( + (uri"http://example.com", "http://example.com"), + (uri"http://example.com?x=y", "http://example.com?x=y") + ), + "scheme" -> List( + (uri"http${if (secure) "s" else ""}://example.com", + s"https://example.com"), + (uri"${if (secure) "https" else "http"}://example.com", + s"https://example.com"), + (uri"${if (secure) "https://" else "http://"}example.com", + s"https://example.com"), + (uri"example.com?a=$v2", s"example.com?a=$v2queryEncoded") + ), + "authority" -> List( + (uri"http://$v1.com", s"http://$v1.com"), + (uri"http://$v2.com", s"http://$v2hostEncoded.com"), + (uri"http://$None.example.com", s"http://example.com"), + (uri"http://${Some("sub")}.example.com", s"http://sub.example.com"), + (uri"http://${List("sub1", "sub2")}.example.com", + s"http://sub1.sub2.example.com"), + (uri"http://${List("sub", "example", "com")}", s"http://sub.example.com") + ), + "authority with parameters" -> List( + (uri"http://$v1.com?x=$v2", s"http://$v1.com?x=$v2queryEncoded") + ), + "query parameter values" -> List( + (uri"http://example.com?x=$v1", s"http://example.com?x=$v1"), + (uri"http://example.com?x=$v2", s"http://example.com?x=$v2queryEncoded") + ), + "optional query parameters" -> List( + (uri"http://example.com?a=$None", s"http://example.com"), + (uri"http://example.com?a=b&c=$None", s"http://example.com?a=b"), + (uri"http://example.com?a=b&c=$None&e=f", s"http://example.com?a=b&e=f"), + (uri"http://example.com?a=${Some(v1)}", s"http://example.com?a=$v1"), + (uri"http://example.com?a=${Some(v1)}&c=d", + s"http://example.com?a=$v1&c=d") + ), + "embed whole url" -> List( + (uri"${"http://example.com/a/b?x=y&1=2"}", + s"http://example.com/a/b?x=y&1=2") + ) ) - for (((interpolated, expected), i) <- testData.zipWithIndex) { - it should s"interpolate to $expected ($i)" in { + for { + (groupName, testCases) <- testData + ((interpolated, expected), i) <- testCases.zipWithIndex + } { + test(s"[$groupName] interpolate to $expected (${i + 1})") { interpolated should be(new URI(expected)) } } |