Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ lazy val server = project.in(file("server"))
Defaults.itSettings,
fork := true, // important: otherwise we run into classloader issues
libraryDependencies ++= Seq(
"com.lihaoyi" %% "cask" % "0.8.3",
"com.lihaoyi" %% "cask" % "0.9.5",
"org.slf4j" % "slf4j-simple" % Slf4jVersion % Optional,
"com.lihaoyi" %% "requests" % "0.8.2" % Test,
"org.scalatest" %% "scalatest" % ScalaTestVersion % "it",
Expand Down
2 changes: 1 addition & 1 deletion core/src/main/scala/replpp/util/ClasspathHelper.scala
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ object ClasspathHelper {
if (debugPrint) println(s"using jar from inherited classpath: $path")
entries.addOne(path)
} else {
if (debugPrint) println(s"exluding jar from inherited classpath (included=$included; excluded=$excluded: $path)")
if (debugPrint) println(s"excluding jar from inherited classpath (included=$included; excluded=$excluded: $path)")
}
}
System.getProperty("java.class.path").split(pathSeparator).filter(_.nonEmpty).map(Paths.get(_)).foreach(addToEntriesMaybe)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ abstract class WebServiceWithWebSocket[T <: HasUUID](
case Some(providedAuth) => areEqual(providedAuth, requiredAuth)
}
}
delegate(Map("isAuthorized" -> isAuthorized))
delegate(request, Map("isAuthorized" -> isAuthorized))
}

private def parseAuthentication(request: Request): Option[UsernamePasswordAuth] =
Expand Down
30 changes: 18 additions & 12 deletions server/src/test/scala/replpp/server/ReplServerTests.scala
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
"asynchronous api" should {
"allow websocket connections to the `/connect` endpoint" in Fixture() { url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") { case cask.Ws.Text(msg) =>
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") { case cask.Ws.Text(msg) =>
wsMsgPromise.success(msg)
}
val wsMsg = Await.result(wsMsgPromise.future, DefaultPromiseAwaitTimeout)
Expand Down Expand Up @@ -80,7 +80,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
"allow fetching the result of a completed query using its UUID" in Fixture() { url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand All @@ -103,7 +103,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
"use predefined code" in Fixture("val foo = 40") { url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand All @@ -126,7 +126,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
"use runBefore code" in Fixture(runBeforeCode = Seq("import Int.MaxValue")) { url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand All @@ -149,7 +149,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
"disallow fetching the result of a completed query with an invalid auth header" in Fixture() { url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand All @@ -172,7 +172,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand All @@ -199,7 +199,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
"write a well-formatted message to a websocket connection when a query failed evaluation" in Fixture() { url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand Down Expand Up @@ -228,7 +228,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
url =>
val wsMsgPromise = scala.concurrent.Promise[String]()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") {
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") {
case cask.Ws.Text(msg) if msg == "connected" =>
connectedPromise.success(msg)
case cask.Ws.Text(msg) =>
Expand All @@ -254,7 +254,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {

"receive error when attempting to retrieve result with invalid uuid" in Fixture() { url =>
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") { case cask.Ws.Text(msg) =>
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") { case cask.Ws.Text(msg) =>
connectedPromise.success(msg)
}
Await.result(connectedPromise.future, Duration(1, SECONDS))
Expand All @@ -266,7 +266,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {

"return a valid JSON response when calling /result with incorrectly-formatted UUID parameter" in Fixture() { url =>
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") { case cask.Ws.Text(msg) =>
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") { case cask.Ws.Text(msg) =>
connectedPromise.success(msg)
}
Await.result(connectedPromise.future, Duration(1, SECONDS))
Expand All @@ -284,7 +284,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {

val rtl: Lock = new ReentrantLock()
val connectedPromise = scala.concurrent.Promise[String]()
cask.util.WsClient.connect(s"$url/connect") { case cask.Ws.Text(msg) =>
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") { case cask.Ws.Text(msg) =>
if (msg == "connected") {
connectedPromise.success(msg)
} else {
Expand Down Expand Up @@ -318,7 +318,7 @@ class ReplServerTests extends AnyWordSpec with Matchers {
val connectedPromise = scala.concurrent.Promise[String]()

val rtl: Lock = new ReentrantLock()
cask.util.WsClient.connect(s"$url/connect") { case cask.Ws.Text(msg) =>
cask.util.WsClient.connect(s"${websocketUrl(url)}/connect") { case cask.Ws.Text(msg) =>
if (msg == "connected") {
connectedPromise.success(msg)
} else {
Expand Down Expand Up @@ -392,6 +392,12 @@ class ReplServerTests extends AnyWordSpec with Matchers {
ujson.read(getResponse.bytes)
}

/**
* org.java_websocket.client.WebSocketClient expects the url scheme to be either `ws` or `wss`,
* and this tests mixes the two cases widely, so I found this to be the simplest way around it...
*/
def websocketUrl(httpUrl: String): String =
httpUrl.replaceFirst("^http://", "ws://")
}

object Fixture {
Expand Down
Loading